forked from danieleteti/loggerpro
-
Notifications
You must be signed in to change notification settings - Fork 0
/
LoggerPro.VCLListViewAppender.pas
83 lines (71 loc) · 1.7 KB
/
LoggerPro.VCLListViewAppender.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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
unit LoggerPro.VCLListViewAppender;
{ <@abstract(The unit to include if you want to use the @link(TVCLMemoLogAppender))
@author(Daniele Teti) }
interface
uses
LoggerPro,
System.Classes,
Vcl.ComCtrls;
type
{ @abstract(Appends formatted @link(TLogItem) to a TMemo in a VCL application) }
TVCLListViewAppender = class(TLoggerProAppenderBase)
private
FLV: TListView;
FMaxLogLines: Word;
public
constructor Create(aLV: TListView; aMaxLogLines: Word = 500; aLogFormat: string = DEFAULT_LOG_FORMAT); reintroduce;
procedure Setup; override;
procedure TearDown; override;
procedure WriteLog(const aLogItem: TLogItem); override;
end;
implementation
uses
System.SysUtils,
Winapi.Windows,
Winapi.Messages;
{ TVCLMemoLogAppender }
constructor TVCLListViewAppender.Create(aLV: TListView; aMaxLogLines: Word; aLogFormat: string);
begin
inherited Create(aLogFormat);
FLV := aLV;
FMaxLogLines := aMaxLogLines;
end;
procedure TVCLListViewAppender.Setup;
begin
inherited;
TThread.Synchronize(nil,
procedure
begin
FLV.Clear;
end);
end;
procedure TVCLListViewAppender.TearDown;
begin
// do nothing
end;
procedure TVCLListViewAppender.WriteLog(const aLogItem: TLogItem);
var
lText: string;
begin
lText := FormatLog(aLogItem);
TThread.Queue(nil,
procedure
var
Lines: integer;
begin
FLV.Items.BeginUpdate;
try
Lines := FLV.Items.Count;
if Lines > FMaxLogLines then
begin
FLV.Items.Delete(0);
end;
FLV.AddItem(lText, nil)
finally
FLV.Items.EndUpdate;
end;
FLV.Scroll(0, FLV.Items.Count);
SendMessage(FLV.Handle, EM_SCROLLCARET, 0, 0);
end);
end;
end.