aboutsummaryrefslogtreecommitdiff
path: root/src/trace/debug.h
blob: 3a1652543a9a6f55c224c07deedda1c1c594b1dc (plain)
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
/* Copyright (c) 2017, The Tor Project, Inc. */
/* See LICENSE for licensing information */

#ifndef TOR_TRACE_LOG_DEBUG_H
#define TOR_TRACE_LOG_DEBUG_H

#include "torlog.h"

/* Stringify pre-processor trick. */
#define XSTR(d) STR(d)
#define STR(s) #s

/* Send every event to a debug log level. This is useful to debug new trace
 * events without implementing them for a specific event tracing framework.
 * Note that the arguments are ignored since at this step we do not know the
 * types and amount there is. */

/* Example on how to map a tracepoint to log_debug(). */
#undef tor_trace
#define tor_trace(subsystem, name, args...) \
  log_debug(LD_GENERAL, "Trace event \"" XSTR(name) "\" from " \
                        "\"" XSTR(subsystem) "\" hit. " \
                        "(line "XSTR(__LINE__) ")")

#endif /* TOR_TRACE_LOG_DEBUG_H */