mirror of
https://github.com/status-im/react-native.git
synced 2025-02-24 15:18:10 +00:00
Replace MethodCallResult with folly::Optional
Reviewed By: AaaChiuuu Differential Revision: D4481987 fbshipit-source-id: 945dd671eb2482f3c6b626192aa2181c5bfd906f
This commit is contained in:
parent
7812b82b18
commit
4d2512aef9
@ -119,7 +119,7 @@ void RCTNativeModule::invoke(ExecutorToken token, unsigned int methodId, folly::
|
|||||||
MethodCallResult RCTNativeModule::callSerializableNativeHook(
|
MethodCallResult RCTNativeModule::callSerializableNativeHook(
|
||||||
ExecutorToken token, unsigned int reactMethodId, folly::dynamic &¶ms) {
|
ExecutorToken token, unsigned int reactMethodId, folly::dynamic &¶ms) {
|
||||||
RCTFatal(RCTErrorWithMessage(@"callSerializableNativeHook is not yet supported on iOS"));
|
RCTFatal(RCTErrorWithMessage(@"callSerializableNativeHook is not yet supported on iOS"));
|
||||||
return {nullptr, true};
|
return folly::none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -192,7 +192,7 @@ MethodCallResult MethodInvoker::invoke(std::weak_ptr<Instance>& instance, jni::a
|
|||||||
case KEY: { \
|
case KEY: { \
|
||||||
auto result = env->Call ## METHOD ## MethodA(module.get(), method_, args); \
|
auto result = env->Call ## METHOD ## MethodA(module.get(), method_, args); \
|
||||||
jni::throwPendingJniExceptionAsCppException(); \
|
jni::throwPendingJniExceptionAsCppException(); \
|
||||||
return MethodCallResult {result, false}; \
|
return folly::dynamic(result); \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define CASE_OBJECT(KEY, JNI_CLASS, ACTIONS) \
|
#define CASE_OBJECT(KEY, JNI_CLASS, ACTIONS) \
|
||||||
@ -200,7 +200,7 @@ MethodCallResult MethodInvoker::invoke(std::weak_ptr<Instance>& instance, jni::a
|
|||||||
auto jobject = env->CallObjectMethodA(module.get(), method_, args); \
|
auto jobject = env->CallObjectMethodA(module.get(), method_, args); \
|
||||||
jni::throwPendingJniExceptionAsCppException(); \
|
jni::throwPendingJniExceptionAsCppException(); \
|
||||||
auto result = adopt_local(static_cast<JNI_CLASS::javaobject>(jobject)); \
|
auto result = adopt_local(static_cast<JNI_CLASS::javaobject>(jobject)); \
|
||||||
return MethodCallResult {result->ACTIONS, false}; \
|
return folly::dynamic(result->ACTIONS); \
|
||||||
}
|
}
|
||||||
|
|
||||||
char returnType = signature_.at(0);
|
char returnType = signature_.at(0);
|
||||||
@ -208,7 +208,7 @@ MethodCallResult MethodInvoker::invoke(std::weak_ptr<Instance>& instance, jni::a
|
|||||||
case 'v':
|
case 'v':
|
||||||
env->CallVoidMethodA(module.get(), method_, args);
|
env->CallVoidMethodA(module.get(), method_, args);
|
||||||
jni::throwPendingJniExceptionAsCppException();
|
jni::throwPendingJniExceptionAsCppException();
|
||||||
return MethodCallResult {nullptr, true};
|
return folly::none;
|
||||||
|
|
||||||
CASE_PRIMITIVE('z', jboolean, Boolean)
|
CASE_PRIMITIVE('z', jboolean, Boolean)
|
||||||
CASE_OBJECT('Z', JBoolean, value())
|
CASE_OBJECT('Z', JBoolean, value())
|
||||||
@ -225,7 +225,7 @@ MethodCallResult MethodInvoker::invoke(std::weak_ptr<Instance>& instance, jni::a
|
|||||||
|
|
||||||
default:
|
default:
|
||||||
LOG(FATAL) << "Unknown return type: " << returnType;
|
LOG(FATAL) << "Unknown return type: " << returnType;
|
||||||
return MethodCallResult {nullptr, true};
|
return folly::none;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -163,7 +163,7 @@ MethodCallResult CxxNativeModule::callSerializableNativeHook(
|
|||||||
" is asynchronous but invoked synchronously"));
|
" is asynchronous but invoked synchronously"));
|
||||||
}
|
}
|
||||||
|
|
||||||
return { method.syncFunc(std::move(args)), false };
|
return method.syncFunc(std::move(args));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -6,11 +6,11 @@
|
|||||||
#include <functional>
|
#include <functional>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
#include <sys/mman.h>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include <sys/mman.h>
|
|
||||||
|
|
||||||
#include <folly/Exception.h>
|
#include <folly/Exception.h>
|
||||||
|
#include <folly/Optional.h>
|
||||||
#include <folly/dynamic.h>
|
#include <folly/dynamic.h>
|
||||||
|
|
||||||
#include "JSModulesUnbundle.h"
|
#include "JSModulesUnbundle.h"
|
||||||
@ -34,10 +34,7 @@ class JSModulesUnbundle;
|
|||||||
class MessageQueueThread;
|
class MessageQueueThread;
|
||||||
class ModuleRegistry;
|
class ModuleRegistry;
|
||||||
|
|
||||||
struct MethodCallResult {
|
using MethodCallResult = folly::Optional<folly::dynamic>;
|
||||||
folly::dynamic result;
|
|
||||||
bool isUndefined;
|
|
||||||
};
|
|
||||||
|
|
||||||
// This interface describes the delegate interface required by
|
// This interface describes the delegate interface required by
|
||||||
// Executor implementations to call from JS into native code.
|
// Executor implementations to call from JS into native code.
|
||||||
|
@ -877,10 +877,10 @@ JSValueRef JSCExecutor::nativeCallSyncHook(
|
|||||||
moduleId,
|
moduleId,
|
||||||
methodId,
|
methodId,
|
||||||
std::move(args));
|
std::move(args));
|
||||||
if (result.isUndefined) {
|
if (!result.hasValue()) {
|
||||||
return Value::makeUndefined(m_context);
|
return Value::makeUndefined(m_context);
|
||||||
}
|
}
|
||||||
return Value::fromDynamic(m_context, result.result);
|
return Value::fromDynamic(m_context, result.value());
|
||||||
}
|
}
|
||||||
|
|
||||||
} }
|
} }
|
||||||
|
Loading…
x
Reference in New Issue
Block a user