Files
allwpilib/wpilibc/src/main/native/cpp/Tracer.cpp

59 lines
1.4 KiB
C++
Raw Normal View History

// Copyright (c) FIRST and other WPILib contributors.
// Open Source Software; you can modify and/or share it under the terms of
// the WPILib BSD license file in the root directory of this project.
#include "frc/Tracer.h"
#include <wpi/Format.h>
#include <wpi/SmallString.h>
#include <wpi/raw_ostream.h>
#include "frc/Errors.h"
using namespace frc;
Tracer::Tracer() {
ResetTimer();
}
void Tracer::ResetTimer() {
m_startTime = hal::fpga_clock::now();
}
void Tracer::ClearEpochs() {
ResetTimer();
m_epochs.clear();
}
void Tracer::AddEpoch(wpi::StringRef epochName) {
auto currentTime = hal::fpga_clock::now();
m_epochs[epochName] = currentTime - m_startTime;
m_startTime = currentTime;
}
void Tracer::PrintEpochs() {
wpi::SmallString<128> buf;
wpi::raw_svector_ostream os(buf);
PrintEpochs(os);
if (!buf.empty()) {
FRC_ReportError(warn::Warning, "{}", buf.c_str());
}
}
void Tracer::PrintEpochs(wpi::raw_ostream& os) {
using std::chrono::duration_cast;
using std::chrono::microseconds;
auto now = hal::fpga_clock::now();
if (now - m_lastEpochsPrintTime > kMinPrintPeriod) {
m_lastEpochsPrintTime = now;
for (const auto& epoch : m_epochs) {
os << '\t' << epoch.getKey() << ": "
<< wpi::format(
"%.6f",
duration_cast<microseconds>(epoch.getValue()).count() / 1.0e6)
<< "s\n";
}
}
}