blob: 60e27abfc78aa6b482f8e0faa2aa6866ca0ed215 [file] [log] [blame]
// Copyright 2019 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef UTIL_TRACE_LOGGING_MACRO_SUPPORT_H_
#define UTIL_TRACE_LOGGING_MACRO_SUPPORT_H_
#ifndef INCLUDING_FROM_UTIL_TRACE_LOGGING_H_
#error "Do not include this header directly. Use util/trace_logging.h."
#endif
#ifndef ENABLE_TRACE_LOGGING
#error "BUG: This file should not have been reached."
#endif
#include "platform/api/trace_logging_platform.h"
#include "platform/base/trace_logging_activation.h"
#include "platform/base/trace_logging_types.h"
#include "util/trace_logging/scoped_trace_operations.h"
// Helper macros. These are used to simplify the macros below.
// NOTE: These cannot be #undef'd or they will stop working outside this file.
// NOTE: Two of these below macros are intentionally the same. This is to work
// around optimizations in the C++ Precompiler.
#define TRACE_INTERNAL_CONCAT(a, b) a##b
#define TRACE_INTERNAL_CONCAT_CONST(a, b) TRACE_INTERNAL_CONCAT(a, b)
#define TRACE_INTERNAL_UNIQUE_VAR_NAME(a) \
TRACE_INTERNAL_CONCAT_CONST(a, __LINE__)
// Because we need to suppress unused variables, and this code is used
// repeatedly in below macros, define helper macros to do this on a per-compiler
// basis until we begin using C++ 17 which supports [[maybe_unused]] officially.
#if defined(__clang__)
#define TRACE_INTERNAL_IGNORE_UNUSED_VAR [[maybe_unused]]
#elif defined(__GNUC__)
#define TRACE_INTERNAL_IGNORE_UNUSED_VAR __attribute__((unused))
#else
#define TRACE_INTERNAL_IGNORE_UNUSED_VAR [[maybe_unused]]
#endif // defined(__clang__)
namespace openscreen {
namespace internal {
inline bool IsTraceLoggingEnabled(TraceCategory::Value category) {
const CurrentTracingDestination destination;
return destination && destination->IsTraceLoggingEnabled(category);
}
} // namespace internal
} // namespace openscreen
#define TRACE_IS_ENABLED(category) \
openscreen::internal::IsTraceLoggingEnabled(category)
// Internal logging macros.
#define TRACE_SET_HIERARCHY_INTERNAL(line, ids) \
alignas(32) uint8_t TRACE_INTERNAL_CONCAT_CONST( \
tracing_storage, line)[sizeof(openscreen::internal::TraceIdSetter)]; \
TRACE_INTERNAL_IGNORE_UNUSED_VAR \
const auto TRACE_INTERNAL_UNIQUE_VAR_NAME(trace_ref_) = \
TRACE_IS_ENABLED(openscreen::TraceCategory::Value::kAny) \
? openscreen::internal::TraceInstanceHelper< \
openscreen::internal::TraceIdSetter>:: \
Create(TRACE_INTERNAL_CONCAT_CONST(tracing_storage, line), \
ids) \
: openscreen::internal::TraceInstanceHelper< \
openscreen::internal::TraceIdSetter>::Empty()
#define TRACE_SCOPED_INTERNAL(line, category, name, ...) \
alignas(32) uint8_t TRACE_INTERNAL_CONCAT_CONST( \
tracing_storage, \
line)[sizeof(openscreen::internal::SynchronousTraceLogger)]; \
TRACE_INTERNAL_IGNORE_UNUSED_VAR \
const auto TRACE_INTERNAL_UNIQUE_VAR_NAME(trace_ref_) = \
TRACE_IS_ENABLED(category) \
? openscreen::internal::TraceInstanceHelper< \
openscreen::internal::SynchronousTraceLogger>:: \
Create(TRACE_INTERNAL_CONCAT_CONST(tracing_storage, line), \
category, name, __FILE__, __LINE__, ##__VA_ARGS__) \
: openscreen::internal::TraceInstanceHelper< \
openscreen::internal::SynchronousTraceLogger>::Empty()
#define TRACE_ASYNC_START_INTERNAL(line, category, name, ...) \
alignas(32) uint8_t TRACE_INTERNAL_CONCAT_CONST( \
temp_storage, \
line)[sizeof(openscreen::internal::AsynchronousTraceLogger)]; \
TRACE_INTERNAL_IGNORE_UNUSED_VAR \
const auto TRACE_INTERNAL_UNIQUE_VAR_NAME(trace_ref_) = \
TRACE_IS_ENABLED(category) \
? openscreen::internal::TraceInstanceHelper< \
openscreen::internal::AsynchronousTraceLogger>:: \
Create(TRACE_INTERNAL_CONCAT_CONST(temp_storage, line), \
category, name, __FILE__, __LINE__, ##__VA_ARGS__) \
: openscreen::internal::TraceInstanceHelper< \
openscreen::internal::AsynchronousTraceLogger>::Empty()
#endif // UTIL_TRACE_LOGGING_MACRO_SUPPORT_H_