mirror of
https://github.com/status-im/react-native.git
synced 2025-01-27 09:45:04 +00:00
156e5d9837
Summary: Introduces the inspector library supporting the Chrome Debugging Protocol for JavaScriptCore. Eventually this will mean that it is possible to attach the Chrome inspector directly to the JSC instance running on the device. This library doesn't define the actual transport but leaves that up to the platform layer. The main entry point (and the only exported header) is `Inspector.h`. This diff only introduces the basics supporting the `Schema` and `Inspector` domains meaning it doesn't have any features yet. These will come in following diffs. Reviewed By: michalgr Differential Revision: D4021490 fbshipit-source-id: 517fd9033051c11ba97d312b16382445ae85d3f3
119 lines
3.0 KiB
C++
119 lines
3.0 KiB
C++
// Copyright 2004-present Facebook. All Rights Reserved.
|
|
|
|
#pragma once
|
|
|
|
#include "Value.h"
|
|
|
|
#include <JavaScriptCore/JSContextRef.h>
|
|
#include <JavaScriptCore/JSObjectRef.h>
|
|
#include <JavaScriptCore/JSValueRef.h>
|
|
|
|
#include <stdexcept>
|
|
#include <algorithm>
|
|
#include <functional>
|
|
|
|
namespace facebook {
|
|
namespace react {
|
|
|
|
inline void throwJSExecutionException(const char* msg) {
|
|
throw JSException(msg);
|
|
}
|
|
|
|
template <typename... Args>
|
|
inline void throwJSExecutionException(const char* fmt, Args... args) {
|
|
int msgSize = snprintf(nullptr, 0, fmt, args...);
|
|
msgSize = std::min(512, msgSize + 1);
|
|
char *msg = (char*) alloca(msgSize);
|
|
snprintf(msg, msgSize, fmt, args...);
|
|
throw JSException(msg);
|
|
}
|
|
|
|
template <typename... Args>
|
|
inline void throwJSExecutionExceptionWithStack(const char* msg, const char* stack) {
|
|
throw JSException(msg, stack);
|
|
}
|
|
|
|
using JSFunction = std::function<JSValueRef(JSContextRef, JSObjectRef, size_t, const JSValueRef[])>;
|
|
|
|
JSObjectRef makeFunction(
|
|
JSContextRef ctx,
|
|
const char* name,
|
|
JSFunction function);
|
|
|
|
void installGlobalFunction(
|
|
JSGlobalContextRef ctx,
|
|
const char* name,
|
|
JSFunction function);
|
|
|
|
JSObjectRef makeFunction(
|
|
JSGlobalContextRef ctx,
|
|
const char* name,
|
|
JSObjectCallAsFunctionCallback callback);
|
|
|
|
void installGlobalFunction(
|
|
JSGlobalContextRef ctx,
|
|
const char* name,
|
|
JSObjectCallAsFunctionCallback callback);
|
|
|
|
void installGlobalProxy(
|
|
JSGlobalContextRef ctx,
|
|
const char* name,
|
|
JSObjectGetPropertyCallback callback);
|
|
|
|
void removeGlobal(JSGlobalContextRef ctx, const char* name);
|
|
|
|
JSValueRef makeJSCException(
|
|
JSContextRef ctx,
|
|
const char* exception_text);
|
|
|
|
JSValueRef evaluateScript(
|
|
JSContextRef ctx,
|
|
JSStringRef script,
|
|
JSStringRef sourceURL);
|
|
|
|
#if WITH_FBJSCEXTENSIONS
|
|
JSValueRef evaluateSourceCode(
|
|
JSContextRef ctx,
|
|
JSSourceCodeRef source,
|
|
JSStringRef sourceURL);
|
|
#endif
|
|
|
|
void formatAndThrowJSException(
|
|
JSContextRef ctx,
|
|
JSValueRef exn,
|
|
JSStringRef sourceURL);
|
|
|
|
JSValueRef makeJSError(JSContextRef ctx, const char *error);
|
|
|
|
JSValueRef translatePendingCppExceptionToJSError(JSContextRef ctx, const char *exceptionLocation);
|
|
JSValueRef translatePendingCppExceptionToJSError(JSContextRef ctx, JSObjectRef jsFunctionCause);
|
|
|
|
template<JSValueRef (method)(JSContextRef ctx,
|
|
JSObjectRef function,
|
|
JSObjectRef thisObject,
|
|
size_t argumentCount,
|
|
const JSValueRef arguments[],
|
|
JSValueRef *exception)>
|
|
inline JSObjectCallAsFunctionCallback exceptionWrapMethod() {
|
|
struct funcWrapper {
|
|
static JSValueRef call(
|
|
JSContextRef ctx,
|
|
JSObjectRef function,
|
|
JSObjectRef thisObject,
|
|
size_t argumentCount,
|
|
const JSValueRef arguments[],
|
|
JSValueRef *exception) {
|
|
try {
|
|
return (*method)(ctx, function, thisObject, argumentCount, arguments, exception);
|
|
} catch (...) {
|
|
*exception = translatePendingCppExceptionToJSError(ctx, function);
|
|
return JSValueMakeUndefined(ctx);
|
|
}
|
|
}
|
|
};
|
|
|
|
return &funcWrapper::call;
|
|
}
|
|
|
|
} }
|