2015-06-19 14:59:42 -07:00
|
|
|
/**
|
|
|
|
* 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 <QuartzCore/QuartzCore.h>
|
|
|
|
|
|
|
|
#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 @[
|
2015-08-21 11:33:04 -07:00
|
|
|
@(RCTPLData[RCTPLScriptDownload][0]),
|
|
|
|
@(RCTPLData[RCTPLScriptDownload][1]),
|
|
|
|
@(RCTPLData[RCTPLScriptExecution][0]),
|
|
|
|
@(RCTPLData[RCTPLScriptExecution][1]),
|
|
|
|
@(RCTPLData[RCTPLNativeModuleInit][0]),
|
|
|
|
@(RCTPLData[RCTPLNativeModuleInit][1]),
|
2015-10-05 10:53:33 -07:00
|
|
|
@(RCTPLData[RCTPLNativeModuleInjectConfig][0]),
|
|
|
|
@(RCTPLData[RCTPLNativeModuleInjectConfig][1]),
|
2015-08-21 11:33:04 -07:00
|
|
|
@(RCTPLData[RCTPLTTI][0]),
|
|
|
|
@(RCTPLData[RCTPLTTI][1]),
|
2015-06-19 14:59:42 -07:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
@interface RCTPerformanceLogger : NSObject <RCTBridgeModule>
|
|
|
|
|
|
|
|
@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
|
|
|
|
{
|
2015-07-09 07:26:54 -07:00
|
|
|
[[NSNotificationCenter defaultCenter] removeObserver:self];
|
|
|
|
|
2015-06-19 14:59:42 -07:00
|
|
|
[_bridge enqueueJSCall:@"PerformanceLogger.addTimespans" args:@[
|
|
|
|
RCTPerformanceLoggerOutput(),
|
|
|
|
@[
|
|
|
|
@"ScriptDownload",
|
|
|
|
@"ScriptExecution",
|
2015-08-21 11:33:04 -07:00
|
|
|
@"NativeModuleInit",
|
2015-10-05 10:53:33 -07:00
|
|
|
@"NativeModuleInjectConfig",
|
2015-06-19 14:59:42 -07:00
|
|
|
@"TTI",
|
|
|
|
],
|
|
|
|
]];
|
|
|
|
}
|
|
|
|
|
|
|
|
@end
|