mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
a64319a2b2
Summary: [Changelog][Internal] Adds API definition for [Performance.mark](https://www.w3.org/TR/user-timing/#mark-method) support. This is a bare bone implementation, that just logs events on the native side. The next step is the native logic for queuing, flushing etc. Note that here I route both JS and native marks to native for now, for simplicity sake - ultimately this may not be what we want, as it may be more efficient to process marks, logged from JS, on the JS side. Reviewed By: rubennorte Differential Revision: D41472148 fbshipit-source-id: bdf2b182b8472a71a5500235849bca5af1c2f360
52 lines
1.5 KiB
C++
52 lines
1.5 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 "NativePerformanceObserver.h"
|
|
#include <glog/logging.h>
|
|
|
|
namespace facebook::react {
|
|
|
|
NativePerformanceObserver::NativePerformanceObserver(
|
|
std::shared_ptr<CallInvoker> jsInvoker)
|
|
: NativePerformanceObserverCxxSpec(std::move(jsInvoker)) {}
|
|
|
|
void NativePerformanceObserver::startReporting(
|
|
jsi::Runtime &rt,
|
|
std::string entryType) {
|
|
LOG(INFO) << "Started reporting perf entry type: " << entryType;
|
|
}
|
|
|
|
void NativePerformanceObserver::stopReporting(
|
|
jsi::Runtime &rt,
|
|
std::string entryType) {
|
|
LOG(INFO) << "Stopped reporting perf entry type: " << entryType;
|
|
}
|
|
|
|
std::vector<RawPerformanceEntry> NativePerformanceObserver::getPendingEntries(
|
|
jsi::Runtime &rt) {
|
|
return std::vector<RawPerformanceEntry>{};
|
|
}
|
|
|
|
void NativePerformanceObserver::setOnPerformanceEntryCallback(
|
|
jsi::Runtime &rt,
|
|
std::optional<AsyncCallback<>> callback) {
|
|
callback_ = callback;
|
|
LOG(INFO) << "setOnPerformanceEntryCallback: "
|
|
<< (callback ? "non-empty" : "empty");
|
|
}
|
|
|
|
void NativePerformanceObserver::logEntryForDebug(
|
|
jsi::Runtime &rt,
|
|
RawPerformanceEntry entry) {
|
|
LOG(INFO) << "NativePerformanceObserver::logEntry: "
|
|
<< "name=" << entry.name << " type=" << entry.entryType
|
|
<< " startTime=" << entry.startTime
|
|
<< " duration=" << entry.duration;
|
|
}
|
|
|
|
} // namespace facebook::react
|