mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
Create NativePerformance C++ module
Summary: [Changelog][Internal] The NativePerformance module functionality corresponds to the [timing extensions of the Performance API standard interface](https://www.w3.org/TR/user-timing/#extensions-performance-interface). As this is logically separate from `PerformanceObserver` (which may exist without it), it makes sense to have it as a different native module, so there is no coupling between both. Reviewed By: christophpurrer Differential Revision: D41690145 fbshipit-source-id: 7443f4c51f54cc2fdddbdb2e89f9a1fa457ab280
This commit is contained in:
committed by
Facebook GitHub Bot
parent
1c7e678e08
commit
cb552f62f2
@@ -22,43 +22,36 @@ static PerformanceEntryType stringToPerformanceEntryType(
|
||||
|
||||
NativePerformanceObserver::NativePerformanceObserver(
|
||||
std::shared_ptr<CallInvoker> jsInvoker)
|
||||
: NativePerformanceObserverCxxSpec(std::move(jsInvoker)),
|
||||
reporter_(std::make_unique<PerformanceEntryReporter>()) {}
|
||||
|
||||
NativePerformanceObserver::~NativePerformanceObserver() {}
|
||||
: NativePerformanceObserverCxxSpec(std::move(jsInvoker)) {}
|
||||
|
||||
void NativePerformanceObserver::startReporting(
|
||||
jsi::Runtime &rt,
|
||||
std::string entryType) {
|
||||
reporter_->startReporting(stringToPerformanceEntryType(entryType));
|
||||
PerformanceEntryReporter::getInstance().startReporting(
|
||||
stringToPerformanceEntryType(entryType));
|
||||
}
|
||||
|
||||
void NativePerformanceObserver::stopReporting(
|
||||
jsi::Runtime &rt,
|
||||
std::string entryType) {
|
||||
reporter_->stopReporting(stringToPerformanceEntryType(entryType));
|
||||
PerformanceEntryReporter::getInstance().stopReporting(
|
||||
stringToPerformanceEntryType(entryType));
|
||||
}
|
||||
|
||||
std::vector<RawPerformanceEntry> NativePerformanceObserver::popPendingEntries(
|
||||
jsi::Runtime &rt) {
|
||||
return reporter_->popPendingEntries();
|
||||
return PerformanceEntryReporter::getInstance().popPendingEntries();
|
||||
}
|
||||
|
||||
std::vector<RawPerformanceEntry> NativePerformanceObserver::getPendingEntries(
|
||||
jsi::Runtime &rt) {
|
||||
return reporter_->getPendingEntries();
|
||||
return PerformanceEntryReporter::getInstance().getPendingEntries();
|
||||
}
|
||||
|
||||
void NativePerformanceObserver::setOnPerformanceEntryCallback(
|
||||
jsi::Runtime &rt,
|
||||
std::optional<AsyncCallback<>> callback) {
|
||||
reporter_->setReportingCallback(callback);
|
||||
}
|
||||
|
||||
void NativePerformanceObserver::logEntryForDebug(
|
||||
jsi::Runtime &rt,
|
||||
RawPerformanceEntry entry) {
|
||||
reporter_->logEntry(entry);
|
||||
PerformanceEntryReporter::getInstance().setReportingCallback(callback);
|
||||
}
|
||||
|
||||
} // namespace facebook::react
|
||||
|
||||
Reference in New Issue
Block a user