This repository was archived by the owner on Dec 2, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathUnit1.pas
67 lines (56 loc) · 1.64 KB
/
Unit1.pas
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
unit Unit1;
interface
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.ExtCtrls, Vcl.StdCtrls, LoggerPro,
Vcl.Samples.Spin;
type
TForm1 = class(TForm)
btnStartLogger: TButton;
memoLog: TMemo;
pTop: TPanel;
btnSendLogMessages: TButton;
btnStoploggers: TButton;
seLoggerCount: TSpinEdit;
procedure btnStartLoggerClick(Sender: TObject);
procedure btnSendLogMessagesClick(Sender: TObject);
procedure btnStoploggersClick(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
Loggers: TArray<ILogWriter>
end;
var
Form1: TForm1;
implementation
uses LoggerPro.VCLMemoAppender, LoggerPro.OutputDebugStringAppender;
{$R *.dfm}
procedure TForm1.btnStartLoggerClick(Sender: TObject);
var
i: integer;
begin
SetLength(Loggers, seLoggerCount.Value);
for I := 0 to Length(loggers)-1 do
begin
Loggers[i] := BuildLogWriter([TVCLMemoLogAppender.Create(memoLog), TLoggerProOutputDebugStringAppender.Create], nil, TLogType.Debug);
end;
for I := 0 to Length(loggers)-1 do
begin
Loggers[i].InfoFmt('First log message to Loggers[%d]', [i], Format('Loggers[%d]', [i]));
end;
end;
procedure TForm1.btnSendLogMessagesClick(Sender: TObject);
var
i: integer;
begin
for i := 0 to Length(loggers)-1 do
begin
Loggers[i].InfoFmt('Manual log message to Loggers[%d]', [i], Format('Loggers[%d]', [i]));
end;
end;
procedure TForm1.btnStoploggersClick(Sender: TObject);
begin
SetLength(Loggers, 0);
end;
end.