index efca52fcafad7736e72f30afe8dce85aa6352398..5e6212b921b5b7ddc04784ad9d601503b3d93483 100644 (file)
--- a/src/shared/xprofiler.pas
+++ b/src/shared/xprofiler.pas
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
+ * the Free Software Foundation, version 3 of the License ONLY.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
interface
-uses
- SysUtils,
- {$IF DEFINED(LINUX)}
+{$IFNDEF IN_TOOLS}
+ uses
+ {$IFDEF USE_SDL}
+ SDL,
+ {$ENDIF}
+ {$IFDEF USE_SDL2}
+ SDL2,
+ {$ENDIF}
+ SysUtils;
+
+ {$DEFINE STOPWATCH_IS_HERE}
+
+{$ELSE}
+ uses
+ SysUtils
+ {$IF DEFINED(LINUX) OR DEFINED(ANDROID)}
{$DEFINE STOPWATCH_IS_HERE}
- unixtype, linux
+ , unixtype, linux
{$ELSEIF DEFINED(WINDOWS)}
{$DEFINE STOPWATCH_IS_HERE}
- Windows
+ , Windows
{$ELSEIF DEFINED(HAIKU)}
{$DEFINE STOPWATCH_IS_HERE}
- unixtype
+ , unixtype
{$ELSE}
{$IFDEF STOPWATCH_IS_HERE}
{$UNDEF STOPWATCH_IS_HERE}
{$WARNING You suck!}
{$ENDIF}
;
+{$ENDIF} // IN_TOOLS
+
+{$IFDEF USE_SDL}
+ type
+ UInt64 = QWord; (* !!! *)
+{$ENDIF}
{$IF DEFINED(STOPWATCH_IS_HERE)}
type
implementation
+{$IFNDEF IN_TOOLS}
+type
+ THPTimeType = Int64;
+{$ELSE}
{$IF DEFINED(LINUX)}
type THPTimeType = TTimeSpec;
{$ELSE}
var
mFrequency: Int64 = 0;
mHasHPTimer: Boolean = false;
+{$ENDIF}
// ////////////////////////////////////////////////////////////////////////// //
procedure initTimerIntr ();
+{$IFDEF IN_TOOLS}
var
r: THPTimeType;
+{$ENDIF}
begin
+{$IFDEF IN_TOOLS}
if (mFrequency = 0) then
begin
{$IF DEFINED(LINUX)}
mFrequency := r;
{$ENDIF}
end;
+{$ENDIF}
+ (* init sdl timers? *)
end;
+{$IF DEFINED(IN_TOOLS)}
function getTimeMicro (): UInt64; inline;
var
r: THPTimeType;
result := UInt64(r)*1000000 div mFrequency;
{$ENDIF}
end;
+(* !!!
+{$ELSEIF DEFINED(USE_SDL)}
+function getTimeMicro: UInt64; inline;
+begin
+ {$WARNING use inaccurate profiling timer}
+ result := SDL_GetTicks() * 1000
+end;
+*)
+{$ELSEIF DEFINED(USE_SDL2)}
+function getTimeMicro (): UInt64; inline;
+begin
+ Result := SDL_GetPerformanceCounter() * 1000000 div SDL_GetPerformanceFrequency()
+end;
+{$ELSE}
+function getTimeMicro: UInt64; inline;
+begin
+ {$WARNING use stub profiling timer}
+end;
+{$ENDIF}
function getTimeMilli (): UInt64; inline;
begin
- result := getTimeMicro div 1000;
+ result := getTimeMicro() div 1000;
end;