/
logger.d
79 lines (68 loc) · 1.53 KB
/
logger.d
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
//===-- gen/logger.d - Codegen debug logging ----------------------*- D -*-===//
//
// LDC – the LLVM D compiler
//
// This file is distributed under the BSD-style LDC license. See the LICENSE
// file for details.
//
//===----------------------------------------------------------------------===//
//
// D implementation of the functionality of logger.{h/cpp}.
//
//===----------------------------------------------------------------------===//
module gen.logger;
private extern (C++) extern __gshared bool _Logger_enabled;
extern (C++, Logger)
{
void indent();
void undent();
void printIndentation();
}
struct Log
{
static bool enabled()
{
return _Logger_enabled;
}
static void indent()
{
if (enabled())
.indent();
}
static void undent()
{
if (enabled())
.undent();
}
// Usage: auto _ = Log.newScope();
static auto newScope()
{
struct ScopeExitUndenter
{
~this()
{
Logger.undent();
}
}
Logger.indent();
return ScopeExitUndenter();
}
static void printfln(T...)(T args)
{
static import std.stdio;
if (enabled())
{
printIndentation();
std.stdio.writefln(args);
}
}
static void printf(T...)(T args)
{
static import std.stdio;
if (enabled())
{
printIndentation();
std.stdio.writef(args);
}
}
}