-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathspritelylog.pas
58 lines (47 loc) · 1002 Bytes
/
spritelylog.pas
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
unit SpritelyLog;
{$mode objfpc}{$H+}
interface
uses
Classes, SysUtils,
CastleLog, CastleApplicationProperties,
CastleClassUtils, CastleNotifications;
type
{ Log handler sending logs to server using asynchronous HTTP POST. }
TLogHandler = class(TComponent)
strict private
InsideLogCallback: Boolean;
public
constructor Create(AOwner: TComponent); override;
procedure LogCallback(const Message: String);
end;
var
LogHandler: TLogHandler;
implementation
{$ifdef cgeapp}
uses AppInitialization;
{$else}
uses GUIInitialization;
{$endif}
constructor TLogHandler.Create(AOwner: TComponent);
begin
inherited;
end;
procedure TLogHandler.LogCallback(const Message: String);
begin
if InsideLogCallback then
Exit;
InsideLogCallback := True;
try
{$ifdef cgeapp}
WriteLn(stderr, Message);
{$else}
with CastleForm do
begin
Applog.Lines.Add(Message);
end;
{$endif}
finally
InsideLogCallback := False;
end;
end;
end.