forked from danieleteti/loggerpro
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLoggerPro.ConsoleAppender.pas
More file actions
99 lines (87 loc) · 2.77 KB
/
LoggerPro.ConsoleAppender.pas
File metadata and controls
99 lines (87 loc) · 2.77 KB
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
88
89
90
91
92
93
94
95
96
97
98
99
unit LoggerPro.ConsoleAppender;
{ <@abstract(The unit to include if you want to use @link(TLoggerProConsoleAppender))
@author(Daniele Teti) }
interface
uses
LoggerPro, System.Classes;
type
{
@abstract(Logs to the console using 4 different colors for the different logs level)
To learn how to use this appender, check the sample @code(console_appender.dproj)
@author(Daniele Teti - d.teti@bittime.it)
}
TLoggerProConsoleAppender = class(TLoggerProAppenderBase)
protected
procedure SetColor(const Color: Integer);
public
constructor Create; override;
procedure Setup; override;
procedure TearDown; override;
procedure WriteLog(const aLogItem: TLogItem); override;
end;
implementation
uses
System.SysUtils, Winapi.Windows, Winapi.Messages;
const
DEFAULT_LOG_FORMAT = '%0:s [TID %1:-8d][%2:-10s] %3:s [%4:s]';
{ FOREGROUND COLORS - CAN BE COMBINED }
FOREGROUND_BLUE = 1; { text color blue. }
FOREGROUND_GREEN = 2; { text color green }
FOREGROUND_RED = 4; { text color red }
FOREGROUND_INTENSITY = 8; { text color is intensified }
{ BACKGROUND COLORS - CAN BE COMBINED }
BACKGROUND_BLUE = $10; { background color blue }
BACKGROUND_GREEN = $20; { background color green }
BACKGROUND_RED = $40; { background color red. }
BACKGROUND_INTENSITY = $80; { background color is intensified }
constructor TLoggerProConsoleAppender.Create;
begin
inherited Create;
end;
procedure TLoggerProConsoleAppender.SetColor(const Color: Integer);
begin
SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), Color);
end;
procedure TLoggerProConsoleAppender.Setup;
begin
if IsConsole then
raise ELoggerPro.CreateFmt('Cannot use %s in a console app', [ClassName]);
TThread.Synchronize(nil,
procedure
begin
if GetStdHandle(STD_OUTPUT_HANDLE) = 0 then
raise ELoggerPro.Create
('Console not present' + slineBreak +
'[HINT: You can call "AllocConsole" to create a Console in a GUI application]');
end);
end;
procedure TLoggerProConsoleAppender.TearDown;
begin
// do nothing
end;
procedure TLoggerProConsoleAppender.WriteLog(const aLogItem: TLogItem);
var
lText: string;
lColor: Integer;
begin
case aLogItem.LogType of
TLogType.Debug:
lColor := FOREGROUND_GREEN;
TLogType.Info:
lColor := FOREGROUND_BLUE or FOREGROUND_GREEN or FOREGROUND_RED;
TLogType.Warning:
lColor := FOREGROUND_RED or FOREGROUND_GREEN or FOREGROUND_INTENSITY;
TLogType.Error:
lColor := FOREGROUND_RED or FOREGROUND_INTENSITY;
end;
lText := Format(DEFAULT_LOG_FORMAT, [datetimetostr(aLogItem.TimeStamp),
aLogItem.ThreadID, aLogItem.LogTypeAsString, aLogItem.LogMessage,
aLogItem.LogTag]);
TThread.Queue(nil,
procedure
begin
SetColor(lColor);
Writeln(lText);
end);
end;
end.