X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Fgame%2Fg_basic.pas;h=98cebcce846067023ff07b3fa558f1c9ddba0797;hb=10c770e6551f77ef4382930e7800ab93ea3e4047;hp=1705e0e371054939c97ff485be59178684684f72;hpb=a057c2c1dcfc935e6393b7ec9a2f93a2397c117d;p=d2df-sdl.git diff --git a/src/game/g_basic.pas b/src/game/g_basic.pas index 1705e0e..98cebcc 100644 --- a/src/game/g_basic.pas +++ b/src/game/g_basic.pas @@ -13,7 +13,7 @@ * You should have received a copy of the GNU General Public License * along with this program. If not, see . *) -{$MODE DELPHI} +{$INCLUDE ../shared/a_modes.inc} unit g_basic; interface @@ -47,8 +47,6 @@ function g_CollideLevel(X, Y: Integer; Width, Height: Word): Boolean; function g_CollideAround(X1, Y1: Integer; Width1, Height1: Word; X2, Y2: Integer; Width2, Height2: Word): Boolean; function g_CollidePlayer(X, Y: Integer; Width, Height: Word): Boolean; -function g_CollideMonster(X, Y: Integer; Width, Height: Word): Boolean; -function g_CollideItem(X, Y: Integer; Width, Height: Word): Boolean; function g_PatchLength(X1, Y1, X2, Y2: Integer): Word; function g_TraceVector(X1, Y1, X2, Y2: Integer): Boolean; function g_GetAcidHit(X, Y: Integer; Width, Height: Word): Byte; @@ -102,6 +100,10 @@ begin end; function g_CollideLevel(X, Y: Integer; Width, Height: Word): Boolean; +begin + result := g_Map_CollidePanel(X, Y, Width, Height, (PANEL_WALL or PANEL_CLOSEDOOR or PANEL_OPENDOOR), false); +end; +(* var a: Integer; begin @@ -121,6 +123,7 @@ begin Exit; end; end; +*) function g_CollidePlayer(X, Y: Integer; Width, Height: Word): Boolean; var @@ -139,41 +142,6 @@ begin end; end; -function g_CollideMonster(X, Y: Integer; Width, Height: Word): Boolean; -var - a: Integer; -begin - Result := False; - - if gMonsters = nil then Exit; - - for a := 0 to High(gMonsters) do - if (gMonsters[a] <> nil) and gMonsters[a].Live then - if g_Obj_Collide(X, Y, Width, Height, @gMonsters[a].Obj) then - begin - Result := True; - Exit; - end; -end; - -function g_CollideItem(X, Y: Integer; Width, Height: Word): Boolean; -var - a: Integer; -begin - Result := False; - - if gItems = nil then - Exit; - - for a := 0 to High(gItems) do - if gItems[a].Live then - if g_Obj_Collide(X, Y, Width, Height, @gItems[a].Obj) then - begin - Result := True; - Exit; - end; -end; - function g_TraceVector(X1, Y1, X2, Y2: Integer): Boolean; var i: Integer; @@ -254,19 +222,12 @@ begin UID_MONSTER: begin - repeat - Result := UID_MAX_PLAYER+$1+Random(UID_MAX_MONSTER-UID_MAX_GAME-UID_MAX_PLAYER+$1); - - ok := True; - if gMonsters <> nil then - for i := 0 to High(gMonsters) do - if gMonsters[i] <> nil then - if Result = gMonsters[i].UID then - begin - ok := False; - Break; - end; - until ok; + //FIXME!!! + while true do + begin + result := UID_MAX_PLAYER+$1+Random(UID_MAX_MONSTER-UID_MAX_GAME-UID_MAX_PLAYER+$1); + if (g_Monsters_ByUID(result) = nil) then break; + end; end; end; end; @@ -986,7 +947,7 @@ begin UID_MONSTER: begin - m := g_Monsters_Get(UID); + m := g_Monsters_ByUID(UID); if m = nil then Exit; if not m.Live then Exit;