]>
git.zerfleddert.de Git - micropolis/blob - src/sim/s_power.c
5d309b320530a047036a05ab8371cf3a3b7a594a
3 * Micropolis, Unix Version. This game was released for the Unix platform
4 * in or about 1990 and has been modified for inclusion in the One Laptop
5 * Per Child program. Copyright (C) 1989 - 2007 Electronic Arts Inc. If
6 * you need assistance with this program, you may contact:
7 * http://wiki.laptop.org/go/Micropolis or email micropolis@laptop.org.
9 * This program is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation, either version 3 of the License, or (at
12 * your option) any later version.
14 * This program is distributed in the hope that it will be useful, but
15 * WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 * General Public License for more details. You should have received a
18 * copy of the GNU General Public License along with this program. If
19 * not, see <http://www.gnu.org/licenses/>.
21 * ADDITIONAL TERMS per GNU GPL Section 7
23 * No trademark or publicity rights are granted. This license does NOT
24 * give you any right, title or interest in the trademark SimCity or any
25 * other Electronic Arts trademark. You may not distribute any
26 * modification of this program using the trademark SimCity or claim any
27 * affliation or association with Electronic Arts Inc. or its employees.
29 * Any propagation or conveyance of this program must include this
30 * copyright notice and these terms.
32 * If you convey this program (or any modifications of it) and assume
33 * contractual liability for the program to recipients of it, you agree
34 * to indemnify Electronic Arts for any liability that those contractual
35 * assumptions impose on Electronic Arts.
37 * You may not misrepresent the origins of this program; modified
38 * versions of the program must be marked as such and not identified as
39 * the original program.
41 * This disclaimer supplements the one included in the General Public
42 * License. TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, THIS
43 * PROGRAM IS PROVIDED TO YOU "AS IS," WITH ALL FAULTS, WITHOUT WARRANTY
44 * OF ANY KIND, AND YOUR USE IS AT YOUR SOLE RISK. THE ENTIRE RISK OF
45 * SATISFACTORY QUALITY AND PERFORMANCE RESIDES WITH YOU. ELECTRONIC ARTS
46 * DISCLAIMS ANY AND ALL EXPRESS, IMPLIED OR STATUTORY WARRANTIES,
47 * INCLUDING IMPLIED WARRANTIES OF MERCHANTABILITY, SATISFACTORY QUALITY,
48 * FITNESS FOR A PARTICULAR PURPOSE, NONINFRINGEMENT OF THIRD PARTY
49 * RIGHTS, AND WARRANTIES (IF ANY) ARISING FROM A COURSE OF DEALING,
50 * USAGE, OR TRADE PRACTICE. ELECTRONIC ARTS DOES NOT WARRANT AGAINST
51 * INTERFERENCE WITH YOUR ENJOYMENT OF THE PROGRAM; THAT THE PROGRAM WILL
52 * MEET YOUR REQUIREMENTS; THAT OPERATION OF THE PROGRAM WILL BE
53 * UNINTERRUPTED OR ERROR-FREE, OR THAT THE PROGRAM WILL BE COMPATIBLE
54 * WITH THIRD PARTY SOFTWARE OR THAT ANY ERRORS IN THE PROGRAM WILL BE
55 * CORRECTED. NO ORAL OR WRITTEN ADVICE PROVIDED BY ELECTRONIC ARTS OR
56 * ANY AUTHORIZED REPRESENTATIVE SHALL CREATE A WARRANTY. SOME
57 * JURISDICTIONS DO NOT ALLOW THE EXCLUSION OF OR LIMITATIONS ON IMPLIED
58 * WARRANTIES OR THE LIMITATIONS ON THE APPLICABLE STATUTORY RIGHTS OF A
59 * CONSUMER, SO SOME OR ALL OF THE ABOVE EXCLUSIONS AND LIMITATIONS MAY
69 char PowerStackX
[PWRSTKSIZE
], PowerStackY
[PWRSTKSIZE
];
70 QUAD MaxPower
, NumPower
;
73 /* comefrom: TestForCond DoPowerScan TryGo */
74 MoveMapSim (short MDir
)
86 if (SMapX
< (WORLD_X
- 1)) {
90 if (SMapX
> (WORLD_X
- 1))
94 if (SMapY
< (WORLD_Y
- 1)) {
98 if (SMapY
> (WORLD_Y
- 1))
118 /* comefrom: DoPowerScan */
121 register int PowerWrd
;
123 /* XXX: assumes 120x100 */
124 PowerWrd
= (SMapX
>>4) + (SMapY
<<3);
125 PowerMap
[PowerWrd
] |= 1 << (SMapX
& 15);
132 /* comefrom: TestForCond */
133 int TestPowerBit(void)
135 register int PowerWrd
;
137 if ((CChr9
== NUCLEAR
) || (CChr9
== POWERPLANT
))
139 /* XXX: assumes 120x100 */
140 PowerWrd
= (SMapX
>>4) + (SMapY
<<3);
141 if (PowerWrd
>= PWRMAPSIZE
)
143 return ((PowerMap
[PowerWrd
] & (1 << (SMapX
& 15))) ? 1 : 0);
148 /* comefrom: DoPowerScan */
149 short TestForCond(short TFDir
)
151 register int xsave
, ysave
, PowerWrd
;
155 if (MoveMapSim(TFDir
)) {
156 /* TestPowerBit was taking a lot of time so I swapped the & order -Don */
158 if ((Map
[SMapX
][SMapY
] & CONDBIT
) &&
161 if ((Map
[SMapX
][SMapY
] & CONDBIT
) &&
162 (CChr9
!= NUCLEAR
) &&
163 (CChr9
!= POWERPLANT
) &&
166 (PowerWrd
= (SMapX
>>4) + (SMapY
<<3)),
168 (PowerWrd
= POWERWORD(SMapX
, SMapY
)),
170 ((PowerWrd
> PWRMAPSIZE
) ||
171 ((PowerMap
[PowerWrd
] & (1 << (SMapX
& 15))) == 0))))
185 /* comefrom: Simulate SpecialInit InitSimMemory */
189 register int ConNum
, Dir
, x
;
191 for (x
= 0; x
< PWRMAPSIZE
; x
++)
192 PowerMap
[x
] = 0; /* ClearPowerMem */
194 MaxPower
= (CoalPop
* 700L) + (NuclearPop
* 2000L); /* post release */
197 while (PowerStackNum
) {
201 if (++NumPower
> MaxPower
) {
211 SETPOWERBIT(SMapX
, SMapY
);
213 PowerMap
[(SMapX
>>4) + (SMapY
<<3)] |= 1 << (SMapX
& 15);
218 while ((Dir
< 4) && (ConNum
< 2)) {
219 if (TestForCond(Dir
)) {
232 /* comefrom: DoPowerScan DoSPZone */
235 if (PowerStackNum
< (PWRSTKSIZE
- 2)) {
237 PowerStackX
[PowerStackNum
] = SMapX
;
238 PowerStackY
[PowerStackNum
] = SMapY
;
243 /* comefrom: DoPowerScan */
246 if (PowerStackNum
> 0) {
247 SMapX
= PowerStackX
[PowerStackNum
];
248 SMapY
= PowerStackY
[PowerStackNum
];