aboutsummaryrefslogtreecommitdiff
path: root/src/zencore/trace.cpp
blob: f7e4c4b68d420bb196528c23906f2080b75f45ae (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
// Copyright Epic Games, Inc. All Rights Reserved.

#if ZEN_WITH_TRACE

#	include <zencore/config.h>
#	include <zencore/zencore.h>

#	define TRACE_IMPLEMENT 1
#	include <zencore/trace.h>

void
TraceInit(std::string_view ProgramName)
{
	static std::atomic_bool gInited	 = false;
	bool					Expected = false;
	if (!gInited.compare_exchange_strong(Expected, true))
	{
		return;
	}

	trace::FInitializeDesc Desc = {
		.bUseImportantCache = true,
	};
	trace::Initialize(Desc);

#	if ZEN_PLATFORM_WINDOWS
	const char* CommandLineString = GetCommandLineA();
#	else
	const char* CommandLineString = "";
#	endif

	trace::ThreadRegister("main", /* system id */ 0, /* sort id */ 0);
	trace::DescribeSession(ProgramName,
#	if ZEN_BUILD_DEBUG
						   trace::Build::Debug,
#	else
						   trace::Build::Development,
#	endif
						   CommandLineString,
						   ZEN_CFG_VERSION_BUILD_STRING);
}

void
TraceShutdown()
{
	(void)TraceStop();
	trace::Shutdown();
}

bool
IsTracing()
{
	return trace::IsTracing();
}

void
TraceStart(std::string_view ProgramName, const char* HostOrPath, TraceType Type)
{
	TraceInit(ProgramName);
	switch (Type)
	{
		case TraceType::Network:
			trace::SendTo(HostOrPath);
			break;

		case TraceType::File:
			trace::WriteTo(HostOrPath);
			break;

		case TraceType::None:
			break;
	}
	trace::ToggleChannel("cpu", true);
}

bool
TraceStop()
{
	trace::ToggleChannel("cpu", false);
	if (trace::Stop())
	{
		return true;
	}
	return false;
}

#endif	// ZEN_WITH_TRACE