| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- // 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/AppActivity/FPRScreenTraceTracker.h"
- #import <Foundation/Foundation.h>
- #import <QuartzCore/QuartzCore.h>
- #import <stdatomic.h>
- #import "FirebasePerformance/Sources/Common/FPRConstants.h"
- #import "FirebasePerformance/Sources/Timer/FIRTrace+Internal.h"
- @class UIViewController;
- NS_ASSUME_NONNULL_BEGIN
- /** Prefix string for screen traces. */
- FOUNDATION_EXTERN NSString *const kFPRPrefixForScreenTraceName;
- /** Counter name for frozen frames. */
- FOUNDATION_EXTERN NSString *const kFPRFrozenFrameCounterName;
- /** Counter name for slow frames. */
- FOUNDATION_EXTERN NSString *const kFPRSlowFrameCounterName;
- /** Counter name for total frames. */
- FOUNDATION_EXTERN NSString *const kFPRTotalFramesCounterName;
- /** Slow frame threshold (for time difference between current and previous frame render time)
- * in sec.
- */
- FOUNDATION_EXTERN CFTimeInterval const kFPRSlowFrameThreshold;
- /** Frozen frame threshold (for time difference between current and previous frame render time)
- * in sec.
- */
- FOUNDATION_EXTERN CFTimeInterval const kFPRFrozenFrameThreshold;
- @interface FPRScreenTraceTracker ()
- /** A map table of that has the viewControllers as the keys and their associated trace as the value.
- * The key is weakly retained and the value is strongly retained.
- */
- @property(nonatomic) NSMapTable<UIViewController *, FIRTrace *> *activeScreenTraces;
- /** A list of all UIViewController instances that were visible before app was backgrounded. The
- * viewControllers are reatined weakly.
- */
- @property(nonatomic, nullable) NSPointerArray *previouslyVisibleViewControllers;
- /** Serial queue on which all operations that need to be thread safe in this class take place. */
- @property(nonatomic) dispatch_queue_t screenTraceTrackerSerialQueue;
- /** The display link that provides us with the frame rate data. */
- @property(nonatomic) CADisplayLink *displayLink;
- /** Dispatch group which allows us to make this class testable. Instead of waiting an arbitrary
- * amount of time for an asynchronous task to finish before asserting its behavior, we can wait
- * on this dispatch group to finish executing before testing the behavior of any asynchronous
- * task. Consequently, all asynchronous tasks in this class should use this dispatch group.
- */
- @property(nonatomic) dispatch_group_t screenTraceTrackerDispatchGroup;
- /** The frozen frames counter. */
- @property(atomic) int_fast64_t frozenFramesCount;
- /** The total frames counter. */
- @property(atomic) int_fast64_t totalFramesCount;
- /** The slow frames counter. */
- @property(atomic) int_fast64_t slowFramesCount;
- /** Handles the appDidBecomeActive notification. Restores the screen traces that were active before
- * the app was backgrounded.
- *
- * @param notification The NSNotification object.
- */
- - (void)appDidBecomeActiveNotification:(NSNotification *)notification;
- /** Handles the appWillResignActive notification. Saves the names of the screen traces that are
- * currently active and stops all of them.
- *
- * @param notification The NSNotification object.
- */
- - (void)appWillResignActiveNotification:(NSNotification *)notification;
- /** The method that is invoked by the CADisplayLink when a new frame is rendered. */
- - (void)displayLinkStep;
- /** Tells the screen trace tracker that the given viewController appeared. This should be called
- * from the main thread.
- *
- * @param viewController The UIViewController instance that appeared.
- */
- - (void)viewControllerDidAppear:(UIViewController *)viewController;
- /** Tells the screen trace tracker that the given viewController disappeared. This should be called
- * from the main thread.
- *
- * @param viewController The UIViewController instance that disappeared.
- */
- - (void)viewControllerDidDisappear:(id)viewController;
- @end
- NS_ASSUME_NONNULL_END
|