mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
cb48b50290
Summary: Now we store a revision number of a Shadow Tree that leads to a transaction for which the concrete instance of MountingTelemetry corresponds. This is useful to understand how many actual transactions were skipped during a mounting phase (a mounting transaction does not directly correspond to a commit operation). Changelog: [Internal] Fabric-specific internal change. Reviewed By: mdvacca Differential Revision: D23364663 fbshipit-source-id: 32b86bcdfc1ae97d8fff3b97a8615cc5a5b4d4a9
81 lines
2.1 KiB
C++
81 lines
2.1 KiB
C++
/*
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
#include "SurfaceTelemetry.h"
|
|
|
|
#include <algorithm>
|
|
|
|
namespace facebook {
|
|
namespace react {
|
|
|
|
void SurfaceTelemetry::incorporate(
|
|
MountingTelemetry const &telemetry,
|
|
int numberOfMutations) {
|
|
layoutTime_ += telemetry.getLayoutEndTime() - telemetry.getLayoutStartTime();
|
|
commitTime_ += telemetry.getCommitEndTime() - telemetry.getCommitStartTime();
|
|
diffTime_ += telemetry.getDiffEndTime() - telemetry.getDiffStartTime();
|
|
mountTime_ += telemetry.getMountEndTime() - telemetry.getMountStartTime();
|
|
|
|
numberOfTransactions_++;
|
|
numberOfMutations_ += numberOfMutations;
|
|
numberOfTextMeasurements_ += telemetry.getNumberOfTextMeasurements();
|
|
lastRevisionNumber_ = telemetry.getRevisionNumber();
|
|
|
|
while (recentCommitTelemetries_.size() >=
|
|
kMaxNumberOfRecordedCommitTelemetries) {
|
|
recentCommitTelemetries_.erase(recentCommitTelemetries_.begin());
|
|
}
|
|
|
|
recentCommitTelemetries_.push_back(telemetry);
|
|
}
|
|
|
|
TelemetryDuration SurfaceTelemetry::getLayoutTime() const {
|
|
return layoutTime_;
|
|
}
|
|
|
|
TelemetryDuration SurfaceTelemetry::getCommitTime() const {
|
|
return commitTime_;
|
|
}
|
|
|
|
TelemetryDuration SurfaceTelemetry::getDiffTime() const {
|
|
return diffTime_;
|
|
}
|
|
|
|
TelemetryDuration SurfaceTelemetry::getMountTime() const {
|
|
return mountTime_;
|
|
}
|
|
|
|
int SurfaceTelemetry::getNumberOfTransactions() const {
|
|
return numberOfTransactions_;
|
|
}
|
|
|
|
int SurfaceTelemetry::getNumberOfMutations() const {
|
|
return numberOfMutations_;
|
|
}
|
|
|
|
int SurfaceTelemetry::getNumberOfTextMeasurements() const {
|
|
return numberOfTextMeasurements_;
|
|
}
|
|
|
|
int SurfaceTelemetry::getLastRevisionNumber() const {
|
|
return lastRevisionNumber_;
|
|
}
|
|
|
|
std::vector<MountingTelemetry> SurfaceTelemetry::getRecentCommitTelemetries()
|
|
const {
|
|
auto result = std::vector<MountingTelemetry>{};
|
|
result.reserve(recentCommitTelemetries_.size());
|
|
std::copy(
|
|
recentCommitTelemetries_.begin(),
|
|
recentCommitTelemetries_.end(),
|
|
std::back_inserter(result));
|
|
return result;
|
|
}
|
|
|
|
} // namespace react
|
|
} // namespace facebook
|