mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-08-11 12:46:06 +02:00
+ added unit System.Terminal.Logger
This commit is contained in:
parent
b201ab9d1d
commit
28831a7734
@ -50,6 +50,8 @@ begin
|
|||||||
AddUnit('system.terminal.base');
|
AddUnit('system.terminal.base');
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
T:=P.Targets.AddUnit('system.terminal.logger.pas');
|
||||||
|
|
||||||
//P.NamespaceMap:='namespaces.lst';
|
//P.NamespaceMap:='namespaces.lst';
|
||||||
|
|
||||||
{$ifndef ALLPACKAGES}
|
{$ifndef ALLPACKAGES}
|
||||||
|
179
packages/fcl-fpterm/src/system.terminal.logger.pas
Normal file
179
packages/fcl-fpterm/src/system.terminal.logger.pas
Normal file
@ -0,0 +1,179 @@
|
|||||||
|
{ This file is part of fpterm - a terminal emulator, written in Free Pascal
|
||||||
|
|
||||||
|
Copyright (C) 2022, 2024 Nikolay Nikolov <nickysn@users.sourceforge.net>
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or modify it
|
||||||
|
under the terms of the GNU Library General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2 of the License, or (at your
|
||||||
|
option) any later version with the following modification:
|
||||||
|
|
||||||
|
As a special exception, the copyright holders of this library give you
|
||||||
|
permission to link this library with independent modules to produce an
|
||||||
|
executable, regardless of the license terms of these independent modules,and
|
||||||
|
to copy and distribute the resulting executable under terms of your choice,
|
||||||
|
provided that you also meet, for each linked independent module, the terms
|
||||||
|
and conditions of the license of that module. An independent module is a
|
||||||
|
module which is not derived from or based on this library. If you modify
|
||||||
|
this library, you may extend this exception to your version of the library,
|
||||||
|
but you are not obligated to do so. If you do not wish to do so, delete this
|
||||||
|
exception statement from your version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License
|
||||||
|
for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with this library; if not, write to the Free Software Foundation,
|
||||||
|
Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1335, USA.
|
||||||
|
}
|
||||||
|
|
||||||
|
unit System.Terminal.Logger;
|
||||||
|
|
||||||
|
{$mode objfpc}{$H+}
|
||||||
|
|
||||||
|
interface
|
||||||
|
|
||||||
|
type
|
||||||
|
TVerbosityLevel = (
|
||||||
|
vlSpam,
|
||||||
|
vlDebug,
|
||||||
|
vlVerbose,
|
||||||
|
vlInfo,
|
||||||
|
vlNotice,
|
||||||
|
vlWarning,
|
||||||
|
vlSuccess,
|
||||||
|
vlError,
|
||||||
|
vlCritical);
|
||||||
|
|
||||||
|
const
|
||||||
|
DefaultLogLevel = vlWarning;
|
||||||
|
|
||||||
|
type
|
||||||
|
|
||||||
|
{ TLogger }
|
||||||
|
|
||||||
|
TLogger = class
|
||||||
|
public
|
||||||
|
procedure LogMessage(AVerbosityLevel: TVerbosityLevel; const msg: string); virtual; abstract;
|
||||||
|
end;
|
||||||
|
|
||||||
|
{ TSilentLogger }
|
||||||
|
|
||||||
|
TSilentLogger = class(TLogger)
|
||||||
|
public
|
||||||
|
procedure LogMessage(AVerbosityLevel: TVerbosityLevel; const msg: string); override;
|
||||||
|
end;
|
||||||
|
|
||||||
|
{ TConsoleLogger }
|
||||||
|
|
||||||
|
TConsoleLogger = class(TLogger)
|
||||||
|
private
|
||||||
|
FVerbosityLevel: TVerbosityLevel;
|
||||||
|
public
|
||||||
|
constructor Create(AVerbosityLevel: TVerbosityLevel);
|
||||||
|
procedure LogMessage(AVerbosityLevel: TVerbosityLevel; const msg: string); override;
|
||||||
|
end;
|
||||||
|
|
||||||
|
{ TFileLogger }
|
||||||
|
|
||||||
|
TFileLogger = class(TLogger)
|
||||||
|
private
|
||||||
|
FVerbosityLevel: TVerbosityLevel;
|
||||||
|
FFileName: string;
|
||||||
|
public
|
||||||
|
constructor Create(const AFileName: string; AVerbosityLevel: TVerbosityLevel);
|
||||||
|
procedure LogMessage(AVerbosityLevel: TVerbosityLevel; const msg: string); override;
|
||||||
|
end;
|
||||||
|
|
||||||
|
function Str2VerbosityLevel(const S: string): TVerbosityLevel;
|
||||||
|
|
||||||
|
implementation
|
||||||
|
|
||||||
|
uses
|
||||||
|
{$IFDEF FPC_DOTTEDUNITS}
|
||||||
|
System.SysUtils;
|
||||||
|
{$ELSE FPC_DOTTEDUNITS}
|
||||||
|
SysUtils;
|
||||||
|
{$ENDIF FPC_DOTTEDUNITS}
|
||||||
|
|
||||||
|
function Str2VerbosityLevel(const S: string): TVerbosityLevel;
|
||||||
|
begin
|
||||||
|
case UpCase(S) of
|
||||||
|
'SPAM':
|
||||||
|
Result := vlSpam;
|
||||||
|
'DEBUG':
|
||||||
|
Result := vlDebug;
|
||||||
|
'VERBOSE':
|
||||||
|
Result := vlVerbose;
|
||||||
|
'INFO':
|
||||||
|
Result := vlInfo;
|
||||||
|
'NOTICE':
|
||||||
|
Result := vlNotice;
|
||||||
|
'WARNING':
|
||||||
|
Result := vlWarning;
|
||||||
|
'SUCCESS':
|
||||||
|
Result := vlSuccess;
|
||||||
|
'ERROR':
|
||||||
|
Result := vlError;
|
||||||
|
'CRITICAL':
|
||||||
|
Result := vlCritical;
|
||||||
|
else
|
||||||
|
raise EArgumentException.Create('Invalid verbosity level');
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
|
{ TSilentLogger }
|
||||||
|
|
||||||
|
procedure TSilentLogger.LogMessage(AVerbosityLevel: TVerbosityLevel; const msg: string);
|
||||||
|
begin
|
||||||
|
end;
|
||||||
|
|
||||||
|
{ TConsoleLogger }
|
||||||
|
|
||||||
|
constructor TConsoleLogger.Create(AVerbosityLevel: TVerbosityLevel);
|
||||||
|
begin
|
||||||
|
FVerbosityLevel := AVerbosityLevel;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure TConsoleLogger.LogMessage(AVerbosityLevel: TVerbosityLevel; const msg: string);
|
||||||
|
begin
|
||||||
|
if AVerbosityLevel >= FVerbosityLevel then
|
||||||
|
Writeln(msg);
|
||||||
|
end;
|
||||||
|
|
||||||
|
{ TFileLogger }
|
||||||
|
|
||||||
|
constructor TFileLogger.Create(const AFileName: string; AVerbosityLevel: TVerbosityLevel);
|
||||||
|
var
|
||||||
|
F: TextFile;
|
||||||
|
begin
|
||||||
|
FFileName := AFileName;
|
||||||
|
FVerbosityLevel := AVerbosityLevel;
|
||||||
|
AssignFile(F, FFileName);
|
||||||
|
Rewrite(F);
|
||||||
|
CloseFile(F);
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure TFileLogger.LogMessage(AVerbosityLevel: TVerbosityLevel; const msg: string);
|
||||||
|
var
|
||||||
|
F: TextFile;
|
||||||
|
begin
|
||||||
|
if AVerbosityLevel >= FVerbosityLevel then
|
||||||
|
begin
|
||||||
|
AssignFile(F, FFileName);
|
||||||
|
{$I-}
|
||||||
|
Append(F);
|
||||||
|
{$I+}
|
||||||
|
if IOResult <> 0 then
|
||||||
|
Rewrite(F);
|
||||||
|
try
|
||||||
|
Writeln(F, msg);
|
||||||
|
finally
|
||||||
|
CloseFile(F);
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
|
end.
|
||||||
|
|
Loading…
Reference in New Issue
Block a user