amis-rpc-design/node_modules/react-native/ReactCommon/react/renderer/telemetry/TransactionTelemetry.cpp
2023-10-07 19:42:30 +08:00

164 lines
5.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 "TransactionTelemetry.h"
#include <react/debug/react_native_assert.h>
#include <utility>
namespace facebook::react {
thread_local TransactionTelemetry *threadLocalTransactionTelemetry = nullptr;
TransactionTelemetry::TransactionTelemetry()
: TransactionTelemetry(telemetryTimePointNow) {}
TransactionTelemetry::TransactionTelemetry(
std::function<TelemetryTimePoint()> now)
: now_{std::move(now)} {}
TransactionTelemetry *TransactionTelemetry::threadLocalTelemetry() {
return threadLocalTransactionTelemetry;
}
void TransactionTelemetry::setAsThreadLocal() {
threadLocalTransactionTelemetry = this;
}
void TransactionTelemetry::unsetAsThreadLocal() {
threadLocalTransactionTelemetry = nullptr;
}
void TransactionTelemetry::willCommit() {
react_native_assert(commitStartTime_ == kTelemetryUndefinedTimePoint);
react_native_assert(commitEndTime_ == kTelemetryUndefinedTimePoint);
commitStartTime_ = now_();
}
void TransactionTelemetry::didCommit() {
react_native_assert(commitStartTime_ != kTelemetryUndefinedTimePoint);
react_native_assert(commitEndTime_ == kTelemetryUndefinedTimePoint);
commitEndTime_ = now_();
}
void TransactionTelemetry::willDiff() {
react_native_assert(diffStartTime_ == kTelemetryUndefinedTimePoint);
react_native_assert(diffEndTime_ == kTelemetryUndefinedTimePoint);
diffStartTime_ = now_();
}
void TransactionTelemetry::didDiff() {
react_native_assert(diffStartTime_ != kTelemetryUndefinedTimePoint);
react_native_assert(diffEndTime_ == kTelemetryUndefinedTimePoint);
diffEndTime_ = now_();
}
void TransactionTelemetry::willLayout() {
react_native_assert(layoutStartTime_ == kTelemetryUndefinedTimePoint);
react_native_assert(layoutEndTime_ == kTelemetryUndefinedTimePoint);
layoutStartTime_ = now_();
}
void TransactionTelemetry::willMeasureText() {
react_native_assert(
lastTextMeasureStartTime_ == kTelemetryUndefinedTimePoint);
lastTextMeasureStartTime_ = now_();
}
void TransactionTelemetry::didMeasureText() {
numberOfTextMeasurements_++;
react_native_assert(
lastTextMeasureStartTime_ != kTelemetryUndefinedTimePoint);
textMeasureTime_ += now_() - lastTextMeasureStartTime_;
lastTextMeasureStartTime_ = kTelemetryUndefinedTimePoint;
}
void TransactionTelemetry::didLayout() {
react_native_assert(layoutStartTime_ != kTelemetryUndefinedTimePoint);
react_native_assert(layoutEndTime_ == kTelemetryUndefinedTimePoint);
layoutEndTime_ = now_();
}
void TransactionTelemetry::willMount() {
react_native_assert(mountStartTime_ == kTelemetryUndefinedTimePoint);
react_native_assert(mountEndTime_ == kTelemetryUndefinedTimePoint);
mountStartTime_ = now_();
}
void TransactionTelemetry::didMount() {
react_native_assert(mountStartTime_ != kTelemetryUndefinedTimePoint);
react_native_assert(mountEndTime_ == kTelemetryUndefinedTimePoint);
mountEndTime_ = now_();
}
void TransactionTelemetry::setRevisionNumber(int revisionNumber) {
revisionNumber_ = revisionNumber;
}
TelemetryTimePoint TransactionTelemetry::getDiffStartTime() const {
react_native_assert(diffStartTime_ != kTelemetryUndefinedTimePoint);
react_native_assert(diffEndTime_ != kTelemetryUndefinedTimePoint);
return diffStartTime_;
}
TelemetryTimePoint TransactionTelemetry::getDiffEndTime() const {
react_native_assert(diffStartTime_ != kTelemetryUndefinedTimePoint);
react_native_assert(diffEndTime_ != kTelemetryUndefinedTimePoint);
return diffEndTime_;
}
TelemetryTimePoint TransactionTelemetry::getCommitStartTime() const {
react_native_assert(commitStartTime_ != kTelemetryUndefinedTimePoint);
react_native_assert(commitEndTime_ != kTelemetryUndefinedTimePoint);
return commitStartTime_;
}
TelemetryTimePoint TransactionTelemetry::getCommitEndTime() const {
react_native_assert(commitStartTime_ != kTelemetryUndefinedTimePoint);
react_native_assert(commitEndTime_ != kTelemetryUndefinedTimePoint);
return commitEndTime_;
}
TelemetryTimePoint TransactionTelemetry::getLayoutStartTime() const {
react_native_assert(layoutStartTime_ != kTelemetryUndefinedTimePoint);
react_native_assert(layoutEndTime_ != kTelemetryUndefinedTimePoint);
return layoutStartTime_;
}
TelemetryTimePoint TransactionTelemetry::getLayoutEndTime() const {
react_native_assert(layoutStartTime_ != kTelemetryUndefinedTimePoint);
react_native_assert(layoutEndTime_ != kTelemetryUndefinedTimePoint);
return layoutEndTime_;
}
TelemetryTimePoint TransactionTelemetry::getMountStartTime() const {
react_native_assert(mountStartTime_ != kTelemetryUndefinedTimePoint);
react_native_assert(mountEndTime_ != kTelemetryUndefinedTimePoint);
return mountStartTime_;
}
TelemetryTimePoint TransactionTelemetry::getMountEndTime() const {
react_native_assert(mountStartTime_ != kTelemetryUndefinedTimePoint);
react_native_assert(mountEndTime_ != kTelemetryUndefinedTimePoint);
return mountEndTime_;
}
TelemetryDuration TransactionTelemetry::getTextMeasureTime() const {
return textMeasureTime_;
}
int TransactionTelemetry::getNumberOfTextMeasurements() const {
return numberOfTextMeasurements_;
}
int TransactionTelemetry::getRevisionNumber() const {
return revisionNumber_;
}
} // namespace facebook::react