Proyectos de Subversion Iphone Microlearning

Rev

Autoría | Ultima modificación | Ver Log |

// Copyright 2020 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//      http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#import "FirebasePerformance/Sources/Timer/FPRCounterList.h"

#import "FirebasePerformance/Sources/AppActivity/FPRSessionDetails.h"

#import "FirebasePerformance/Sources/AppActivity/FPRTraceBackgroundActivityTracker.h"

#import "FirebasePerformance/Sources/FPRClient+Private.h"
#import "FirebasePerformance/Sources/FPRClient.h"

/**
 * Extension that is added on top of the class FIRTrace to make the private properties visible
 * between the implementation file and the unit tests.
 */
@interface FIRTrace ()

/** @brief NSTimeInterval for which the trace was active. */
@property(nonatomic, assign, readonly) NSTimeInterval totalTraceTimeInterval;

/** @brief Start time of the trace since epoch. */
@property(nonatomic, assign, readonly) NSTimeInterval startTimeSinceEpoch;

/**
 * Starts a stage with the given name. Multiple stages can have a same name. Starting a new stage
 * would stop the previous active stage if any.
 *
 * @param stageName name of the Stage.
 */
- (void)startStageNamed:(nonnull NSString *)stageName;

/** @brief List of stages in the trace. */
@property(nonnull, nonatomic) FPRClient *fprClient;

/** @brief List of stages in the trace. */
@property(nonnull, nonatomic) NSMutableArray<FIRTrace *> *stages;

/** @brief The current active stage. */
@property(nullable, nonatomic) FIRTrace *activeStage;

/** List of counters managed by the Trace. */
@property(nonnull, nonatomic, readonly) FPRCounterList *counterList;

/** Background state of the trace. */
@property(nonatomic, readonly) FPRTraceState backgroundTraceState;

/** @brief List of sessions the trace is associated with. */
@property(nonatomic, readwrite, nonnull) NSMutableArray<FPRSessionDetails *> *activeSessions;

/** @brief Serial queue to manage sessionId updates. */
@property(nonnull, nonatomic, readonly) dispatch_queue_t sessionIdSerialQueue;

/**
 * Verifies if the trace contains all necessary and valid information.
 *
 * @return A boolean stating if the Trace is complete.
 */
- (BOOL)isCompleteAndValid;

@end