This repository has been archived on 2023-10-09. You can view files and clone it, but cannot push or open issues or pull requests.
Files
blender-archive/source/blender/blenlib/BLI_timeit.hh

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

44 lines
848 B
C++
Raw Normal View History

/* SPDX-License-Identifier: GPL-2.0-or-later */
#pragma once
#include <chrono>
#include <iostream>
#include <string>
#include "BLI_sys_types.h"
namespace blender::timeit {
using Clock = std::chrono::steady_clock;
using TimePoint = Clock::time_point;
using Nanoseconds = std::chrono::nanoseconds;
void print_duration(Nanoseconds duration);
class ScopedTimer {
private:
std::string name_;
TimePoint start_;
public:
ScopedTimer(std::string name) : name_(std::move(name))
{
start_ = Clock::now();
}
~ScopedTimer()
{
2020-07-03 14:52:51 +02:00
const TimePoint end = Clock::now();
const Nanoseconds duration = end - start_;
std::cout << "Timer '" << name_ << "' took ";
print_duration(duration);
std::cout << '\n';
}
};
} // namespace blender::timeit
#define SCOPED_TIMER(name) blender::timeit::ScopedTimer scoped_timer(name)