2016-05-03 19:29:58 -07:00
|
|
|
// Copyright 2004-present Facebook. All Rights Reserved.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
#include <string>
|
2016-07-11 06:52:06 -07:00
|
|
|
|
2017-06-23 16:49:55 -07:00
|
|
|
#include <cxxreact/NativeModule.h>
|
2016-05-18 12:46:01 -07:00
|
|
|
#include <folly/dynamic.h>
|
2016-05-03 19:29:58 -07:00
|
|
|
|
|
|
|
namespace facebook {
|
|
|
|
namespace react {
|
|
|
|
|
2017-06-23 16:49:55 -07:00
|
|
|
class JSBigString;
|
2016-05-03 19:29:58 -07:00
|
|
|
class JSExecutor;
|
2016-10-03 05:07:41 -07:00
|
|
|
class JSModulesUnbundle;
|
2016-05-03 19:29:58 -07:00
|
|
|
class MessageQueueThread;
|
2016-10-03 05:07:41 -07:00
|
|
|
class ModuleRegistry;
|
2017-09-22 09:56:50 -07:00
|
|
|
class RAMBundleRegistry;
|
2016-05-03 19:29:58 -07:00
|
|
|
|
2016-05-18 12:46:01 -07:00
|
|
|
// This interface describes the delegate interface required by
|
|
|
|
// Executor implementations to call from JS into native code.
|
|
|
|
class ExecutorDelegate {
|
|
|
|
public:
|
|
|
|
virtual ~ExecutorDelegate() {}
|
|
|
|
|
2016-10-03 05:07:41 -07:00
|
|
|
virtual std::shared_ptr<ModuleRegistry> getModuleRegistry() = 0;
|
|
|
|
|
2016-05-18 12:46:01 -07:00
|
|
|
virtual void callNativeModules(
|
2016-09-19 04:43:09 -07:00
|
|
|
JSExecutor& executor, folly::dynamic&& calls, bool isEndOfBatch) = 0;
|
2016-05-18 12:46:01 -07:00
|
|
|
virtual MethodCallResult callSerializableNativeHook(
|
|
|
|
JSExecutor& executor, unsigned int moduleId, unsigned int methodId, folly::dynamic&& args) = 0;
|
|
|
|
};
|
|
|
|
|
2018-03-15 09:21:04 -07:00
|
|
|
using NativeExtensionsProvider = std::function<folly::dynamic(const std::string&)>;
|
|
|
|
|
2016-05-03 19:29:58 -07:00
|
|
|
class JSExecutorFactory {
|
|
|
|
public:
|
|
|
|
virtual std::unique_ptr<JSExecutor> createJSExecutor(
|
2016-05-18 12:46:01 -07:00
|
|
|
std::shared_ptr<ExecutorDelegate> delegate,
|
|
|
|
std::shared_ptr<MessageQueueThread> jsQueue) = 0;
|
|
|
|
virtual ~JSExecutorFactory() {}
|
2016-05-03 19:29:58 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
class JSExecutor {
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Execute an application script bundle in the JS context.
|
|
|
|
*/
|
2016-05-13 17:15:06 -07:00
|
|
|
virtual void loadApplicationScript(std::unique_ptr<const JSBigString> script,
|
|
|
|
std::string sourceURL) = 0;
|
2016-05-03 19:29:58 -07:00
|
|
|
|
|
|
|
/**
|
2017-09-22 09:56:50 -07:00
|
|
|
* Add an application "RAM" bundle registry
|
2016-05-03 19:29:58 -07:00
|
|
|
*/
|
2017-09-22 09:56:50 -07:00
|
|
|
virtual void setBundleRegistry(std::unique_ptr<RAMBundleRegistry> bundleRegistry) = 0;
|
2016-05-03 19:29:58 -07:00
|
|
|
|
2017-11-09 11:55:37 -08:00
|
|
|
/**
|
|
|
|
* Register a file path for an additional "RAM" bundle
|
|
|
|
*/
|
|
|
|
virtual void registerBundle(uint32_t bundleId, const std::string& bundlePath) = 0;
|
|
|
|
|
2016-05-03 19:29:58 -07:00
|
|
|
/**
|
|
|
|
* Executes BatchedBridge.callFunctionReturnFlushedQueue with the module ID,
|
|
|
|
* method ID and optional additional arguments in JS. The executor is responsible
|
|
|
|
* for using Bridge->callNativeModules to invoke any necessary native modules methods.
|
|
|
|
*/
|
|
|
|
virtual void callFunction(const std::string& moduleId, const std::string& methodId, const folly::dynamic& arguments) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Executes BatchedBridge.invokeCallbackAndReturnFlushedQueue with the cbID,
|
|
|
|
* and optional additional arguments in JS and returns the next queue. The executor
|
|
|
|
* is responsible for using Bridge->callNativeModules to invoke any necessary
|
|
|
|
* native modules methods.
|
|
|
|
*/
|
|
|
|
virtual void invokeCallback(const double callbackId, const folly::dynamic& arguments) = 0;
|
|
|
|
|
2016-05-13 17:15:06 -07:00
|
|
|
virtual void setGlobalVariable(std::string propName,
|
|
|
|
std::unique_ptr<const JSBigString> jsonValue) = 0;
|
2017-12-18 13:19:35 -08:00
|
|
|
|
2016-05-03 19:29:58 -07:00
|
|
|
virtual void* getJavaScriptContext() {
|
|
|
|
return nullptr;
|
2016-05-18 12:46:01 -07:00
|
|
|
}
|
2017-06-26 05:48:40 -07:00
|
|
|
|
2017-12-20 02:19:36 -08:00
|
|
|
/**
|
|
|
|
* Returns whether or not the underlying executor supports debugging via the
|
|
|
|
* Chrome remote debugging protocol.
|
|
|
|
*/
|
2017-12-18 13:19:35 -08:00
|
|
|
virtual bool isInspectable() {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2017-09-05 14:47:06 -07:00
|
|
|
/**
|
|
|
|
* The description is displayed in the dev menu, if there is one in
|
|
|
|
* this build. There is a default, but if this method returns a
|
|
|
|
* non-empty string, it will be used instead.
|
|
|
|
*/
|
|
|
|
virtual std::string getDescription() = 0;
|
|
|
|
|
2017-06-26 05:48:40 -07:00
|
|
|
virtual void handleMemoryPressure(int pressureLevel) {}
|
|
|
|
|
2016-05-18 12:46:01 -07:00
|
|
|
virtual void destroy() {}
|
|
|
|
virtual ~JSExecutor() {}
|
2016-05-03 19:29:58 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
} }
|