// Copyright (C) 2022 The Qt Company Ltd. // SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only #pragma once #include "nanotraceglobals.h" #include #include #include #include #ifdef NANOTRACE_ENABLED #define NANOTRACE_INIT(process, thread, filepath) Nanotrace::init(process, thread, filepath) #define NANOTRACE_SHUTDOWN() Nanotrace::shutdown() #define NANOTRACE_SCOPE(cat, name) Nanotrace::ScopeTracer nanotraceScopedTracerObject(name, cat, {}) #define NANOTRACE_INSTANT(cat, name) Nanotrace::addTracePoint(name, cat, 'I', {}) #define NANOTRACE_BEGIN(cat, name) Nanotrace::addTracePoint(name, cat, 'B', {}) #define NANOTRACE_END(cat, name) Nanotrace::addTracePoint(name, cat, 'E', {}) #define NANOTRACE_SCOPE_ARGS(cat, name, ...) Nanotrace::ScopeTracer nanotraceScopedTracerObject(name, cat, {__VA_ARGS__}) #define NANOTRACE_INSTANT_ARGS(cat, name, ...) Nanotrace::addTracePoint(name, cat, 'I', {__VA_ARGS__}) #define NANOTRACE_BEGIN_ARGS(cat, name, ...) Nanotrace::addTracePoint(name, cat, 'B', {__VA_ARGS__}) #else #define NANOTRACE_INIT(process, thread, filepath) #define NANOTRACE_SHUTDOWN() #define NANOTRACE_SCOPE(cat, name) #define NANOTRACE_INSTANT(cat, name) #define NANOTRACE_BEGIN(cat, name) #define NANOTRACE_END(cat, name) #define NANOTRACE_SCOPE_ARGS(cat, name, ...) #define NANOTRACE_INSTANT_ARGS(cat, name, ...) #define NANOTRACE_BEGIN_ARGS(cat, name, ...) #endif namespace Nanotrace { using Units = std::chrono::microseconds; using Clock = std::chrono::high_resolution_clock; using TimePoint = std::chrono::time_point< Clock >; class NANOTRACESHARED_EXPORT Arg { public: using SupportedType = std::variant; Arg(const std::string &name, const SupportedType &val); std::string name() const; std::string value() const; private: std::string m_name; SupportedType m_value; }; NANOTRACESHARED_EXPORT void init(const std::string &process, const std::string &thread, const std::string &path); NANOTRACESHARED_EXPORT void shutdown(); NANOTRACESHARED_EXPORT void flush(); NANOTRACESHARED_EXPORT void addTracePoint( const std::string &name, const std::string &cat, char phase, std::initializer_list< Nanotrace::Arg > arguments); class NANOTRACESHARED_EXPORT ScopeTracer { public: ScopeTracer( const std::string &name, const std::string &cat, std::initializer_list< Nanotrace::Arg > arguments); ~ScopeTracer(); private: TimePoint m_start; std::string m_name; std::string m_cat; std::vector< Nanotrace::Arg > m_args; }; } // End namespace Nanotrace.