/** * Copyright (c) 2015-present, Facebook, Inc. * All rights reserved. * * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. */ #import #import "RCTPerformanceLogger.h" #import "RCTRootView.h" static int64_t RCTPLData[RCTPLSize][2] = {}; void RCTPerformanceLoggerStart(RCTPLTag tag) { RCTPLData[tag][0] = CACurrentMediaTime() * 1000; } void RCTPerformanceLoggerEnd(RCTPLTag tag) { RCTPLData[tag][1] = CACurrentMediaTime() * 1000; } NSArray *RCTPerformanceLoggerOutput(void) { return @[ @(RCTPLData[RCTPLScriptDownload][0]), @(RCTPLData[RCTPLScriptDownload][1]), @(RCTPLData[RCTPLScriptExecution][0]), @(RCTPLData[RCTPLScriptExecution][1]), @(RCTPLData[RCTPLNativeModuleInit][0]), @(RCTPLData[RCTPLNativeModuleInit][1]), @(RCTPLData[RCTPLNativeModulePrepareConfig][0]), @(RCTPLData[RCTPLNativeModulePrepareConfig][1]), @(RCTPLData[RCTPLNativeModuleInjectConfig][0]), @(RCTPLData[RCTPLNativeModuleInjectConfig][1]), @(RCTPLData[RCTPLTTI][0]), @(RCTPLData[RCTPLTTI][1]), ]; } @interface RCTPerformanceLogger : NSObject @end @implementation RCTPerformanceLogger RCT_EXPORT_MODULE() @synthesize bridge = _bridge; - (instancetype)init { if ((self = [super init])) { [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(sendTimespans) name:RCTContentDidAppearNotification object:nil]; } return self; } - (void)dealloc { [[NSNotificationCenter defaultCenter] removeObserver:self]; } - (void)sendTimespans { [[NSNotificationCenter defaultCenter] removeObserver:self]; [_bridge enqueueJSCall:@"PerformanceLogger.addTimespans" args:@[ RCTPerformanceLoggerOutput(), @[ @"ScriptDownload", @"ScriptExecution", @"NativeModuleInit", @"NativeModulePrepareConfig", @"NativeModuleInjectConfig", @"TTI", ], ]]; } @end