mirror of
https://github.com/danieleteti/delphimvcframework.git
synced 2024-11-16 00:05:53 +01:00
84 lines
1.7 KiB
ObjectPascal
84 lines
1.7 KiB
ObjectPascal
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.
|