Menu

[r7]: / appservices.pas  Maximize  Restore  History

Download this file

99 lines (85 with data), 3.2 kB

 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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
{---------------------------------------------------------------------}
{ }
{ Firebird database server profiler tool (FBProfiler) }
{ }
{ Copyright (c) 2013-2018 Bel Air Informatique (www.belair-info.fr) }
{ Copyright (c) 2013-2018 Serguei Tarassov (www.arbinada.com) }
{ }
{ FBProfiler uses IBX For Lazarus components (Firebird Express) }
{ FBProfiler was firstly released for public domain }
{ on October 31 of 2015 (Halloween) so any donations are welcome. }
{ }
{ The contents of this file are subject to the InterBase }
{ Public License Version 1.0 (the "License"); you may not }
{ use this file except in compliance with the License. You }
{ may obtain a copy of the License at }
{ http://www.firebirdsql.org/en/interbase-public-license/ }
{ Software distributed under the License is distributed on }
{ an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either }
{ express or implied. See the License for the specific language }
{ governing rights and limitations under the License. }
{ }
{---------------------------------------------------------------------}
unit AppServices;
{$mode objfpc}{$H+}
interface
uses
Classes, SysUtils, EventLog,
{$IFDEF WINDOWS}
Windows,
{$ENDIF}
VersionResource, VersionTypes,
TraceControl;
function GetLog: TEventLog;
function GetTraces: TTraceSessionManager;
function GetVersionInfo: TVersionFixedInfo;
implementation
var
TraceManager: TTraceSessionManager = nil;
Log: TEventLog = nil;
FileVersionResource: TVersionResource = nil;
function GetLog: TEventLog;
begin
if Log = nil then
begin
Log := TEventLog.Create(nil);
Log.FileName := ParamStr(0) + '.log';
Log.LogType := ltFile;
Log.Active := True;
end;
Result := Log;
end;
function GetTraces: TTraceSessionManager;
begin
if TraceManager = nil then
TraceManager := TTraceSessionManager.Create;
Result := TraceManager;
end;
function GetVersionInfo: TVersionFixedInfo;
var
Stream: TResourceStream;
begin
if FileVersionResource = nil then
begin
FileVersionResource := TVersionResource.Create;
Stream := TResourceStream.CreateFromID(HINSTANCE, 1, PChar(RT_VERSION));
try
FileVersionResource.SetCustomRawDataStream(Stream);
Result := FileVersionResource.FixedInfo; // load data
FileVersionResource.SetCustomRawDataStream(nil);
finally
Stream.Free
end;
end
else
Result := FileVersionResource.FixedInfo;
end;
initialization
finalization
if TraceManager <> nil then
FreeAndNil(TraceManager);
if Log <> nil then
FreeAndNil(Log);
if FileVersionResource = nil then
FreeAndNil(FileVersionResource);
end.
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.