Fix ReactPerf markers in Systrace

Reviewed By: @spicyj

Differential Revision: D2468107
This commit is contained in:
Tadeu Zagallo 2015-10-01 14:08:13 -07:00 committed by facebook-github-bot-3
parent d447edc5ed
commit d96748492f
3 changed files with 42 additions and 30 deletions

View File

@ -133,7 +133,9 @@ function setUpWebSockets() {
function setupProfile() { function setupProfile() {
console.profile = console.profile || GLOBAL.nativeTraceBeginSection || function () {}; console.profile = console.profile || GLOBAL.nativeTraceBeginSection || function () {};
console.profileEnd = console.profileEnd || GLOBAL.nativeTraceEndSection || function () {}; console.profileEnd = console.profileEnd || GLOBAL.nativeTraceEndSection || function () {};
require('BridgeProfiling').swizzleReactPerf(); if (__DEV__) {
require('BridgeProfiling').swizzleReactPerf();
}
} }
function setUpProcessEnv() { function setUpProcessEnv() {

View File

@ -14,9 +14,24 @@
var GLOBAL = GLOBAL || this; var GLOBAL = GLOBAL || this;
var TRACE_TAG_REACT_APPS = 1 << 17; var TRACE_TAG_REACT_APPS = 1 << 17;
var _enabled = false;
var _ReactPerf = null;
function ReactPerf() {
if (!_ReactPerf) {
_ReactPerf = require('ReactPerf');
}
return _ReactPerf;
}
var BridgeProfiling = { var BridgeProfiling = {
setEnabled(enabled: boolean) {
_enabled = enabled;
ReactPerf().enableMeasure = enabled;
},
profile(profileName?: any) { profile(profileName?: any) {
if (GLOBAL.__BridgeProfilingIsProfiling) { if (_enabled) {
profileName = typeof profileName === 'function' ? profileName = typeof profileName === 'function' ?
profileName() : profileName; profileName() : profileName;
console.profile(TRACE_TAG_REACT_APPS, profileName); console.profile(TRACE_TAG_REACT_APPS, profileName);
@ -24,29 +39,28 @@ var BridgeProfiling = {
}, },
profileEnd() { profileEnd() {
if (GLOBAL.__BridgeProfilingIsProfiling) { if (_enabled) {
console.profileEnd(TRACE_TAG_REACT_APPS); console.profileEnd(TRACE_TAG_REACT_APPS);
} }
}, },
swizzleReactPerf() { reactPerfMeasure(objName: string, fnName: string, func: any): any {
var ReactPerf = require('ReactPerf'); return function (component) {
var originalMeasure = ReactPerf.measure; if (!_enabled) {
ReactPerf.measure = function (objName, fnName, func) { return func.apply(this, arguments);
func = originalMeasure.apply(ReactPerf, arguments); }
return function (component) {
if (GLOBAL.__BridgeProfilingIsProfiling) { var name = objName === 'ReactCompositeComponent' && this.getName() || '';
var name = this._instance && this._instance.constructor && BridgeProfiling.profile(`${objName}.${fnName}(${name})`);
(this._instance.constructor.displayName || var ret = func.apply(this, arguments);
this._instance.constructor.name); BridgeProfiling.profileEnd();
BridgeProfiling.profile(`${objName}.${fnName}(${name})`); return ret;
}
var ret = func.apply(this, arguments);
BridgeProfiling.profileEnd();
return ret;
};
}; };
}, },
swizzleReactPerf() {
ReactPerf().injection.injectMeasure(BridgeProfiling.reactPerfMeasure);
},
}; };
module.exports = BridgeProfiling; module.exports = BridgeProfiling;

View File

@ -336,17 +336,13 @@ static void RCTInstallJSCProfiler(RCTBridge *bridge, JSContextRef context)
- (void)toggleProfilingFlag:(NSNotification *)notification - (void)toggleProfilingFlag:(NSNotification *)notification
{ {
JSObjectRef globalObject = JSContextGetGlobalObject(_context.ctx); [self executeBlockOnJavaScriptQueue:^{
BOOL enabled = [notification.name isEqualToString:RCTProfileDidStartProfiling];
bool enabled = [notification.name isEqualToString:RCTProfileDidStartProfiling]; NSString *script = [NSString stringWithFormat:@"var p = require('BridgeProfiling') || {}; p.setEnabled && p.setEnabled(%@)", enabled ? @"true" : @"false"];
JSStringRef JSName = JSStringCreateWithUTF8CString("__BridgeProfilingIsProfiling"); JSStringRef scriptJSRef = JSStringCreateWithUTF8CString(script.UTF8String);
JSObjectSetProperty(_context.ctx, JSEvaluateScript(_context.ctx, scriptJSRef, NULL, NULL, 0, NULL);
globalObject, JSStringRelease(scriptJSRef);
JSName, }];
JSValueMakeBoolean(_context.ctx, enabled),
kJSPropertyAttributeNone,
NULL);
JSStringRelease(JSName);
} }
- (void)_addNativeHook:(JSObjectCallAsFunctionCallback)hook withName:(const char *)name - (void)_addNativeHook:(JSObjectCallAsFunctionCallback)hook withName:(const char *)name