mirror of
https://github.com/status-im/react-native.git
synced 2025-01-15 12:05:06 +00:00
03e1f40c1e
Reviewed By: mhorowitz Differential Revision: D5120975 fbshipit-source-id: 6e9c80a57fdcf7f3dad21d5521fb928b52c924c7
55 lines
1.8 KiB
Plaintext
55 lines
1.8 KiB
Plaintext
// Copyright 2004-present Facebook. All Rights Reserved.
|
|
|
|
/**
|
|
* 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.
|
|
*/
|
|
|
|
#include "RCTJSCHelpers.h"
|
|
|
|
#import <Foundation/Foundation.h>
|
|
|
|
#import <React/RCTBridge+Private.h>
|
|
#import <React/RCTCxxUtils.h>
|
|
#import <React/RCTLog.h>
|
|
#import <cxxreact/Platform.h>
|
|
#import <jschelpers/Value.h>
|
|
|
|
using namespace facebook::react;
|
|
|
|
namespace {
|
|
|
|
JSValueRef nativeLoggingHook(
|
|
JSContextRef ctx, JSObjectRef function, JSObjectRef thisObject, size_t argumentCount,
|
|
const JSValueRef arguments[], JSValueRef *exception) {
|
|
RCTLogLevel level = RCTLogLevelInfo;
|
|
if (argumentCount > 1) {
|
|
level = MAX(level, (RCTLogLevel)Value(ctx, arguments[1]).asNumber());
|
|
}
|
|
if (argumentCount > 0) {
|
|
JSContext *contextObj = contextForGlobalContextRef(JSC_JSContextGetGlobalContext(ctx));
|
|
JSValue *msg = [JSC_JSValue(ctx) valueWithJSValueRef:arguments[0] inContext:contextObj];
|
|
_RCTLogJavaScriptInternal(level, [msg toString]);
|
|
}
|
|
return Value::makeUndefined(ctx);
|
|
}
|
|
|
|
JSValueRef nativePerformanceNow(
|
|
JSContextRef ctx, JSObjectRef function, JSObjectRef thisObject, size_t argumentCount,
|
|
const JSValueRef arguments[], JSValueRef *exception) {
|
|
return Value::makeNumber(ctx, CACurrentMediaTime() * 1000);
|
|
}
|
|
|
|
}
|
|
|
|
void RCTPrepareJSCExecutor() {
|
|
ReactMarker::logTaggedMarker = [](const ReactMarker::ReactMarkerId, const char *tag) {};
|
|
PerfLogging::installNativeHooks = RCTFBQuickPerformanceLoggerConfigureHooks;
|
|
JSNativeHooks::loggingHook = nativeLoggingHook;
|
|
JSNativeHooks::nowHook = nativePerformanceNow;
|
|
}
|