X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Fgame%2Fg_basic.pas;h=367c0e1e87d1850a43fdfeca03ec9bc2b1368927;hb=31b1ad1d8b34f7f157c18618f4eaf2bdbd11d305;hp=afe112e157ecda9cd1a0e00b6ea25e640c9b2216;hpb=1581de2ca25df32e3126a91d6e306e18130656ca;p=d2df-sdl.git diff --git a/src/game/g_basic.pas b/src/game/g_basic.pas index afe112e..367c0e1 100644 --- a/src/game/g_basic.pas +++ b/src/game/g_basic.pas @@ -40,6 +40,7 @@ type function g_GetBuilderName (): AnsiString; function g_GetBuildHash (full: Boolean = True): AnsiString; +function g_GetBuildArch (): AnsiString; function g_CreateUID(UIDType: Byte): Word; function g_GetUIDType(UID: Word): Byte; @@ -54,7 +55,6 @@ function g_CollidePlayer(X, Y: Integer; Width, Height: Word): Boolean; inline; function g_PatchLength(X1, Y1, X2, Y2: Integer): Word; function g_TraceVector(X1, Y1, X2, Y2: Integer): Boolean; // `true`: no wall hit function g_GetAcidHit(X, Y: Integer; Width, Height: Word): Byte; -function g_Look(a, b: PObj; d: TDirection): Boolean; procedure IncMax(var A: Integer; B, Max: Integer); overload; procedure IncMax(var A: Single; B, Max: Single); overload; procedure IncMax(var A: Integer; Max: Integer); overload; @@ -76,8 +76,6 @@ function Sign(A: Single): ShortInt; overload; function PointToRect(X, Y, X1, Y1: Integer; Width, Height: Word): Integer; function GetAngle(baseX, baseY, pointX, PointY: Integer): SmallInt; function GetAngle2(vx, vy: Integer): SmallInt; -function GetLines(Text: string; FontID: DWORD; MaxWidth: Word): SSArray; -procedure Sort(var a: SSArray); function Sscanf(const s: string; const fmt: string; const Pointers: array of Pointer): Integer; function InDWArray(a: DWORD; arr: DWArray): Boolean; @@ -100,8 +98,8 @@ var implementation uses - Math, geom, e_log, g_map, g_gfx, g_player, SysUtils, MAPDEF, - StrUtils, e_graphics, g_monsters, g_items, g_game; + Math, geom, e_log, g_map, g_player, SysUtils, MAPDEF, + StrUtils, g_monsters, g_items, g_game; {$PUSH} {$WARN 2054 OFF} // unknwon env var @@ -130,6 +128,90 @@ begin end; {$POP} +function g_GetBuildArch (): AnsiString; + var cpu, mode, fpu: AnsiString; +begin + {$IF DEFINED(CPUX86_64) OR DEFINED(CPUAMD64) OR DEFINED(CPUX64)} + cpu := 'x86_64'; + {$ELSEIF DEFINED(CPUI386) OR DEFINED(CPU386)} + cpu := 'x86'; + {$ELSEIF DEFINED(CPUI8086)} + cpu := 'i8086'; + {$ELSEIF DEFINED(CPUI64)} + cpu := 'Itanium64'; + {$ELSEIF DEFINED(CPUARM)} + cpu := 'ARM'; + {$ELSEIF DEFINED(CPUAVR)} + cpu := 'AVR'; + {$ELSEIF DEFINED(CPUPOWERPC32)} + cpu := 'PowerPC_32'; + {$ELSEIF DEFINED(CPUPOWERPC64)} + cpu := 'PowerPC_64'; + {$ELSEIF DEFINED(CPUALPHA)}} + cpu := 'Alpha'; + {$ELSEIF DEFINED(CPUSPARC32)} + cpu := 'Sparc32'; + {$ELSEIF DEFINED(CPUM68020)} + cpu := 'M68020'; + {$ELSEIF DEFINED(CPU68K) OR DEFINED(CPUM68K)} + cpu := 'm68k'; + {$ELSEIF DEFINED(CPUSPARC)} + cpu := 'unknown-sparc'; + {$ELSEIF DEFINED(CPUPOWERPC)} + cpu := 'unknown-ppc'; + {$ELSEIF DEFINED(CPU86) OR DEFINED(CPU87)} + cpu := 'unknown-intel'; + {$ELSE} + cpu := 'unknown-arch'; + {$ENDIF} + + {$IF DEFINED(CPU64)} + mode := '64-bit'; + {$ELSEIF DEFINED(CPU32)} + mode := '32-bit'; + {$ELSEIF DEFINED(CPU16)} + mode := '16-bit'; + {$ELSE} + mode := 'unknown-mode'; + {$ENDIF} + + {$IF DEFINED(FPUSOFT)} + fpu := 'soft'; + {$ELSEIF DEFINED(FPUSSE3)} + fpu := 'sse3'; + {$ELSEIF DEFINED(FPUSSE2)} + fpu := 'sse2'; + {$ELSEIF DEFINED(FPUSSE)} + fpu := 'sse'; + {$ELSEIF DEFINED(FPUSSE64)} + fpu := 'sse64'; + {$ELSEIF DEFINED(FPULIBGCC)} + fpu := 'libgcc'; + {$ELSEIF DEFINED(FPU68881)} + fpu := '68881'; + {$ELSEIF DEFINED(FPUVFP)} + fpu := 'vfp'; + {$ELSEIF DEFINED(FPUFPA11)} + fpu := 'fpa11'; + {$ELSEIF DEFINED(FPUFPA10)} + fpu := 'fpa10'; + {$ELSEIF DEFINED(FPUFPA)} + fpu := 'fpa'; + {$ELSEIF DEFINED(FPUX87)} + fpu := 'x87'; + {$ELSEIF DEFINED(FPUITANIUM)} + fpu := 'itanium'; + {$ELSEIF DEFINED(FPUSTANDARD)} + fpu := 'standard'; + {$ELSEIF DEFINED(FPUHARD)} + fpu := 'hard'; + {$ELSE} + fpu := 'unknown-fpu'; + {$ENDIF} + + result := cpu + ' ' + mode + ' ' + fpu; +end; + function g_PatchLength(X1, Y1, X2, Y2: Integer): Word; begin Result := Min(Round(Hypot(Abs(X2-X1), Abs(Y2-Y1))), 65535); @@ -482,23 +564,6 @@ begin Result := tab[a]; end; -function g_Look(a, b: PObj; d: TDirection): Boolean; -begin - if not gmon_dbg_los_enabled then begin result := false; exit; end; // always "wall hit" - - if ((b^.X > a^.X) and (d = TDirection.D_LEFT)) or - ((b^.X < a^.X) and (d = TDirection.D_RIGHT)) then - begin - Result := False; - Exit; - end; - - Result := g_TraceVector(a^.X+a^.Rect.X+(a^.Rect.Width div 2), - a^.Y+a^.Rect.Y+(a^.Rect.Height div 2), - b^.X+b^.Rect.X+(b^.Rect.Width div 2), - b^.Y+b^.Rect.Y+(b^.Rect.Height div 2)); -end; - function GetAngle(baseX, baseY, pointX, PointY: Integer): SmallInt; var c: Single; @@ -658,62 +723,6 @@ begin end; end; -function GetLines (Text: string; FontID: DWORD; MaxWidth: Word): SSArray; - var i, j, len, lines: Integer; - - function GetLine (j, i: Integer): String; - begin - result := Copy(text, j, i - j + 1); - end; - - function GetWidth (j, i: Integer): Integer; - var w, h: Word; - begin - e_CharFont_GetSize(FontID, GetLine(j, i), w, h); - result := w - end; - -begin - result := nil; lines := 0; - j := 1; i := 1; len := Length(Text); - e_LogWritefln('GetLines @%s len=%s [%s]', [MaxWidth, len, Text]); - while j <= len do - begin - (* --- Get longest possible sequence --- *) - while (i + 1 <= len) and (GetWidth(j, i + 1) <= MaxWidth) do Inc(i); - (* --- Do not include part of word --- *) - if (i < len) and (text[i] <> ' ') then - while (i >= j) and (text[i] <> ' ') do Dec(i); - (* --- Do not include spaces --- *) - while (i >= j) and (text[i] = ' ') do Dec(i); - (* --- Add line --- *) - SetLength(result, lines + 1); - result[lines] := GetLine(j, i); - e_LogWritefln(' -> (%s:%s::%s) [%s]', [j, i, GetWidth(j, i), result[lines]]); - Inc(lines); - (* --- Skip spaces --- *) - while (i <= len) and (text[i] = ' ') do Inc(i); - j := i + 2; - end; -end; - -procedure Sort(var a: SSArray); -var - i, j: Integer; - s: string; -begin - if a = nil then Exit; - - for i := High(a) downto Low(a) do - for j := Low(a) to High(a)-1 do - if LowerCase(a[j]) > LowerCase(a[j+1]) then - begin - s := a[j]; - a[j] := a[j+1]; - a[j+1] := s; - end; -end; - function Sscanf(const s: String; const fmt: String; const Pointers: array of Pointer): Integer; var