mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
Instrument sync and async method calls (#28893)
Summary: Pull Request resolved: https://github.com/facebook/react-native/pull/28893 `JSIExecutor::callSerializableNativeHook` converts the arguments from `JSI::Value` to `folly::dynamic`. Then, `RCTNativeModule` converts the arguments from `folly::dynamic` to ObjC data structures in its `static invokeInner` function. Therefore, I decided to start the sync markers inside `JSIExecutor::callSerializableNativeHook`, which required me to expose these two methode `ModuleRegistry::getModuleName` and `ModuleRegistry::getModuleSyncMethodName`. This shouldn't modify performance because we eagerly generate a NativeModule's methods when it's first required. So, at worst, this is doing a cache lookup. Changelog: [Internal] Reviewed By: PeteTheHeat Differential Revision: D21443610 fbshipit-source-id: 67cf563b0b06153e56e63ba7e186eea31eafc853
This commit is contained in:
committed by
Facebook GitHub Bot
parent
bf0e516086
commit
0b8a82a6ee
@@ -195,6 +195,26 @@ folly::Optional<ModuleConfig> ModuleRegistry::getConfig(
|
||||
}
|
||||
}
|
||||
|
||||
std::string ModuleRegistry::getModuleName(unsigned int moduleId) {
|
||||
if (moduleId >= modules_.size()) {
|
||||
throw std::runtime_error(folly::to<std::string>(
|
||||
"moduleId ", moduleId, " out of range [0..", modules_.size(), ")"));
|
||||
}
|
||||
|
||||
return modules_[moduleId]->getName();
|
||||
}
|
||||
|
||||
std::string ModuleRegistry::getModuleSyncMethodName(
|
||||
unsigned int moduleId,
|
||||
unsigned int methodId) {
|
||||
if (moduleId >= modules_.size()) {
|
||||
throw std::runtime_error(folly::to<std::string>(
|
||||
"moduleId ", moduleId, " out of range [0..", modules_.size(), ")"));
|
||||
}
|
||||
|
||||
return modules_[moduleId]->getSyncMethodName(methodId);
|
||||
}
|
||||
|
||||
void ModuleRegistry::callNativeMethod(
|
||||
unsigned int moduleId,
|
||||
unsigned int methodId,
|
||||
|
||||
Reference in New Issue
Block a user