- TEST_SPEC.md: Updated test directory structure to reflect Core/Asset, Core/IO, and Resources/<Type> subdirectories - TEST_SPEC.md: Updated module names and test counts (852 total) - TEST_SPEC.md: Updated build commands for new Resources subdirectories - README.md: Updated engine structure with Core/Asset/ and Core/IO/ - README.md: Updated Resources section with layered architecture - README.md: Updated test coverage table with accurate counts
57 lines
1.2 KiB
C++
57 lines
1.2 KiB
C++
#pragma once
|
|
|
|
#include "LogLevel.h"
|
|
#include <XCEngine/Core/Containers/String.h>
|
|
|
|
#include <vector>
|
|
#include <chrono>
|
|
#include <unordered_map>
|
|
|
|
namespace XCEngine {
|
|
namespace Debug {
|
|
|
|
class Profiler {
|
|
public:
|
|
static Profiler& Get();
|
|
|
|
void Initialize();
|
|
void Shutdown();
|
|
|
|
void BeginProfile(const char* name);
|
|
void EndProfile();
|
|
|
|
void BeginFrame();
|
|
void EndFrame();
|
|
|
|
void MarkEvent(const char* name, uint64_t timestamp, uint32_t threadId);
|
|
void SetMarker(const char* name, uint32_t color);
|
|
|
|
void ExportChromeTracing(const Containers::String& filePath);
|
|
|
|
private:
|
|
struct ProfileNode {
|
|
const char* name;
|
|
uint64_t startTime;
|
|
uint64_t endTime;
|
|
uint32_t threadId;
|
|
};
|
|
|
|
struct ProfileSample {
|
|
const char* name;
|
|
uint64_t duration;
|
|
uint32_t threadId;
|
|
};
|
|
|
|
std::vector<ProfileNode> m_profileStack;
|
|
std::vector<ProfileSample> m_samples;
|
|
uint64_t m_frameStartTime = 0;
|
|
bool m_initialized = false;
|
|
};
|
|
|
|
#define XE_PROFILE_BEGIN(name) XCEngine::Debug::Profiler::Get().BeginProfile(name)
|
|
#define XE_PROFILE_END() XCEngine::Debug::Profiler::Get().EndProfile()
|
|
#define XE_PROFILE_FUNCTION() XE_PROFILE_BEGIN(__FUNCTION__)
|
|
|
|
} // namespace Debug
|
|
} // namespace XCEngine
|