f53df7da64
Code submissions have continually suffered from formatting inconsistencies that constantly have to be addressed. Using clang-format simplifies this by making code formatting more consistent, and allows automation of the code formatting so that maintainers can focus more on the code itself instead of code formatting.
48 lines
990 B
C++
48 lines
990 B
C++
#pragma once
|
|
|
|
#include "profiler.h"
|
|
|
|
struct ScopeProfiler {
|
|
const char *name;
|
|
bool enabled = true;
|
|
|
|
ScopeProfiler(const char *name) : name(name) { profile_start(name); }
|
|
|
|
~ScopeProfiler() { Stop(); }
|
|
|
|
ScopeProfiler(const ScopeProfiler &) = delete;
|
|
ScopeProfiler(ScopeProfiler &&other)
|
|
: name(other.name), enabled(other.enabled)
|
|
{
|
|
other.enabled = false;
|
|
}
|
|
|
|
ScopeProfiler &operator=(const ScopeProfiler &) = delete;
|
|
ScopeProfiler &operator=(ScopeProfiler &&other) = delete;
|
|
|
|
void Stop()
|
|
{
|
|
if (!enabled)
|
|
return;
|
|
|
|
profile_end(name);
|
|
enabled = false;
|
|
}
|
|
};
|
|
|
|
#ifndef NO_PROFILER_MACROS
|
|
|
|
#define ScopeProfiler_NameConcatImpl(x, y) x##y
|
|
#define ScopeProfiler_NameConcat(x, y) ScopeProfiler_NameConcatImpl(x, y)
|
|
|
|
#ifdef __COUNTER__
|
|
#define ScopeProfiler_Name(x) ScopeProfiler_NameConcat(x, __COUNTER__)
|
|
#else
|
|
#define ScopeProfiler_Name(x) ScopeProfiler_NameConcat(x, __LINE__)
|
|
#endif
|
|
|
|
#define ProfileScope(x) \
|
|
ScopeProfiler ScopeProfiler_Name(SCOPE_PROFILE) { x }
|
|
|
|
#endif
|