mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
14ab76ac30
Summary: Pull Request resolved: https://github.com/facebook/react-native/pull/36312 ## Changelog: [Internal] - `clearMarks` and `clearMeasures` methods are incidental to the `NativePerformance` TurboModule functionality, as in reality this responsibility belongs more on the `NativePerformanceObserver` and `PerformanceEntryReporter` side. This is something that [the standard indirectly suggests](https://www.w3.org/TR/user-timing/#clearmarks-method) as well (referencing [performance entry buffer](https://www.w3.org/TR/performance-timeline/#dfn-performance-entry-buffer)). The new implementation should be also a little bit more efficient, as it avoids calling the predicate for each entry. Finally (and frankly, the main reason for this change, from my perspective), it will simplify mocking/testing the JS part of the PerfAPI code. Reviewed By: rubennorte Differential Revision: D43621174 fbshipit-source-id: c4217a0da1d8ecbce797240627f7b4f057d85b97
57 lines
1.7 KiB
C++
57 lines
1.7 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.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <FBReactNativeSpec/FBReactNativeSpecJSI.h>
|
|
#include <memory>
|
|
#include <string>
|
|
|
|
#include "NativePerformanceObserver.h"
|
|
|
|
namespace facebook::react {
|
|
class PerformanceEntryReporter;
|
|
|
|
#pragma mark - Structs
|
|
|
|
#pragma mark - implementation
|
|
|
|
class NativePerformance : public NativePerformanceCxxSpec<NativePerformance>,
|
|
std::enable_shared_from_this<NativePerformance> {
|
|
public:
|
|
NativePerformance(std::shared_ptr<CallInvoker> jsInvoker);
|
|
|
|
void
|
|
mark(jsi::Runtime &rt, std::string name, double startTime, double duration);
|
|
|
|
void 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);
|
|
|
|
// To align with web API, we will make sure to return three properties
|
|
// (jsHeapSizeLimit, totalJSHeapSize, usedJSHeapSize) + anything needed from
|
|
// the VM side.
|
|
// `jsHeapSizeLimit`: The maximum size of the heap, in bytes, that
|
|
// is available to the context.
|
|
// `totalJSHeapSize`: The total allocated heap size, in bytes.
|
|
// `usedJSHeapSize`: The currently active segment of JS heap, in
|
|
// bytes.
|
|
//
|
|
// Note that we use int64_t here and it's ok to lose precision in JS doubles
|
|
// for heap size information, as double's 2^53 sig bytes is large enough.
|
|
std::unordered_map<std::string, double> getSimpleMemoryInfo(jsi::Runtime &rt);
|
|
|
|
private:
|
|
};
|
|
|
|
} // namespace facebook::react
|