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
|
type
|
||||||
TOnGetDefaultIniName = function: string;
|
TOnGetDefaultIniName = function: string;
|
||||||
TRxLoggerEvent = procedure( ALogType:TEventType; const ALogMessage:string);
|
|
||||||
|
|
||||||
const
|
const
|
||||||
OnGetDefaultIniName: TOnGetDefaultIniName = nil;
|
OnGetDefaultIniName: TOnGetDefaultIniName = nil;
|
||||||
OnRxLoggerEvent:TRxLoggerEvent = nil;
|
|
||||||
|
|
||||||
//Save to IniFile or TRegIniFile string value
|
//Save to IniFile or TRegIniFile string value
|
||||||
procedure IniWriteString(IniFile: TObject; const Section, Ident,
|
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);
|
||||||
procedure ErrorBox(const S:string; Params:array of const);
|
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 RxGetKeyboardLayoutName:string;
|
||||||
|
|
||||||
function RxMessageBeep(AStyle:TRxMsgBeepStyle):boolean;
|
function RxMessageBeep(AStyle:TRxMsgBeepStyle):boolean;
|
||||||
@ -110,7 +102,7 @@ uses
|
|||||||
{$IFDEF LINUX}
|
{$IFDEF LINUX}
|
||||||
X, XKB, xkblib, xlib,
|
X, XKB, xkblib, xlib,
|
||||||
{$ENDIF}
|
{$ENDIF}
|
||||||
Registry, Forms, FileUtil, LazUTF8, LazFileUtils, Dialogs;
|
Registry, Forms, FileUtil, LazUTF8, LazFileUtils, Dialogs, rxlogging;
|
||||||
|
|
||||||
function RxGetAppConfigDir(Global: Boolean): String;
|
function RxGetAppConfigDir(Global: Boolean): String;
|
||||||
{$IFDEF WINDOWS}
|
{$IFDEF WINDOWS}
|
||||||
@ -134,11 +126,6 @@ begin
|
|||||||
end;
|
end;
|
||||||
{$ENDIF}
|
{$ENDIF}
|
||||||
|
|
||||||
procedure RxWriteLog(ALogType:TEventType; const ALogMessage:string);
|
|
||||||
begin
|
|
||||||
if Assigned(OnRxLoggerEvent) then
|
|
||||||
OnRxLoggerEvent(ALogType, ALogMessage)
|
|
||||||
end;
|
|
||||||
|
|
||||||
procedure InfoBox(const S: string);
|
procedure InfoBox(const S: string);
|
||||||
begin
|
begin
|
||||||
@ -176,43 +163,6 @@ begin
|
|||||||
ErrorBox(Format(S, Params));
|
ErrorBox(Format(S, Params));
|
||||||
end;
|
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}
|
{$IFDEF LINUX}
|
||||||
function getKeyboardLang(dpy:PDisplay; AGroup:Integer):string;
|
function getKeyboardLang(dpy:PDisplay; AGroup:Integer):string;
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
"/>
|
"/>
|
||||||
<License Value="LGPL"/>
|
<License Value="LGPL"/>
|
||||||
<Version Minor="4" Build="6"/>
|
<Version Minor="4" Build="6"/>
|
||||||
<Files Count="10">
|
<Files Count="11">
|
||||||
<Item1>
|
<Item1>
|
||||||
<Filename Value="rxtools/rxcrc.pas"/>
|
<Filename Value="rxtools/rxcrc.pas"/>
|
||||||
<UnitName Value="rxCRC"/>
|
<UnitName Value="rxCRC"/>
|
||||||
@ -55,6 +55,10 @@
|
|||||||
<Filename Value="rxtools/rxtextholder.pas"/>
|
<Filename Value="rxtools/rxtextholder.pas"/>
|
||||||
<UnitName Value="RxTextHolder"/>
|
<UnitName Value="RxTextHolder"/>
|
||||||
</Item10>
|
</Item10>
|
||||||
|
<Item11>
|
||||||
|
<Filename Value="rxtools/rxlogging.pas"/>
|
||||||
|
<UnitName Value="rxlogging"/>
|
||||||
|
</Item11>
|
||||||
</Files>
|
</Files>
|
||||||
<LazDoc Paths="docs;/usr/local/share/lazarus/components/rxnew/docs"/>
|
<LazDoc Paths="docs;/usr/local/share/lazarus/components/rxnew/docs"/>
|
||||||
<i18n>
|
<i18n>
|
||||||
@ -62,10 +66,13 @@
|
|||||||
<OutDir Value="languages"/>
|
<OutDir Value="languages"/>
|
||||||
<EnableI18NForLFM Value="True"/>
|
<EnableI18NForLFM Value="True"/>
|
||||||
</i18n>
|
</i18n>
|
||||||
<RequiredPkgs Count="1">
|
<RequiredPkgs Count="2">
|
||||||
<Item1>
|
<Item1>
|
||||||
<PackageName Value="FCL"/>
|
<PackageName Value="LazUtils"/>
|
||||||
</Item1>
|
</Item1>
|
||||||
|
<Item2>
|
||||||
|
<PackageName Value="FCL"/>
|
||||||
|
</Item2>
|
||||||
</RequiredPkgs>
|
</RequiredPkgs>
|
||||||
<UsageOptions>
|
<UsageOptions>
|
||||||
<UnitPath Value="$(PkgOutDir)"/>
|
<UnitPath Value="$(PkgOutDir)"/>
|
||||||
|
@ -9,7 +9,7 @@ interface
|
|||||||
|
|
||||||
uses
|
uses
|
||||||
rxCRC, rxConfigValues, rxconst, rxdateutil, rxdconst, rxFileUtils,
|
rxCRC, rxConfigValues, rxconst, rxdateutil, rxdconst, rxFileUtils,
|
||||||
rxstrutils, rxutils, RxTextHolder, LazarusPackageIntf;
|
rxstrutils, rxutils, RxTextHolder, rxlogging, LazarusPackageIntf;
|
||||||
|
|
||||||
implementation
|
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