mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
cb552f62f2
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
72 lines
1.9 KiB
C++
72 lines
1.9 KiB
C++
/*
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
#include "PerformanceEntryReporter.h"
|
|
#include <glog/logging.h>
|
|
#include <react/renderer/runtimescheduler/RuntimeScheduler.h>
|
|
#include "NativePerformanceObserver.h"
|
|
|
|
namespace facebook::react {
|
|
PerformanceEntryReporter &PerformanceEntryReporter::getInstance() {
|
|
static PerformanceEntryReporter instance;
|
|
return instance;
|
|
}
|
|
|
|
void PerformanceEntryReporter::setReportingCallback(
|
|
std::optional<AsyncCallback<>> callback) {
|
|
callback_ = callback;
|
|
}
|
|
|
|
void PerformanceEntryReporter::startReporting(PerformanceEntryType entryType) {
|
|
reportingType_[static_cast<int>(entryType)] = true;
|
|
}
|
|
void PerformanceEntryReporter::stopReporting(PerformanceEntryType entryType) {
|
|
reportingType_[static_cast<int>(entryType)] = false;
|
|
}
|
|
|
|
const std::vector<RawPerformanceEntry>
|
|
&PerformanceEntryReporter::getPendingEntries() const {
|
|
return entries_;
|
|
}
|
|
|
|
std::vector<RawPerformanceEntry> PerformanceEntryReporter::popPendingEntries() {
|
|
auto entriesToReturn = std::move(entries_);
|
|
entries_ = {};
|
|
return entriesToReturn;
|
|
}
|
|
|
|
void PerformanceEntryReporter::clearPendingEntries() {
|
|
entries_.clear();
|
|
}
|
|
|
|
void PerformanceEntryReporter::logEntry(const RawPerformanceEntry &entry) {
|
|
if (!isReportingType(static_cast<PerformanceEntryType>(entry.entryType))) {
|
|
return;
|
|
}
|
|
|
|
entries_.emplace_back(entry);
|
|
|
|
// TODO: Add buffering/throttling - but for testing this works as well, for
|
|
// now
|
|
callback_->callWithPriority(SchedulerPriority::IdlePriority);
|
|
}
|
|
|
|
void PerformanceEntryReporter::mark(
|
|
const std::string &name,
|
|
double startTime,
|
|
double duration) {
|
|
logEntry(
|
|
{name,
|
|
static_cast<int>(PerformanceEntryType::MARK),
|
|
startTime,
|
|
duration,
|
|
std::nullopt,
|
|
std::nullopt,
|
|
std::nullopt});
|
|
}
|
|
} // namespace facebook::react
|