mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
62a28e4bdb
Summary: Changelog: [Internal] This implements the C++ side logic of handling `Performance.measure` calls. Since measures may refer to earlier logged marks by name, we need to keep track of the former. I also use a fixed size (circular) buffer to prevent the marks from piling forever. Also adds implementation of clearing marks/measures, as per standard. Reviewed By: mdvacca Differential Revision: D41756928 fbshipit-source-id: 19dce28d6af4c5646274e6d5db20b41869282780
50 lines
1.3 KiB
C++
50 lines
1.3 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 "NativePerformance.h"
|
|
#include <glog/logging.h>
|
|
#include "PerformanceEntryReporter.h"
|
|
|
|
namespace facebook::react {
|
|
|
|
NativePerformance::NativePerformance(std::shared_ptr<CallInvoker> jsInvoker)
|
|
: NativePerformanceCxxSpec(std::move(jsInvoker)) {}
|
|
|
|
void NativePerformance::mark(
|
|
jsi::Runtime &rt,
|
|
std::string name,
|
|
double startTime,
|
|
double duration) {
|
|
PerformanceEntryReporter::getInstance().mark(name, startTime, duration);
|
|
}
|
|
|
|
void NativePerformance::clearMarks(
|
|
jsi::Runtime &rt,
|
|
std::optional<std::string> markName) {
|
|
PerformanceEntryReporter::getInstance().clearMarks(markName);
|
|
}
|
|
|
|
void NativePerformance::measure(
|
|
jsi::Runtime &rt,
|
|
std::string name,
|
|
double startTime,
|
|
double endTime,
|
|
std::optional<double> duration,
|
|
std::optional<std::string> startMark,
|
|
std::optional<std::string> endMark) {
|
|
PerformanceEntryReporter::getInstance().measure(
|
|
name, startTime, endTime, duration, startMark, endMark);
|
|
}
|
|
|
|
void NativePerformance::clearMeasures(
|
|
jsi::Runtime &rt,
|
|
std::optional<std::string> measureName) {
|
|
PerformanceEntryReporter::getInstance().clearMeasures(measureName);
|
|
}
|
|
|
|
} // namespace facebook::react
|