1*3f982cf4SFabien Sanglard // Copyright 2019 The Chromium Authors. All rights reserved.
2*3f982cf4SFabien Sanglard // Use of this source code is governed by a BSD-style license that can be
3*3f982cf4SFabien Sanglard // found in the LICENSE file.
4*3f982cf4SFabien Sanglard
5*3f982cf4SFabien Sanglard #ifndef UTIL_TRACE_LOGGING_H_
6*3f982cf4SFabien Sanglard #define UTIL_TRACE_LOGGING_H_
7*3f982cf4SFabien Sanglard
8*3f982cf4SFabien Sanglard #include "platform/base/trace_logging_types.h"
9*3f982cf4SFabien Sanglard
10*3f982cf4SFabien Sanglard // All compile-time macros for tracing.
11*3f982cf4SFabien Sanglard // NOTE: The ternary operator is used here to ensure that the TraceLogger object
12*3f982cf4SFabien Sanglard // is only constructed if tracing is enabled, but at the same time is created in
13*3f982cf4SFabien Sanglard // the caller's scope. The C++ standards guide guarantees that the constructor
14*3f982cf4SFabien Sanglard // should only be called when IsTraceLoggingEnabled(...) evaluates to true.
15*3f982cf4SFabien Sanglard // static_cast calls are used because if the type of the result of the ternary
16*3f982cf4SFabien Sanglard // operator does not match the expected type, temporary storage is used for the
17*3f982cf4SFabien Sanglard // created object, which results in an extra call to the constructor and
18*3f982cf4SFabien Sanglard // destructor of the tracing objects.
19*3f982cf4SFabien Sanglard //
20*3f982cf4SFabien Sanglard // Further details about how these macros are used can be found in
21*3f982cf4SFabien Sanglard // docs/trace_logging.md.
22*3f982cf4SFabien Sanglard // TODO(rwkeane): Add support for user-provided properties.
23*3f982cf4SFabien Sanglard
24*3f982cf4SFabien Sanglard #if defined(ENABLE_TRACE_LOGGING)
25*3f982cf4SFabien Sanglard
26*3f982cf4SFabien Sanglard #define INCLUDING_FROM_UTIL_TRACE_LOGGING_H_
27*3f982cf4SFabien Sanglard #include "util/trace_logging/macro_support.h"
28*3f982cf4SFabien Sanglard #undef INCLUDING_FROM_UTIL_TRACE_LOGGING_H_
29*3f982cf4SFabien Sanglard
30*3f982cf4SFabien Sanglard #define TRACE_SET_RESULT(result) \
31*3f982cf4SFabien Sanglard do { \
32*3f982cf4SFabien Sanglard if (TRACE_IS_ENABLED(openscreen::TraceCategory::Value::kAny)) { \
33*3f982cf4SFabien Sanglard openscreen::internal::ScopedTraceOperation::set_result(result); \
34*3f982cf4SFabien Sanglard } \
35*3f982cf4SFabien Sanglard } while (false)
36*3f982cf4SFabien Sanglard #define TRACE_SET_HIERARCHY(ids) TRACE_SET_HIERARCHY_INTERNAL(__LINE__, ids)
37*3f982cf4SFabien Sanglard #define TRACE_HIERARCHY \
38*3f982cf4SFabien Sanglard (TRACE_IS_ENABLED(openscreen::TraceCategory::Value::kAny) \
39*3f982cf4SFabien Sanglard ? openscreen::internal::ScopedTraceOperation::hierarchy() \
40*3f982cf4SFabien Sanglard : openscreen::TraceIdHierarchy::Empty())
41*3f982cf4SFabien Sanglard #define TRACE_CURRENT_ID \
42*3f982cf4SFabien Sanglard (TRACE_IS_ENABLED(openscreen::TraceCategory::Value::kAny) \
43*3f982cf4SFabien Sanglard ? openscreen::internal::ScopedTraceOperation::current_id() \
44*3f982cf4SFabien Sanglard : kEmptyTraceId)
45*3f982cf4SFabien Sanglard #define TRACE_ROOT_ID \
46*3f982cf4SFabien Sanglard (TRACE_IS_ENABLED(openscreen::TraceCategory::Value::kAny) \
47*3f982cf4SFabien Sanglard ? openscreen::internal::ScopedTraceOperation::root_id() \
48*3f982cf4SFabien Sanglard : kEmptyTraceId)
49*3f982cf4SFabien Sanglard
50*3f982cf4SFabien Sanglard // Synchronous Trace Macros.
51*3f982cf4SFabien Sanglard #define TRACE_SCOPED(category, name, ...) \
52*3f982cf4SFabien Sanglard TRACE_SCOPED_INTERNAL(__LINE__, category, name, ##__VA_ARGS__)
53*3f982cf4SFabien Sanglard #define TRACE_DEFAULT_SCOPED(category, ...) \
54*3f982cf4SFabien Sanglard TRACE_SCOPED(category, __PRETTY_FUNCTION__, ##__VA_ARGS__)
55*3f982cf4SFabien Sanglard
56*3f982cf4SFabien Sanglard // Asynchronous Trace Macros.
57*3f982cf4SFabien Sanglard #define TRACE_ASYNC_START(category, name, ...) \
58*3f982cf4SFabien Sanglard TRACE_ASYNC_START_INTERNAL(__LINE__, category, name, ##__VA_ARGS__)
59*3f982cf4SFabien Sanglard
60*3f982cf4SFabien Sanglard #define TRACE_ASYNC_END(category, id, result) \
61*3f982cf4SFabien Sanglard TRACE_IS_ENABLED(category) \
62*3f982cf4SFabien Sanglard ? openscreen::internal::ScopedTraceOperation::TraceAsyncEnd( \
63*3f982cf4SFabien Sanglard __LINE__, __FILE__, id, result) \
64*3f982cf4SFabien Sanglard : false
65*3f982cf4SFabien Sanglard
66*3f982cf4SFabien Sanglard #else // ENABLE_TRACE_LOGGING not defined
67*3f982cf4SFabien Sanglard
68*3f982cf4SFabien Sanglard namespace openscreen {
69*3f982cf4SFabien Sanglard namespace internal {
70*3f982cf4SFabien Sanglard // Consumes |args| (to avoid "warn unused variable" errors at compile time), and
71*3f982cf4SFabien Sanglard // provides a "void" result type in the macros below.
72*3f982cf4SFabien Sanglard template <typename... Args>
DoNothingForTracing(Args...args)73*3f982cf4SFabien Sanglard inline void DoNothingForTracing(Args... args) {}
74*3f982cf4SFabien Sanglard } // namespace internal
75*3f982cf4SFabien Sanglard } // namespace openscreen
76*3f982cf4SFabien Sanglard
77*3f982cf4SFabien Sanglard #define TRACE_SET_RESULT(result) \
78*3f982cf4SFabien Sanglard openscreen::internal::DoNothingForTracing(result)
79*3f982cf4SFabien Sanglard #define TRACE_SET_HIERARCHY(ids) openscreen::internal::DoNothingForTracing(ids)
80*3f982cf4SFabien Sanglard #define TRACE_HIERARCHY openscreen::TraceIdHierarchy::Empty()
81*3f982cf4SFabien Sanglard #define TRACE_CURRENT_ID openscreen::kEmptyTraceId
82*3f982cf4SFabien Sanglard #define TRACE_ROOT_ID openscreen::kEmptyTraceId
83*3f982cf4SFabien Sanglard #define TRACE_SCOPED(category, name, ...) \
84*3f982cf4SFabien Sanglard openscreen::internal::DoNothingForTracing(category, name, ##__VA_ARGS__)
85*3f982cf4SFabien Sanglard #define TRACE_DEFAULT_SCOPED(category, ...) \
86*3f982cf4SFabien Sanglard TRACE_SCOPED(category, __PRETTY_FUNCTION__, ##__VA_ARGS__)
87*3f982cf4SFabien Sanglard #define TRACE_ASYNC_START(category, name, ...) \
88*3f982cf4SFabien Sanglard openscreen::internal::DoNothingForTracing(category, name, ##__VA_ARGS__)
89*3f982cf4SFabien Sanglard #define TRACE_ASYNC_END(category, id, result) \
90*3f982cf4SFabien Sanglard openscreen::internal::DoNothingForTracing(category, id, result)
91*3f982cf4SFabien Sanglard
92*3f982cf4SFabien Sanglard #endif // defined(ENABLE_TRACE_LOGGING)
93*3f982cf4SFabien Sanglard
94*3f982cf4SFabien Sanglard #endif // UTIL_TRACE_LOGGING_H_
95