forked from jwvhewitt/gearhead-1
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathghintrinsic.pp
85 lines (69 loc) · 2.38 KB
/
ghintrinsic.pp
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
unit ghintrinsic;
{ Intrinsics are flags that can be attached to any object. They increase }
{ the cost of that object by a finite amount. }
{
GearHead2, a roguelike mecha CRPG
Copyright (C) 2005 Joseph Hewitt
This library is free software; you can redistribute it and/or modify it
under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 2.1 of the License, or (at
your option) any later version.
The full text of the LGPL can be found in license.txt.
This library is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser
General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with this library; if not, write to the Free Software Foundation,
Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
}
{$LONGSTRINGS ON}
interface
uses gears;
const
NAG_Intrinsic = 18;
NumIntrinsic = 7;
NAS_Memo = 1;
NAS_Email = 2;
NAS_News = 3;
NAS_Phone = 4;
NAS_EnviroSealed = 5;
NAS_Integral = 6;
NAS_Personadex = 7;
Intrinsic_Value: Array [1..NumIntrinsic] of Integer = (
200, 300, 400, 500, 100,
0, 250
);
Function IntrinsicCost( Item: GearPtr ): LongInt;
Function PartHasIntrinsic( Part: GearPtr; I: Integer ): Boolean;
implementation
Function IntrinsicCost( Item: GearPtr ): LongInt;
{ Determine the cost of all the intrinsics attached to this item. }
var
Total: longInt;
I: NAttPtr;
begin
Total := 0;
I := Item^.NA;
while I <> Nil do begin
if ( I^.G = NAG_Intrinsic ) and ( I^.S >= 1 ) and ( I^.S <= NumIntrinsic ) then begin
total := total + Intrinsic_Value[ I^.S ];
end;
I := I^.Next;
end;
IntrinsicCost := Total;
end;
Function PartHasIntrinsic( Part: GearPtr; I: Integer ): Boolean;
{ Return TRUE if Part has this intrinsic, or FALSE otherwise. }
begin
if Part = Nil then begin
PartHasIntrinsic := False;
{end else if Part^.G = GG_Software then begin
{ Software that comes loaded with an intrinsic only functions }
{ when it's been installed on a computer. }
PartHasIntrinsic := ( Part^.Parent <> Nil ) and ( Part^.Parent^.G = GG_Computer ) and ( NAttValue( Part^.NA , NAG_Intrinsic , I ) <> 0 );}
end else begin
PartHasIntrinsic := ( NAttValue( Part^.NA , NAG_Intrinsic , I ) <> 0 );
end;
end;
end.