author | unc0rr |
Tue, 03 Jul 2007 17:03:41 +0000 | |
changeset 550 | f6a18d2bab00 |
parent 547 | b81a055f2d06 |
child 553 | 5478386d935f |
permissions | -rw-r--r-- |
393 | 1 |
(* |
2 |
* Hedgewars, a worms-like game |
|
3 |
* Copyright (c) 2006, 2007 Andrey Korotaev <unC0Rr@gmail.com> |
|
4 |
* |
|
5 |
* This program is free software; you can redistribute it and/or modify |
|
6 |
* it under the terms of the GNU General Public License as published by |
|
7 |
* the Free Software Foundation; version 2 of the License |
|
8 |
* |
|
9 |
* This program is distributed in the hope that it will be useful, |
|
10 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
11 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
12 |
* GNU General Public License for more details. |
|
13 |
* |
|
14 |
* You should have received a copy of the GNU General Public License |
|
15 |
* along with this program; if not, write to the Free Software |
|
16 |
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA |
|
17 |
*) |
|
18 |
||
288 | 19 |
unit uAmmos; |
20 |
interface |
|
534 | 21 |
uses uConsts, uTeams; |
288 | 22 |
{$INCLUDE options.inc} |
23 |
||
24 |
procedure AddAmmoStore(s: shortstring); |
|
25 |
procedure AssignStores; |
|
295 | 26 |
procedure AddAmmo(Hedgehog: pointer; ammo: TAmmoType); |
27 |
function HHHasAmmo(Hedgehog: pointer; Ammo: TAmmoType): boolean; |
|
371 | 28 |
procedure PackAmmo(Ammo: PHHAmmo; Slot: LongInt); |
534 | 29 |
procedure OnUsedAmmo(var Hedgehog: THedgehog); |
288 | 30 |
|
31 |
implementation |
|
534 | 32 |
uses uMisc, uGears; |
295 | 33 |
type TAmmoCounts = array[TAmmoType] of Longword; |
288 | 34 |
var StoresList: array[0..Pred(cMaxHHs)] of PHHAmmo; |
35 |
StoreCnt: Longword = 0; |
|
36 |
||
295 | 37 |
procedure FillAmmoStore(Ammo: PHHAmmo; var cnts: TAmmoCounts); |
288 | 38 |
var mi: array[0..cMaxSlotIndex] of byte; |
39 |
a: TAmmoType; |
|
295 | 40 |
begin |
41 |
FillChar(mi, sizeof(mi), 0); |
|
42 |
FillChar(Ammo^, sizeof(Ammo^), 0); |
|
43 |
for a:= Low(TAmmoType) to High(TAmmoType) do |
|
44 |
if cnts[a] > 0 then |
|
45 |
begin |
|
46 |
TryDo(mi[Ammoz[a].Slot] <= cMaxSlotAmmoIndex, 'Ammo slot overflow', true); |
|
351 | 47 |
Ammo^[Ammoz[a].Slot, mi[Ammoz[a].Slot]]:= Ammoz[a].Ammo; |
48 |
Ammo^[Ammoz[a].Slot, mi[Ammoz[a].Slot]].Count:= cnts[a]; |
|
295 | 49 |
inc(mi[Ammoz[a].Slot]) |
50 |
end |
|
51 |
end; |
|
52 |
||
53 |
procedure AddAmmoStore(s: shortstring); |
|
54 |
var cnt: Longword; |
|
55 |
a: TAmmoType; |
|
56 |
ammos: TAmmoCounts; |
|
288 | 57 |
begin |
58 |
TryDo(byte(s[0]) = byte(ord(High(TAmmoType)) + 1), 'Invalid ammo scheme (incompatible frontend)', true); |
|
59 |
||
60 |
inc(StoreCnt); |
|
61 |
TryDo(StoreCnt <= cMaxHHs, 'Ammo stores overflow', true); |
|
62 |
||
63 |
new(StoresList[Pred(StoreCnt)]); |
|
64 |
||
65 |
for a:= Low(TAmmoType) to High(TAmmoType) do |
|
66 |
begin |
|
67 |
cnt:= byte(s[ord(a) + 1]) - byte('0'); |
|
295 | 68 |
if cnt = 9 then cnt:= AMMO_INFINITE; |
69 |
ammos[a]:= cnt |
|
288 | 70 |
end; |
295 | 71 |
|
72 |
FillAmmoStore(StoresList[Pred(StoreCnt)], ammos) |
|
288 | 73 |
end; |
74 |
||
75 |
function GetAmmoByNum(num: Longword): PHHAmmo; |
|
76 |
begin |
|
77 |
TryDo(num < StoreCnt, 'Invalid store number', true); |
|
351 | 78 |
exit(StoresList[num]) |
288 | 79 |
end; |
80 |
||
81 |
procedure AssignStores; |
|
547 | 82 |
var t: LongInt; |
288 | 83 |
i: Longword; |
84 |
begin |
|
547 | 85 |
for t:= 0 to Pred(TeamsCount) do |
86 |
with TeamsArray[t]^ do |
|
288 | 87 |
begin |
88 |
for i:= 0 to cMaxHHIndex do |
|
547 | 89 |
if Hedgehogs[i].Gear <> nil then |
90 |
Hedgehogs[i].Ammo:= GetAmmoByNum(Hedgehogs[i].AmmoStore); |
|
288 | 91 |
end |
92 |
end; |
|
93 |
||
295 | 94 |
procedure AddAmmo(Hedgehog: pointer; ammo: TAmmoType); |
95 |
var ammos: TAmmoCounts; |
|
371 | 96 |
slot, ami: LongInt; |
295 | 97 |
hhammo: PHHAmmo; |
98 |
begin |
|
99 |
FillChar(ammos, sizeof(ammos), 0); |
|
351 | 100 |
hhammo:= PHedgehog(Hedgehog)^.Ammo; |
295 | 101 |
|
102 |
for slot:= 0 to cMaxSlotIndex do |
|
103 |
for ami:= 0 to cMaxSlotAmmoIndex do |
|
351 | 104 |
if hhammo^[slot, ami].Count > 0 then |
105 |
ammos[hhammo^[slot, ami].AmmoType]:= hhammo^[slot, ami].Count; |
|
295 | 106 |
|
394
4c017ae1226a
- Implement hack to let ammo stores work without needed assistance of frontend
unc0rr
parents:
393
diff
changeset
|
107 |
if ammos[ammo] <> AMMO_INFINITE then inc(ammos[ammo], Ammoz[ammo].NumberInCase); |
295 | 108 |
FillAmmoStore(hhammo, ammos) |
109 |
end; |
|
110 |
||
371 | 111 |
procedure PackAmmo(Ammo: PHHAmmo; Slot: LongInt); |
112 |
var ami: LongInt; |
|
295 | 113 |
b: boolean; |
114 |
begin |
|
115 |
repeat |
|
116 |
b:= false; |
|
117 |
ami:= 0; |
|
118 |
while (not b) and (ami < cMaxSlotAmmoIndex) do |
|
351 | 119 |
if (Ammo^[Slot, ami].Count = 0) |
120 |
and (Ammo^[Slot, ami + 1].Count > 0) then b:= true |
|
295 | 121 |
else inc(ami); |
122 |
if b then // there's a free item in ammo stack |
|
123 |
begin |
|
351 | 124 |
Ammo^[Slot, ami]:= Ammo^[Slot, ami + 1]; |
125 |
Ammo^[Slot, ami + 1].Count:= 0 |
|
295 | 126 |
end; |
127 |
until not b; |
|
128 |
end; |
|
129 |
||
534 | 130 |
procedure OnUsedAmmo(var Hedgehog: THedgehog); |
295 | 131 |
var s, a: Longword; |
132 |
begin |
|
534 | 133 |
with Hedgehog do |
295 | 134 |
begin |
135 |
if CurAmmoGear = nil then begin s:= CurSlot; a:= CurAmmo end |
|
136 |
else begin s:= AltSlot; a:= AltAmmo end; |
|
351 | 137 |
with Ammo^[s, a] do |
295 | 138 |
if Count <> AMMO_INFINITE then |
139 |
begin |
|
140 |
dec(Count); |
|
141 |
if Count = 0 then PackAmmo(Ammo, CurSlot) |
|
142 |
end |
|
143 |
end |
|
144 |
end; |
|
145 |
||
146 |
function HHHasAmmo(Hedgehog: pointer; Ammo: TAmmoType): boolean; |
|
371 | 147 |
var slot, ami: LongInt; |
295 | 148 |
begin |
149 |
Slot:= Ammoz[Ammo].Slot; |
|
150 |
ami:= 0; |
|
351 | 151 |
while (ami <= cMaxSlotAmmoIndex) do |
295 | 152 |
begin |
351 | 153 |
with PHedgehog(Hedgehog)^.Ammo^[Slot, ami] do |
154 |
if (AmmoType = Ammo) and (Count > 0) then exit(true); |
|
295 | 155 |
inc(ami) |
351 | 156 |
end; |
157 |
HHHasAmmo:= false |
|
295 | 158 |
end; |
159 |
||
288 | 160 |
end. |