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"
|
2015-10-13 03:43:43 -07:00
|
|
|
#import "RCTLog.h"
|
2015-06-19 14:59:42 -07:00
|
|
|
|
|
|
|
static int64_t RCTPLData[RCTPLSize][2] = {};
|
|
|
|
|
|
|
|
void RCTPerformanceLoggerStart(RCTPLTag tag)
|
|
|
|
{
|
|
|
|
RCTPLData[tag][0] = CACurrentMediaTime() * 1000;
|
2015-10-13 03:43:43 -07:00
|
|
|
RCTPLData[tag][1] = 0;
|
2015-06-19 14:59:42 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
void RCTPerformanceLoggerEnd(RCTPLTag tag)
|
|
|
|
{
|
2015-10-13 03:43:43 -07:00
|
|
|
if (RCTPLData[tag][0] != 0 && RCTPLData[tag][1] == 0) {
|
|
|
|
RCTPLData[tag][1] = CACurrentMediaTime() * 1000;
|
|
|
|
} else {
|
|
|
|
RCTLogInfo(@"Unbalanced calls start/end for tag %li", (unsigned long)tag);
|
|
|
|
}
|
2015-06-19 14:59:42 -07:00
|
|
|
}
|
|
|
|
|
2015-10-21 10:53:35 -07:00
|
|
|
void RCTPerformanceLoggerSet(RCTPLTag tag, int64_t value)
|
|
|
|
{
|
|
|
|
RCTPLData[tag][0] = 0;
|
|
|
|
RCTPLData[tag][1] = value;
|
|
|
|
}
|
|
|
|
|
2015-11-03 14:45:46 -08:00
|
|
|
NSArray<NSNumber *> *RCTPerformanceLoggerOutput(void)
|
2015-06-19 14:59:42 -07:00
|
|
|
{
|
|
|
|
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-08 08:41:55 -07:00
|
|
|
@(RCTPLData[RCTPLNativeModulePrepareConfig][0]),
|
|
|
|
@(RCTPLData[RCTPLNativeModulePrepareConfig][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-10-21 10:53:35 -07:00
|
|
|
@(RCTPLData[RCTPLBundleSize][0]),
|
|
|
|
@(RCTPLData[RCTPLBundleSize][1]),
|
2015-06-19 14:59:42 -07:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2015-10-30 16:51:48 -07:00
|
|
|
NSArray *RCTPerformanceLoggerLabels(void)
|
|
|
|
{
|
|
|
|
return @[
|
|
|
|
@"ScriptDownload",
|
|
|
|
@"ScriptExecution",
|
|
|
|
@"NativeModuleInit",
|
|
|
|
@"NativeModulePrepareConfig",
|
|
|
|
@"NativeModuleInjectConfig",
|
|
|
|
@"TTI",
|
|
|
|
@"BundleSize",
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
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(),
|
2015-10-30 16:51:48 -07:00
|
|
|
RCTPerformanceLoggerLabels(),
|
2015-06-19 14:59:42 -07:00
|
|
|
]];
|
|
|
|
}
|
|
|
|
|
|
|
|
@end
|