2016-05-03 19:29:58 -07:00
|
|
|
// Copyright 2004-present Facebook. All Rights Reserved.
|
|
|
|
|
|
|
|
#ifdef WITH_JSC_EXTRA_TRACING
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <JavaScriptCore/API/JSProfilerPrivate.h>
|
|
|
|
#include <jsc_legacy_profiler.h>
|
2016-11-22 06:05:36 -08:00
|
|
|
#include <jschelpers/JavaScriptCore.h>
|
2016-11-01 11:38:43 -07:00
|
|
|
#include <jschelpers/JSCHelpers.h>
|
|
|
|
#include <jschelpers/Value.h>
|
2016-05-03 19:29:58 -07:00
|
|
|
#include "JSCLegacyProfiler.h"
|
|
|
|
|
2016-11-18 06:25:24 -08:00
|
|
|
using namespace facebook::react;
|
|
|
|
|
2016-05-03 19:29:58 -07:00
|
|
|
static JSValueRef nativeProfilerStart(
|
|
|
|
JSContextRef ctx,
|
|
|
|
JSObjectRef function,
|
|
|
|
JSObjectRef thisObject,
|
|
|
|
size_t argumentCount,
|
|
|
|
const JSValueRef arguments[],
|
|
|
|
JSValueRef* exception) {
|
|
|
|
if (argumentCount < 1) {
|
|
|
|
if (exception) {
|
2016-11-18 06:25:24 -08:00
|
|
|
*exception = Value::makeError(
|
2016-05-03 19:29:58 -07:00
|
|
|
ctx,
|
|
|
|
"nativeProfilerStart: requires at least 1 argument");
|
|
|
|
}
|
2016-11-18 06:25:24 -08:00
|
|
|
return Value::makeUndefined(ctx);
|
2016-05-03 19:29:58 -07:00
|
|
|
}
|
|
|
|
|
2016-11-18 06:25:29 -08:00
|
|
|
auto title = String::adopt(ctx, JSValueToStringCopy(ctx, arguments[0], exception));
|
2016-05-03 19:29:58 -07:00
|
|
|
#if WITH_REACT_INTERNAL_SETTINGS
|
|
|
|
JSStartProfiling(ctx, title, false);
|
|
|
|
#else
|
|
|
|
JSStartProfiling(ctx, title);
|
|
|
|
#endif
|
2016-11-18 06:25:24 -08:00
|
|
|
return Value::makeUndefined(ctx);
|
2016-05-03 19:29:58 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
static JSValueRef nativeProfilerEnd(
|
|
|
|
JSContextRef ctx,
|
|
|
|
JSObjectRef function,
|
|
|
|
JSObjectRef thisObject,
|
|
|
|
size_t argumentCount,
|
|
|
|
const JSValueRef arguments[],
|
|
|
|
JSValueRef* exception) {
|
|
|
|
if (argumentCount < 1) {
|
|
|
|
if (exception) {
|
2016-11-18 06:25:24 -08:00
|
|
|
*exception = Value::makeError(
|
2016-05-03 19:29:58 -07:00
|
|
|
ctx,
|
|
|
|
"nativeProfilerEnd: requires at least 1 argument");
|
|
|
|
}
|
2016-11-18 06:25:24 -08:00
|
|
|
return Value::makeUndefined(ctx);
|
2016-05-03 19:29:58 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
std::string writeLocation("/sdcard/");
|
|
|
|
if (argumentCount > 1) {
|
2016-11-18 06:25:29 -08:00
|
|
|
auto fileName = String::adopt(
|
2016-11-22 06:05:38 -08:00
|
|
|
ctx, JSC_JSValueToStringCopy(ctx, arguments[1], exception));
|
2016-11-18 06:25:29 -08:00
|
|
|
writeLocation += fileName.str();
|
2016-05-03 19:29:58 -07:00
|
|
|
} else {
|
|
|
|
writeLocation += "profile.json";
|
|
|
|
}
|
2016-11-18 06:25:29 -08:00
|
|
|
auto title = String::adopt(
|
2016-11-22 06:05:38 -08:00
|
|
|
ctx, JSC_JSValueToStringCopy(ctx, arguments[0], exception));
|
2016-05-03 19:29:58 -07:00
|
|
|
JSEndProfilingAndRender(ctx, title, writeLocation.c_str());
|
2016-11-18 06:25:24 -08:00
|
|
|
return Value::makeUndefined(ctx);
|
2016-05-03 19:29:58 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
namespace facebook {
|
|
|
|
namespace react {
|
|
|
|
|
|
|
|
void stopAndOutputProfilingFile(
|
|
|
|
JSContextRef ctx,
|
|
|
|
JSStringRef title,
|
|
|
|
const char *filename) {
|
|
|
|
JSEndProfilingAndRender(ctx, title, filename);
|
|
|
|
}
|
|
|
|
|
|
|
|
void addNativeProfilingHooks(JSGlobalContextRef ctx) {
|
2016-07-26 07:20:34 -07:00
|
|
|
// JSEnableByteCodeProfiling();
|
2016-05-03 19:29:58 -07:00
|
|
|
installGlobalFunction(ctx, "nativeProfilerStart", nativeProfilerStart);
|
|
|
|
installGlobalFunction(ctx, "nativeProfilerEnd", nativeProfilerEnd);
|
|
|
|
}
|
|
|
|
|
|
|
|
} }
|
|
|
|
|
|
|
|
#endif
|