mirror of
https://github.com/status-im/react-native.git
synced 2025-01-25 08:48:58 +00:00
8ad09987e5
Reviewed By: javache Differential Revision: D2564757 fb-gh-sync-id: c4429b735482ee6405b936e2dcdf610e9c6ad35f
104 lines
2.6 KiB
Objective-C
104 lines
2.6 KiB
Objective-C
/**
|
|
* 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"
|
|
#import "RCTLog.h"
|
|
|
|
static int64_t RCTPLData[RCTPLSize][2] = {};
|
|
|
|
void RCTPerformanceLoggerStart(RCTPLTag tag)
|
|
{
|
|
RCTPLData[tag][0] = CACurrentMediaTime() * 1000;
|
|
RCTPLData[tag][1] = 0;
|
|
}
|
|
|
|
void RCTPerformanceLoggerEnd(RCTPLTag tag)
|
|
{
|
|
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);
|
|
}
|
|
}
|
|
|
|
void RCTPerformanceLoggerSet(RCTPLTag tag, int64_t value)
|
|
{
|
|
RCTPLData[tag][0] = 0;
|
|
RCTPLData[tag][1] = value;
|
|
}
|
|
|
|
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]),
|
|
@(RCTPLData[RCTPLBundleSize][0]),
|
|
@(RCTPLData[RCTPLBundleSize][1]),
|
|
];
|
|
}
|
|
|
|
@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
|
|
{
|
|
[[NSNotificationCenter defaultCenter] removeObserver:self];
|
|
|
|
[_bridge enqueueJSCall:@"PerformanceLogger.addTimespans" args:@[
|
|
RCTPerformanceLoggerOutput(),
|
|
@[
|
|
@"ScriptDownload",
|
|
@"ScriptExecution",
|
|
@"NativeModuleInit",
|
|
@"NativeModulePrepareConfig",
|
|
@"NativeModuleInjectConfig",
|
|
@"TTI",
|
|
@"BundleSize",
|
|
],
|
|
]];
|
|
}
|
|
|
|
@end
|