You've already forked lazarus-ccr
RxFPC:move rx logging functions to rxtool.rxlogging
git-svn-id: https://svn.code.sf.net/p/lazarus-ccr/svn@6765 8e941d3f-bd1b-0410-a28a-d453659cc2b4
This commit is contained in:
@ -60,11 +60,9 @@ function GetDefaultIniName: string;
|
||||
|
||||
type
|
||||
TOnGetDefaultIniName = function: string;
|
||||
TRxLoggerEvent = procedure( ALogType:TEventType; const ALogMessage:string);
|
||||
|
||||
const
|
||||
OnGetDefaultIniName: TOnGetDefaultIniName = nil;
|
||||
OnRxLoggerEvent:TRxLoggerEvent = nil;
|
||||
|
||||
//Save to IniFile or TRegIniFile string value
|
||||
procedure IniWriteString(IniFile: TObject; const Section, Ident,
|
||||
@ -91,12 +89,6 @@ procedure WarningBox(const S:string; Params:array of const); overload;
|
||||
procedure ErrorBox(const S:string);
|
||||
procedure ErrorBox(const S:string; Params:array of const);
|
||||
|
||||
procedure RxWriteLog(ALogType:TEventType; const ALogMessage:string);
|
||||
procedure RxWriteLog(ALogType:TEventType; const ALogMessage:string; Params:array of const);
|
||||
procedure RxDefaultWriteLog( ALogType:TEventType; const ALogMessage:string);
|
||||
function RxDefaultLogFileName:string;
|
||||
procedure InitRxLogs;
|
||||
|
||||
function RxGetKeyboardLayoutName:string;
|
||||
|
||||
function RxMessageBeep(AStyle:TRxMsgBeepStyle):boolean;
|
||||
@ -110,7 +102,7 @@ uses
|
||||
{$IFDEF LINUX}
|
||||
X, XKB, xkblib, xlib,
|
||||
{$ENDIF}
|
||||
Registry, Forms, FileUtil, LazUTF8, LazFileUtils, Dialogs;
|
||||
Registry, Forms, FileUtil, LazUTF8, LazFileUtils, Dialogs, rxlogging;
|
||||
|
||||
function RxGetAppConfigDir(Global: Boolean): String;
|
||||
{$IFDEF WINDOWS}
|
||||
@ -134,11 +126,6 @@ begin
|
||||
end;
|
||||
{$ENDIF}
|
||||
|
||||
procedure RxWriteLog(ALogType:TEventType; const ALogMessage:string);
|
||||
begin
|
||||
if Assigned(OnRxLoggerEvent) then
|
||||
OnRxLoggerEvent(ALogType, ALogMessage)
|
||||
end;
|
||||
|
||||
procedure InfoBox(const S: string);
|
||||
begin
|
||||
@ -176,43 +163,6 @@ begin
|
||||
ErrorBox(Format(S, Params));
|
||||
end;
|
||||
|
||||
procedure RxWriteLog(ALogType: TEventType; const ALogMessage: string;
|
||||
Params: array of const);
|
||||
begin
|
||||
RxWriteLog(ALogType, Format(ALogMessage, Params));
|
||||
end;
|
||||
|
||||
procedure RxDefaultWriteLog(ALogType: TEventType; const ALogMessage: string);
|
||||
var
|
||||
F: Text;
|
||||
S: String;
|
||||
const
|
||||
sEventNames : array [TEventType] of string =
|
||||
('CUSTOM','INFO','WARNING','ERROR','DEBUG');
|
||||
begin
|
||||
S:=RxDefaultLogFileName;
|
||||
if S<>'' then
|
||||
begin
|
||||
Assign(F, S);
|
||||
if FileExists(S) then
|
||||
Append(F)
|
||||
else
|
||||
Rewrite(F);
|
||||
|
||||
Writeln(F,Format( '|%s| %20s |%s', [sEventNames[ALogType], DateTimeToStr(Now), ALogMessage]));
|
||||
CloseFile(F);
|
||||
end;
|
||||
end;
|
||||
|
||||
function RxDefaultLogFileName: string;
|
||||
begin
|
||||
Result:=AppendPathDelim(GetTempDir) + ExtractFileNameOnly(ParamStr(0)) + '.log';
|
||||
end;
|
||||
|
||||
procedure InitRxLogs;
|
||||
begin
|
||||
OnRxLoggerEvent:=@RxDefaultWriteLog;
|
||||
end;
|
||||
|
||||
{$IFDEF LINUX}
|
||||
function getKeyboardLang(dpy:PDisplay; AGroup:Integer):string;
|
||||
|
@ -15,7 +15,7 @@
|
||||
"/>
|
||||
<License Value="LGPL"/>
|
||||
<Version Minor="4" Build="6"/>
|
||||
<Files Count="10">
|
||||
<Files Count="11">
|
||||
<Item1>
|
||||
<Filename Value="rxtools/rxcrc.pas"/>
|
||||
<UnitName Value="rxCRC"/>
|
||||
@ -55,6 +55,10 @@
|
||||
<Filename Value="rxtools/rxtextholder.pas"/>
|
||||
<UnitName Value="RxTextHolder"/>
|
||||
</Item10>
|
||||
<Item11>
|
||||
<Filename Value="rxtools/rxlogging.pas"/>
|
||||
<UnitName Value="rxlogging"/>
|
||||
</Item11>
|
||||
</Files>
|
||||
<LazDoc Paths="docs;/usr/local/share/lazarus/components/rxnew/docs"/>
|
||||
<i18n>
|
||||
@ -62,10 +66,13 @@
|
||||
<OutDir Value="languages"/>
|
||||
<EnableI18NForLFM Value="True"/>
|
||||
</i18n>
|
||||
<RequiredPkgs Count="1">
|
||||
<RequiredPkgs Count="2">
|
||||
<Item1>
|
||||
<PackageName Value="FCL"/>
|
||||
<PackageName Value="LazUtils"/>
|
||||
</Item1>
|
||||
<Item2>
|
||||
<PackageName Value="FCL"/>
|
||||
</Item2>
|
||||
</RequiredPkgs>
|
||||
<UsageOptions>
|
||||
<UnitPath Value="$(PkgOutDir)"/>
|
||||
|
@ -9,7 +9,7 @@ interface
|
||||
|
||||
uses
|
||||
rxCRC, rxConfigValues, rxconst, rxdateutil, rxdconst, rxFileUtils,
|
||||
rxstrutils, rxutils, RxTextHolder, LazarusPackageIntf;
|
||||
rxstrutils, rxutils, RxTextHolder, rxlogging, LazarusPackageIntf;
|
||||
|
||||
implementation
|
||||
|
||||
|
99
components/rx/trunk/rxtools/rxlogging.pas
Normal file
99
components/rx/trunk/rxtools/rxlogging.pas
Normal file
@ -0,0 +1,99 @@
|
||||
{ rxapputils unit
|
||||
|
||||
Copyright (C) 2005-2018 Lagunov Aleksey alexs75@yandex.ru and Lazarus team
|
||||
original conception from rx library for Delphi (c)
|
||||
|
||||
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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
}
|
||||
unit rxlogging;
|
||||
|
||||
{$I rx.inc}
|
||||
|
||||
interface
|
||||
|
||||
uses
|
||||
Classes, SysUtils;
|
||||
|
||||
type
|
||||
TRxLoggerEvent = procedure( ALogType:TEventType; const ALogMessage:string);
|
||||
|
||||
var
|
||||
OnRxLoggerEvent:TRxLoggerEvent = nil;
|
||||
|
||||
procedure RxWriteLog(ALogType:TEventType; const ALogMessage:string);
|
||||
procedure RxWriteLog(ALogType:TEventType; const ALogMessage:string; Params:array of const);
|
||||
procedure RxDefaultWriteLog( ALogType:TEventType; const ALogMessage:string);
|
||||
function RxDefaultLogFileName:string;
|
||||
procedure InitRxLogs;
|
||||
|
||||
implementation
|
||||
uses LazFileUtils;
|
||||
|
||||
procedure RxWriteLog(ALogType:TEventType; const ALogMessage:string);
|
||||
begin
|
||||
if Assigned(OnRxLoggerEvent) then
|
||||
OnRxLoggerEvent(ALogType, ALogMessage)
|
||||
end;
|
||||
|
||||
procedure RxWriteLog(ALogType: TEventType; const ALogMessage: string;
|
||||
Params: array of const);
|
||||
begin
|
||||
RxWriteLog(ALogType, Format(ALogMessage, Params));
|
||||
end;
|
||||
|
||||
procedure RxDefaultWriteLog(ALogType: TEventType; const ALogMessage: string);
|
||||
var
|
||||
F: Text;
|
||||
S: String;
|
||||
const
|
||||
sEventNames : array [TEventType] of string =
|
||||
('CUSTOM','INFO','WARNING','ERROR','DEBUG');
|
||||
begin
|
||||
S:=RxDefaultLogFileName;
|
||||
if S<>'' then
|
||||
begin
|
||||
Assign(F, S);
|
||||
if FileExists(S) then
|
||||
Append(F)
|
||||
else
|
||||
Rewrite(F);
|
||||
|
||||
Writeln(F,Format( '|%s| %20s |%s', [sEventNames[ALogType], DateTimeToStr(Now), ALogMessage]));
|
||||
CloseFile(F);
|
||||
end;
|
||||
end;
|
||||
|
||||
function RxDefaultLogFileName: string;
|
||||
begin
|
||||
Result:=AppendPathDelim(GetTempDir) + ExtractFileNameOnly(ParamStr(0)) + '.log';
|
||||
end;
|
||||
|
||||
procedure InitRxLogs;
|
||||
begin
|
||||
OnRxLoggerEvent:=@RxDefaultWriteLog;
|
||||
end;
|
||||
end.
|
||||
|
Reference in New Issue
Block a user