mirror of
https://github.com/danieleteti/delphimvcframework.git
synced 2024-11-16 16:25:54 +01:00
166 lines
4.6 KiB
ObjectPascal
166 lines
4.6 KiB
ObjectPascal
|
// *************************************************************************** }
|
||
|
//
|
||
|
// LoggerPro
|
||
|
//
|
||
|
// Copyright (c) 2010-2024 Daniele Teti
|
||
|
//
|
||
|
// https://github.com/danieleteti/loggerpro
|
||
|
//
|
||
|
// ***************************************************************************
|
||
|
//
|
||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
// you may not use this file except in compliance with the License.
|
||
|
// You may obtain a copy of the License at
|
||
|
//
|
||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||
|
//
|
||
|
// Unless required by applicable law or agreed to in writing, software
|
||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
// See the License for the specific language governing permissions and
|
||
|
// limitations under the License.
|
||
|
//
|
||
|
// ***************************************************************************
|
||
|
|
||
|
unit LoggerPro.Renderers;
|
||
|
|
||
|
interface
|
||
|
|
||
|
uses
|
||
|
LoggerPro, System.SysUtils;
|
||
|
|
||
|
type
|
||
|
TLogItemRendererDefault = class(TLogItemRenderer)
|
||
|
private
|
||
|
fInternalLogFormat: string;
|
||
|
fInternalFormatSettings: TFormatSettings;
|
||
|
fInitialized: Boolean;
|
||
|
protected
|
||
|
property InternalLogFormat: String read fInternalLogFormat;
|
||
|
property InternalFormatSettings: TFormatSettings read fInternalFormatSettings;
|
||
|
function GetLogLayoutWithPlaceHolders: String; virtual;
|
||
|
// ILogLayoutRenderer
|
||
|
procedure Setup; override;
|
||
|
procedure TearDown; override;
|
||
|
function RenderLogItem(const aLogItem: TLogItem): String; override;
|
||
|
end;
|
||
|
|
||
|
TLogItemRendererNoTag = class(TLogItemRendererDefault)
|
||
|
protected
|
||
|
function GetLogLayoutWithPlaceHolders: String; override;
|
||
|
function RenderLogItem(const aLogItem: TLogItem): String; override;
|
||
|
end;
|
||
|
|
||
|
TLogItemRendererNoThreadID = class(TLogItemRendererDefault)
|
||
|
protected
|
||
|
function GetLogLayoutWithPlaceHolders: String; override;
|
||
|
function RenderLogItem(const aLogItem: TLogItem): String; override;
|
||
|
end;
|
||
|
|
||
|
TLogItemRendererNoTagNoThreadID = class(TLogItemRendererDefault)
|
||
|
protected
|
||
|
function GetLogLayoutWithPlaceHolders: String; override;
|
||
|
function RenderLogItem(const aLogItem: TLogItem): String; override;
|
||
|
end;
|
||
|
|
||
|
|
||
|
function GetDefaultLogItemRenderer: ILogItemRenderer;
|
||
|
|
||
|
var
|
||
|
gDefaultLogItemRenderer: TLogItemRendererClass = TLogItemRendererDefault;
|
||
|
|
||
|
implementation
|
||
|
|
||
|
function GetDefaultLogItemRenderer: ILogItemRenderer;
|
||
|
begin
|
||
|
Result := gDefaultLogItemRenderer.Create;
|
||
|
end;
|
||
|
|
||
|
{ TLogItemRendererDefault }
|
||
|
|
||
|
procedure TLogItemRendererDefault.TearDown;
|
||
|
begin
|
||
|
// do nothing
|
||
|
end;
|
||
|
|
||
|
procedure TLogItemRendererDefault.Setup;
|
||
|
begin
|
||
|
if not fInitialized then
|
||
|
begin
|
||
|
fInternalFormatSettings := GetDefaultFormatSettings;
|
||
|
fInternalLogFormat := LogLayoutByPlaceHoldersToLogLayoutByIndexes(GetLogLayoutWithPlaceHolders, True);
|
||
|
fInitialized := True;
|
||
|
end;
|
||
|
end;
|
||
|
|
||
|
function TLogItemRendererDefault.GetLogLayoutWithPlaceHolders: String;
|
||
|
begin
|
||
|
Result := '{timestamp}[TID {threadid}][{loglevel}] {message} [{tag}]';
|
||
|
end;
|
||
|
|
||
|
function TLogItemRendererDefault.RenderLogItem(const aLogItem: TLogItem): String;
|
||
|
begin
|
||
|
Result := Format(InternalLogFormat, [
|
||
|
DateTimeToStr(ALogItem.TimeStamp, InternalFormatSettings),
|
||
|
ALogItem.ThreadID.ToString,
|
||
|
ALogItem.LogTypeAsString,
|
||
|
ALogItem.LogMessage,
|
||
|
ALogItem.LogTag
|
||
|
]);
|
||
|
end;
|
||
|
|
||
|
{ TLogItemRendererNoTag }
|
||
|
|
||
|
function TLogItemRendererNoTag.GetLogLayoutWithPlaceHolders: String;
|
||
|
begin
|
||
|
Result := '{timestamp}[TID {threadid}][{loglevel}] {message}';
|
||
|
end;
|
||
|
|
||
|
function TLogItemRendererNoTag.RenderLogItem(const aLogItem: TLogItem): String;
|
||
|
begin
|
||
|
Result := Format(InternalLogFormat, [
|
||
|
DateTimeToStr(ALogItem.TimeStamp, InternalFormatSettings),
|
||
|
ALogItem.ThreadID.ToString,
|
||
|
ALogItem.LogTypeAsString,
|
||
|
ALogItem.LogMessage
|
||
|
]);
|
||
|
end;
|
||
|
|
||
|
{ TLogItemRendererNoThreadID }
|
||
|
|
||
|
function TLogItemRendererNoThreadID.GetLogLayoutWithPlaceHolders: String;
|
||
|
begin
|
||
|
Result := '{timestamp}[{loglevel}] {message} [{tag}]';
|
||
|
end;
|
||
|
|
||
|
function TLogItemRendererNoThreadID.RenderLogItem(const aLogItem: TLogItem): String;
|
||
|
begin
|
||
|
Result := Format(InternalLogFormat, [
|
||
|
DateTimeToStr(ALogItem.TimeStamp, InternalFormatSettings),
|
||
|
ALogItem.LogTypeAsString,
|
||
|
ALogItem.LogMessage,
|
||
|
aLogItem.LogTag
|
||
|
]);
|
||
|
end;
|
||
|
|
||
|
{ TLogItemRendererNoTagNoThreadID }
|
||
|
|
||
|
function TLogItemRendererNoTagNoThreadID.GetLogLayoutWithPlaceHolders: String;
|
||
|
begin
|
||
|
Result := '{timestamp}[{loglevel}] {message}';
|
||
|
end;
|
||
|
|
||
|
function TLogItemRendererNoTagNoThreadID.RenderLogItem(const aLogItem: TLogItem): String;
|
||
|
begin
|
||
|
Result := Format(InternalLogFormat, [
|
||
|
DateTimeToStr(ALogItem.TimeStamp, InternalFormatSettings),
|
||
|
ALogItem.LogTypeAsString,
|
||
|
ALogItem.LogMessage
|
||
|
]);
|
||
|
end;
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
end.
|