delphimvcframework/LoggerPro.VCLListViewAppender.pas
Daniele Teti 55500acdf9 Squashed 'lib/loggerpro/' content from commit d1e0db6e
git-subtree-dir: lib/loggerpro
git-subtree-split: d1e0db6e93724e5fd825f0a8c02151d60450f98f
2023-02-27 12:26:25 +01:00

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.