mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-04-22 00:09:25 +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');
|
||||
end;
|
||||
|
||||
T:=P.Targets.AddUnit('system.terminal.logger.pas');
|
||||
|
||||
//P.NamespaceMap:='namespaces.lst';
|
||||
|
||||
{$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