author | KUDr |
Fri, 20 Apr 2007 19:43:06 +0000 | |
changeset 6513 | 454347ca3dfb |
parent 6505 | 8b4c20ddacd3 |
child 6530 | 06785f74984c |
permissions | -rw-r--r-- |
2186 | 1 |
/* $Id$ */ |
2 |
||
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
3 |
/** @file engine.cpp */ |
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
4 |
|
0 | 5 |
#include "stdafx.h" |
1891
862800791170
(svn r2397) - CodeChange: rename all "ttd" files to "openttd" files.
Darkvater
parents:
1883
diff
changeset
|
6 |
#include "openttd.h" |
1299
39c06aba09aa
(svn r1803) Move debugging stuff into files of it's own
tron
parents:
1197
diff
changeset
|
7 |
#include "debug.h" |
2163
b17b313113a0
(svn r2673) Include functions.h directly, not globally via openttd.h
tron
parents:
2159
diff
changeset
|
8 |
#include "functions.h" |
507
04b5403aaf6b
(svn r815) Include strings.h only in the files which need it.
tron
parents:
485
diff
changeset
|
9 |
#include "table/strings.h" |
0 | 10 |
#include "engine.h" |
1009
75140dc68759
(svn r1508) Remove duplicate declarations and include proper headers where necessary
tron
parents:
964
diff
changeset
|
11 |
#include "gfx.h" |
0 | 12 |
#include "player.h" |
13 |
#include "command.h" |
|
14 |
#include "vehicle.h" |
|
15 |
#include "news.h" |
|
16 |
#include "saveload.h" |
|
2159
f6284cf5fab0
(svn r2669) Shuffle some more stuff around to reduce dependencies
tron
parents:
2147
diff
changeset
|
17 |
#include "variables.h" |
2708
48714bad9499
(svn r3252) - NewGRF: Map new train subtypes to old types for rail vehicles.
peter1138
parents:
2639
diff
changeset
|
18 |
#include "train.h" |
5854
9eee280920f0
(svn r8428) -Codechange: Add proper names to aircraft subtypes instead of magic numbers and add a function IsNormalAircraft() which tells us whether the aircraft is in fact some flying device or a rotor/shadow.
Darkvater
parents:
5840
diff
changeset
|
19 |
#include "aircraft.h" |
3866
b13553406a0a
(svn r4902) Newgrf : Introduction of the newgrf_cargo files.
belugas
parents:
3865
diff
changeset
|
20 |
#include "newgrf_cargo.h" |
4261
28670f743746
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
rubidium
parents:
4171
diff
changeset
|
21 |
#include "date.h" |
4322
f40bbdf476b3
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
rubidium
parents:
4300
diff
changeset
|
22 |
#include "table/engines.h" |
0 | 23 |
|
2763 | 24 |
EngineInfo _engine_info[TOTAL_NUM_ENGINES]; |
25 |
RailVehicleInfo _rail_vehicle_info[NUM_TRAIN_ENGINES]; |
|
26 |
ShipVehicleInfo _ship_vehicle_info[NUM_SHIP_ENGINES]; |
|
27 |
AircraftVehicleInfo _aircraft_vehicle_info[NUM_AIRCRAFT_ENGINES]; |
|
28 |
RoadVehicleInfo _road_vehicle_info[NUM_ROAD_ENGINES]; |
|
29 |
||
0 | 30 |
enum { |
4300
c7e43c47a2b9
(svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents:
4297
diff
changeset
|
31 |
YEAR_ENGINE_AGING_STOPS = 2050, |
c7e43c47a2b9
(svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents:
4297
diff
changeset
|
32 |
}; |
c7e43c47a2b9
(svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents:
4297
diff
changeset
|
33 |
|
0 | 34 |
|
2477
225b2916fe2a
(svn r3003) Change int, uint, uin16 and byte to EngineID where appropriate, plus some related changes (mostly casts)
tron
parents:
2469
diff
changeset
|
35 |
void ShowEnginePreviewWindow(EngineID engine); |
0 | 36 |
|
6247 | 37 |
void DeleteCustomEngineNames() |
0 | 38 |
{ |
39 |
uint i; |
|
40 |
StringID old; |
|
41 |
||
1474
a26a21fa10ef
(svn r1978) - Fix: Plug some memleaks; thanks Valgrind
Darkvater
parents:
1329
diff
changeset
|
42 |
for (i = 0; i != TOTAL_NUM_ENGINES; i++) { |
0 | 43 |
old = _engine_name_strings[i]; |
44 |
_engine_name_strings[i] = i + STR_8000_KIRBY_PAUL_TANK_STEAM; |
|
45 |
DeleteName(old); |
|
46 |
} |
|
47 |
||
48 |
_vehicle_design_names &= ~1; |
|
49 |
} |
|
50 |
||
6247 | 51 |
void LoadCustomEngineNames() |
0 | 52 |
{ |
4432
372316ca7924
(svn r6195) -Codechange: do not use '//' in '/* ... */' style comments and '/*' or '*/' in '//' style comments.
rubidium
parents:
4384
diff
changeset
|
53 |
/* XXX: not done */ |
5380
8ea58542b6e0
(svn r7565) -Codechange: Rework DEBUG functionality. Look for appropiate debugging levels to
Darkvater
parents:
5216
diff
changeset
|
54 |
DEBUG(misc, 1, "LoadCustomEngineNames: not done"); |
0 | 55 |
} |
56 |
||
6247 | 57 |
static void SetupEngineNames() |
0 | 58 |
{ |
1474
a26a21fa10ef
(svn r1978) - Fix: Plug some memleaks; thanks Valgrind
Darkvater
parents:
1329
diff
changeset
|
59 |
StringID *name; |
0 | 60 |
|
1474
a26a21fa10ef
(svn r1978) - Fix: Plug some memleaks; thanks Valgrind
Darkvater
parents:
1329
diff
changeset
|
61 |
for (name = _engine_name_strings; name != endof(_engine_name_strings); name++) |
a26a21fa10ef
(svn r1978) - Fix: Plug some memleaks; thanks Valgrind
Darkvater
parents:
1329
diff
changeset
|
62 |
*name = STR_SV_EMPTY; |
0 | 63 |
|
64 |
DeleteCustomEngineNames(); |
|
65 |
LoadCustomEngineNames(); |
|
66 |
} |
|
67 |
||
68 |
||
69 |
static void CalcEngineReliability(Engine *e) |
|
70 |
{ |
|
71 |
uint age = e->age; |
|
72 |
||
73 |
if (age < e->duration_phase_1) { |
|
74 |
uint start = e->reliability_start; |
|
75 |
e->reliability = age * (e->reliability_max - start) / e->duration_phase_1 + start; |
|
4767
df84b7f59e5b
(svn r6681) -Fix: when vehicles never expire they will stay at peak reliability instead of the lowest to make them useful even when old
bjarni
parents:
4766
diff
changeset
|
76 |
} else if ((age -= e->duration_phase_1) < e->duration_phase_2 || _patches.never_expire_vehicles) { |
df84b7f59e5b
(svn r6681) -Fix: when vehicles never expire they will stay at peak reliability instead of the lowest to make them useful even when old
bjarni
parents:
4766
diff
changeset
|
77 |
/* We are at the peak of this engines life. It will have max reliability. |
df84b7f59e5b
(svn r6681) -Fix: when vehicles never expire they will stay at peak reliability instead of the lowest to make them useful even when old
bjarni
parents:
4766
diff
changeset
|
78 |
* This is also true if the engines never expire. They will not go bad over time */ |
0 | 79 |
e->reliability = e->reliability_max; |
80 |
} else if ((age -= e->duration_phase_2) < e->duration_phase_3) { |
|
81 |
uint max = e->reliability_max; |
|
82 |
e->reliability = (int)age * (int)(e->reliability_final - max) / e->duration_phase_3 + max; |
|
83 |
} else { |
|
4767
df84b7f59e5b
(svn r6681) -Fix: when vehicles never expire they will stay at peak reliability instead of the lowest to make them useful even when old
bjarni
parents:
4766
diff
changeset
|
84 |
/* time's up for this engine. |
df84b7f59e5b
(svn r6681) -Fix: when vehicles never expire they will stay at peak reliability instead of the lowest to make them useful even when old
bjarni
parents:
4766
diff
changeset
|
85 |
* We will now completely retire this design */ |
df84b7f59e5b
(svn r6681) -Fix: when vehicles never expire they will stay at peak reliability instead of the lowest to make them useful even when old
bjarni
parents:
4766
diff
changeset
|
86 |
e->player_avail = 0; |
0 | 87 |
e->reliability = e->reliability_final; |
5944
6d059cc8662b
(svn r8610) -Codechange/Feature: rewrote the list handling in the autoreplace window
bjarni
parents:
5868
diff
changeset
|
88 |
/* Kick this engine out of the lists */ |
6d059cc8662b
(svn r8610) -Codechange/Feature: rewrote the list handling in the autoreplace window
bjarni
parents:
5868
diff
changeset
|
89 |
AddRemoveEngineFromAutoreplaceAndBuildWindows(e->type); |
0 | 90 |
} |
4767
df84b7f59e5b
(svn r6681) -Fix: when vehicles never expire they will stay at peak reliability instead of the lowest to make them useful even when old
bjarni
parents:
4766
diff
changeset
|
91 |
InvalidateWindowClasses(WC_BUILD_VEHICLE); // Update to show the new reliability |
5944
6d059cc8662b
(svn r8610) -Codechange/Feature: rewrote the list handling in the autoreplace window
bjarni
parents:
5868
diff
changeset
|
92 |
InvalidateWindowClasses(WC_REPLACE_VEHICLE); |
0 | 93 |
} |
94 |
||
6247 | 95 |
void AddTypeToEngines() |
842 | 96 |
{ |
2242
512eae2cf006
(svn r2762) Simplify a loop, remove an unused variable and add many consts
tron
parents:
2204
diff
changeset
|
97 |
Engine* e = _engines; |
842 | 98 |
|
6259
471b91a4b1d8
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
rubidium
parents:
6247
diff
changeset
|
99 |
do e->type = VEH_TRAIN; while (++e < &_engines[ROAD_ENGINES_INDEX]); |
471b91a4b1d8
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
rubidium
parents:
6247
diff
changeset
|
100 |
do e->type = VEH_ROAD; while (++e < &_engines[SHIP_ENGINES_INDEX]); |
471b91a4b1d8
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
rubidium
parents:
6247
diff
changeset
|
101 |
do e->type = VEH_SHIP; while (++e < &_engines[AIRCRAFT_ENGINES_INDEX]); |
471b91a4b1d8
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
rubidium
parents:
6247
diff
changeset
|
102 |
do e->type = VEH_AIRCRAFT; while (++e < &_engines[TOTAL_NUM_ENGINES]); |
842 | 103 |
} |
104 |
||
6247 | 105 |
void StartupEngines() |
0 | 106 |
{ |
107 |
Engine *e; |
|
108 |
const EngineInfo *ei; |
|
4300
c7e43c47a2b9
(svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents:
4297
diff
changeset
|
109 |
/* Aging of vehicles stops, so account for that when starting late */ |
4322
f40bbdf476b3
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
rubidium
parents:
4300
diff
changeset
|
110 |
const Date aging_date = min(_date, ConvertYMDToDate(YEAR_ENGINE_AGING_STOPS, 0, 1)); |
0 | 111 |
|
112 |
SetupEngineNames(); |
|
113 |
||
2242
512eae2cf006
(svn r2762) Simplify a loop, remove an unused variable and add many consts
tron
parents:
2204
diff
changeset
|
114 |
for (e = _engines, ei = _engine_info; e != endof(_engines); e++, ei++) { |
512eae2cf006
(svn r2762) Simplify a loop, remove an unused variable and add many consts
tron
parents:
2204
diff
changeset
|
115 |
uint32 r; |
0 | 116 |
|
117 |
e->age = 0; |
|
118 |
e->flags = 0; |
|
119 |
e->player_avail = 0; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
114
diff
changeset
|
120 |
|
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
121 |
/* The magic value of 729 days below comes from the NewGRF spec. If the |
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
122 |
* base intro date is before 1922 then the random number of days is not |
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
123 |
* added. */ |
0 | 124 |
r = Random(); |
4297
d0311b62255c
(svn r5934) -Cleanup: forgot some conversions to Year and to Date
rubidium
parents:
4293
diff
changeset
|
125 |
e->intro_date = ei->base_intro <= ConvertYMDToDate(1922, 0, 1) ? ei->base_intro : (Date)GB(r, 0, 9) + ei->base_intro; |
0 | 126 |
if (e->intro_date <= _date) { |
4300
c7e43c47a2b9
(svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents:
4297
diff
changeset
|
127 |
e->age = (aging_date - e->intro_date) >> 5; |
0 | 128 |
e->player_avail = (byte)-1; |
129 |
e->flags |= ENGINE_AVAILABLE; |
|
130 |
} |
|
131 |
||
2140
a04d0142ad65
(svn r2650) Convert many explicit shifts+ands to extract bits to invocations of GB - should be a bit nicer to read
tron
parents:
1988
diff
changeset
|
132 |
e->reliability_start = GB(r, 16, 14) + 0x7AE0; |
0 | 133 |
r = Random(); |
2140
a04d0142ad65
(svn r2650) Convert many explicit shifts+ands to extract bits to invocations of GB - should be a bit nicer to read
tron
parents:
1988
diff
changeset
|
134 |
e->reliability_max = GB(r, 0, 14) + 0xBFFF; |
a04d0142ad65
(svn r2650) Convert many explicit shifts+ands to extract bits to invocations of GB - should be a bit nicer to read
tron
parents:
1988
diff
changeset
|
135 |
e->reliability_final = GB(r, 16, 14) + 0x3FFF; |
0 | 136 |
|
137 |
r = Random(); |
|
2140
a04d0142ad65
(svn r2650) Convert many explicit shifts+ands to extract bits to invocations of GB - should be a bit nicer to read
tron
parents:
1988
diff
changeset
|
138 |
e->duration_phase_1 = GB(r, 0, 5) + 7; |
a04d0142ad65
(svn r2650) Convert many explicit shifts+ands to extract bits to invocations of GB - should be a bit nicer to read
tron
parents:
1988
diff
changeset
|
139 |
e->duration_phase_2 = GB(r, 5, 4) + ei->base_life * 12 - 96; |
a04d0142ad65
(svn r2650) Convert many explicit shifts+ands to extract bits to invocations of GB - should be a bit nicer to read
tron
parents:
1988
diff
changeset
|
140 |
e->duration_phase_3 = GB(r, 9, 7) + 120; |
0 | 141 |
|
142 |
e->reliability_spd_dec = (ei->unk2&0x7F) << 2; |
|
143 |
||
144 |
/* my invented flag for something that is a wagon */ |
|
145 |
if (ei->unk2 & 0x80) { |
|
146 |
e->age = 0xFFFF; |
|
147 |
} else { |
|
148 |
CalcEngineReliability(e); |
|
149 |
} |
|
150 |
||
151 |
e->lifelength = ei->lifelength + _patches.extend_vehicle_life; |
|
152 |
||
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
153 |
/* prevent certain engines from ever appearing. */ |
2530
df14798edc40
(svn r3059) Use bitfields to encode railtype and climates of engines instead of manual shifting/anding
tron
parents:
2491
diff
changeset
|
154 |
if (!HASBIT(ei->climates, _opt.landscape)) { |
0 | 155 |
e->flags |= ENGINE_AVAILABLE; |
156 |
e->player_avail = 0; |
|
157 |
} |
|
915 | 158 |
|
819
c425b7e22f6a
(svn r1290) Added type to typedef struct Engine and filled in the same data as in type in vehicle
bjarni
parents:
740
diff
changeset
|
159 |
/* This sets up type for the engine |
4549
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4432
diff
changeset
|
160 |
* It is needed if you want to ask the engine what type it is |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4432
diff
changeset
|
161 |
* It should hopefully be the same as when you ask a vehicle what it is |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4432
diff
changeset
|
162 |
* but using this, you can ask what type an engine number is |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4432
diff
changeset
|
163 |
* even if it is not a vehicle (yet)*/ |
0 | 164 |
} |
165 |
} |
|
166 |
||
5823 | 167 |
static void AcceptEnginePreview(EngineID eid, PlayerID player) |
0 | 168 |
{ |
5823 | 169 |
Engine *e = GetEngine(eid); |
0 | 170 |
|
171 |
SETBIT(e->player_avail, player); |
|
6259
471b91a4b1d8
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
rubidium
parents:
6247
diff
changeset
|
172 |
if (e->type == VEH_TRAIN) { |
5823 | 173 |
const RailVehicleInfo *rvi = RailVehInfo(eid); |
174 |
Player *p = GetPlayer(player); |
|
175 |
||
176 |
assert(rvi->railtype < RAILTYPE_END); |
|
177 |
SETBIT(p->avail_railtypes, rvi->railtype); |
|
178 |
} |
|
0 | 179 |
|
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
180 |
e->preview_player = INVALID_PLAYER; |
4766
aa276d0ec2eb
(svn r6680) -Codechange r6679: [train build window] only generate the list when the window data is invalidated or the window is generated, not on each redraw
bjarni
parents:
4549
diff
changeset
|
181 |
if (player == _local_player) { |
5944
6d059cc8662b
(svn r8610) -Codechange/Feature: rewrote the list handling in the autoreplace window
bjarni
parents:
5868
diff
changeset
|
182 |
AddRemoveEngineFromAutoreplaceAndBuildWindows(e->type); |
4766
aa276d0ec2eb
(svn r6680) -Codechange r6679: [train build window] only generate the list when the window data is invalidated or the window is generated, not on each redraw
bjarni
parents:
4549
diff
changeset
|
183 |
} |
0 | 184 |
} |
185 |
||
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
186 |
static PlayerID GetBestPlayer(PlayerID pp) |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
187 |
{ |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
188 |
const Player *p; |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
189 |
int32 best_hist; |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
190 |
PlayerID best_player; |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
191 |
uint mask = 0; |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
192 |
|
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
193 |
do { |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
194 |
best_hist = -1; |
4848
45f848b46222
(svn r6774) -Codechange: Rename the badly named OWNER_SPECTATOR to PLAYER_SPECTATOR and
Darkvater
parents:
4845
diff
changeset
|
195 |
best_player = PLAYER_SPECTATOR; |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
196 |
FOR_ALL_PLAYERS(p) { |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
197 |
if (p->is_active && p->block_preview == 0 && !HASBIT(mask, p->index) && |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
198 |
p->old_economy[0].performance_history > best_hist) { |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
199 |
best_hist = p->old_economy[0].performance_history; |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
200 |
best_player = p->index; |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
201 |
} |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
202 |
} |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
203 |
|
4848
45f848b46222
(svn r6774) -Codechange: Rename the badly named OWNER_SPECTATOR to PLAYER_SPECTATOR and
Darkvater
parents:
4845
diff
changeset
|
204 |
if (best_player == PLAYER_SPECTATOR) return PLAYER_SPECTATOR; |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
205 |
|
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
206 |
SETBIT(mask, best_player); |
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
207 |
} while (pp--, pp != 0); |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
208 |
|
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
209 |
return best_player; |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
210 |
} |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
211 |
|
6247 | 212 |
void EnginesDailyLoop() |
0 | 213 |
{ |
2477
225b2916fe2a
(svn r3003) Change int, uint, uin16 and byte to EngineID where appropriate, plus some related changes (mostly casts)
tron
parents:
2469
diff
changeset
|
214 |
EngineID i; |
0 | 215 |
|
4300
c7e43c47a2b9
(svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents:
4297
diff
changeset
|
216 |
if (_cur_year >= YEAR_ENGINE_AGING_STOPS) return; |
0 | 217 |
|
2242
512eae2cf006
(svn r2762) Simplify a loop, remove an unused variable and add many consts
tron
parents:
2204
diff
changeset
|
218 |
for (i = 0; i != lengthof(_engines); i++) { |
4171 | 219 |
Engine *e = &_engines[i]; |
2242
512eae2cf006
(svn r2762) Simplify a loop, remove an unused variable and add many consts
tron
parents:
2204
diff
changeset
|
220 |
|
6174
0c743995213f
(svn r8944) -Codechange: Move the enum describing the bitmask of Engine.flags to engine.h and give the enum values better names.
maedhros
parents:
6125
diff
changeset
|
221 |
if (e->flags & ENGINE_EXCLUSIVE_PREVIEW) { |
0c743995213f
(svn r8944) -Codechange: Move the enum describing the bitmask of Engine.flags to engine.h and give the enum values better names.
maedhros
parents:
6125
diff
changeset
|
222 |
if (e->flags & ENGINE_OFFER_WINDOW_OPEN) { |
740
ab84ecdf86a2
(svn r1196) -Fix: Preview Vehicle had a small glitch. Fixed now.
truelight
parents:
555
diff
changeset
|
223 |
if (e->preview_player != 0xFF && !--e->preview_wait) { |
6174
0c743995213f
(svn r8944) -Codechange: Move the enum describing the bitmask of Engine.flags to engine.h and give the enum values better names.
maedhros
parents:
6125
diff
changeset
|
224 |
e->flags &= ~ENGINE_OFFER_WINDOW_OPEN; |
0 | 225 |
DeleteWindowById(WC_ENGINE_PREVIEW, i); |
226 |
e->preview_player++; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
114
diff
changeset
|
227 |
} |
4077
d4d440dd8925
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
tron
parents:
3866
diff
changeset
|
228 |
} else if (e->preview_player != 0xFF) { |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
229 |
PlayerID best_player = GetBestPlayer(e->preview_player); |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
230 |
|
4848
45f848b46222
(svn r6774) -Codechange: Rename the badly named OWNER_SPECTATOR to PLAYER_SPECTATOR and
Darkvater
parents:
4845
diff
changeset
|
231 |
if (best_player == PLAYER_SPECTATOR) { |
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
232 |
e->preview_player = INVALID_PLAYER; |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
233 |
continue; |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
234 |
} |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
114
diff
changeset
|
235 |
|
4845
72bbb6e2694e
(svn r6771) -Codechange: Replace two macros with functions. IS_HUMAN_PLAYER and
Darkvater
parents:
4792
diff
changeset
|
236 |
if (!IsHumanPlayer(best_player)) { |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
237 |
/* XXX - TTDBUG: TTD has a bug here ???? */ |
5823 | 238 |
AcceptEnginePreview(i, best_player); |
0 | 239 |
} else { |
6174
0c743995213f
(svn r8944) -Codechange: Move the enum describing the bitmask of Engine.flags to engine.h and give the enum values better names.
maedhros
parents:
6125
diff
changeset
|
240 |
e->flags |= ENGINE_OFFER_WINDOW_OPEN; |
0 | 241 |
e->preview_wait = 20; |
4845
72bbb6e2694e
(svn r6771) -Codechange: Replace two macros with functions. IS_HUMAN_PLAYER and
Darkvater
parents:
4792
diff
changeset
|
242 |
if (IsInteractivePlayer(best_player)) ShowEnginePreviewWindow(i); |
0 | 243 |
} |
244 |
} |
|
245 |
} |
|
246 |
} |
|
247 |
} |
|
248 |
||
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
249 |
/** Accept an engine prototype. XXX - it is possible that the top-player |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
250 |
* changes while you are waiting to accept the offer? Then it becomes invalid |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3222
diff
changeset
|
251 |
* @param tile unused |
6481
85ad87daf4b0
(svn r9662) -Documentation: Doxygen corrections and @file omissions
belugas
parents:
6259
diff
changeset
|
252 |
* @param flags operation to perfom |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
253 |
* @param p1 engine-prototype offered |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
254 |
* @param p2 unused |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
255 |
*/ |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3222
diff
changeset
|
256 |
int32 CmdWantEnginePreview(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) |
0 | 257 |
{ |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
258 |
Engine *e; |
2951 | 259 |
|
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
260 |
if (!IsEngineIndex(p1)) return CMD_ERROR; |
1926
530480d14685
(svn r2432) Use GetEngine() instead of DEREF_ENGINE() or even _engines[]
tron
parents:
1908
diff
changeset
|
261 |
e = GetEngine(p1); |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
262 |
if (GetBestPlayer(e->preview_player) != _current_player) return CMD_ERROR; |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
263 |
|
5823 | 264 |
if (flags & DC_EXEC) AcceptEnginePreview(p1, _current_player); |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
265 |
|
0 | 266 |
return 0; |
267 |
} |
|
268 |
||
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
269 |
/* Determine if an engine type is a wagon (and not a loco) */ |
2477
225b2916fe2a
(svn r3003) Change int, uint, uin16 and byte to EngineID where appropriate, plus some related changes (mostly casts)
tron
parents:
2469
diff
changeset
|
270 |
static bool IsWagon(EngineID index) |
257
0ff8a2e60a0d
(svn r262) Fix: [ 1028234 ] Monorail and MagLev infrastructure not available in 1920s any more
dominik
parents:
220
diff
changeset
|
271 |
{ |
5868
94430141c189
(svn r8455) -Codechange: Give a more meaningful name (railveh_type)to member flags of RailVehInfo, as well as changing the code to reflect the fact that it was not a flag but rather a one value only variable. Doing so, some evaluations have been simplified.
belugas
parents:
5854
diff
changeset
|
272 |
return index < NUM_TRAIN_ENGINES && RailVehInfo(index)->railveh_type == RAILVEH_WAGON; |
257
0ff8a2e60a0d
(svn r262) Fix: [ 1028234 ] Monorail and MagLev infrastructure not available in 1920s any more
dominik
parents:
220
diff
changeset
|
273 |
} |
0ff8a2e60a0d
(svn r262) Fix: [ 1028234 ] Monorail and MagLev infrastructure not available in 1920s any more
dominik
parents:
220
diff
changeset
|
274 |
|
410 | 275 |
static void NewVehicleAvailable(Engine *e) |
0 | 276 |
{ |
277 |
Vehicle *v; |
|
278 |
Player *p; |
|
2477
225b2916fe2a
(svn r3003) Change int, uint, uin16 and byte to EngineID where appropriate, plus some related changes (mostly casts)
tron
parents:
2469
diff
changeset
|
279 |
EngineID index = e - _engines; |
0 | 280 |
|
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
281 |
/* In case the player didn't build the vehicle during the intro period, |
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
282 |
* prevent that player from getting future intro periods for a while. */ |
6174
0c743995213f
(svn r8944) -Codechange: Move the enum describing the bitmask of Engine.flags to engine.h and give the enum values better names.
maedhros
parents:
6125
diff
changeset
|
283 |
if (e->flags & ENGINE_EXCLUSIVE_PREVIEW) { |
0 | 284 |
FOR_ALL_PLAYERS(p) { |
919
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
915
diff
changeset
|
285 |
uint block_preview = p->block_preview; |
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
915
diff
changeset
|
286 |
|
2639 | 287 |
if (!HASBIT(e->player_avail, p->index)) continue; |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
114
diff
changeset
|
288 |
|
919
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
915
diff
changeset
|
289 |
/* We assume the user did NOT build it.. prove me wrong ;) */ |
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
915
diff
changeset
|
290 |
p->block_preview = 20; |
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
915
diff
changeset
|
291 |
|
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
915
diff
changeset
|
292 |
FOR_ALL_VEHICLES(v) { |
6259
471b91a4b1d8
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
rubidium
parents:
6247
diff
changeset
|
293 |
if (v->type == VEH_TRAIN || v->type == VEH_ROAD || v->type == VEH_SHIP || |
471b91a4b1d8
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
rubidium
parents:
6247
diff
changeset
|
294 |
(v->type == VEH_AIRCRAFT && IsNormalAircraft(v))) { |
919
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
915
diff
changeset
|
295 |
if (v->owner == p->index && v->engine_type == index) { |
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
915
diff
changeset
|
296 |
/* The user did prove me wrong, so restore old value */ |
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
915
diff
changeset
|
297 |
p->block_preview = block_preview; |
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
915
diff
changeset
|
298 |
break; |
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
915
diff
changeset
|
299 |
} |
0 | 300 |
} |
301 |
} |
|
302 |
} |
|
303 |
} |
|
304 |
||
6174
0c743995213f
(svn r8944) -Codechange: Move the enum describing the bitmask of Engine.flags to engine.h and give the enum values better names.
maedhros
parents:
6125
diff
changeset
|
305 |
e->flags = (e->flags & ~ENGINE_EXCLUSIVE_PREVIEW) | ENGINE_AVAILABLE; |
5944
6d059cc8662b
(svn r8610) -Codechange/Feature: rewrote the list handling in the autoreplace window
bjarni
parents:
5868
diff
changeset
|
306 |
AddRemoveEngineFromAutoreplaceAndBuildWindows(e->type); |
114
6a2af0c2d0db
(svn r115) Fix: monorail/maglev became available around 1927
dominik
parents:
0
diff
changeset
|
307 |
|
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
308 |
/* Now available for all players */ |
0 | 309 |
e->player_avail = (byte)-1; |
114
6a2af0c2d0db
(svn r115) Fix: monorail/maglev became available around 1927
dominik
parents:
0
diff
changeset
|
310 |
|
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
311 |
/* Do not introduce new rail wagons */ |
2639 | 312 |
if (IsWagon(index)) return; |
114
6a2af0c2d0db
(svn r115) Fix: monorail/maglev became available around 1927
dominik
parents:
0
diff
changeset
|
313 |
|
5823 | 314 |
if (index < NUM_TRAIN_ENGINES) { |
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
315 |
/* maybe make another rail type available */ |
5823 | 316 |
RailType railtype = RailVehInfo(index)->railtype; |
317 |
assert(railtype < RAILTYPE_END); |
|
318 |
FOR_ALL_PLAYERS(p) { |
|
319 |
if (p->is_active) SETBIT(p->avail_railtypes, railtype); |
|
2147
eb6ba42fd216
(svn r2657) -Codechange: The available railtypes per player are now a bitmask, so
celestar
parents:
2140
diff
changeset
|
320 |
} |
0 | 321 |
} |
6209
3a1a90cd67f3
(svn r9001) -Codechange: remove duplication of functions and strings with respect to the news of new vehicles.
rubidium
parents:
6174
diff
changeset
|
322 |
AddNewsItem(index, NEWS_FLAGS(NM_CALLBACK, 0, NT_NEW_VEHICLES, DNC_VEHICLEAVAIL), 0, 0); |
0 | 323 |
} |
324 |
||
6247 | 325 |
void EnginesMonthlyLoop() |
0 | 326 |
{ |
327 |
Engine *e; |
|
328 |
||
4300
c7e43c47a2b9
(svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents:
4297
diff
changeset
|
329 |
if (_cur_year < YEAR_ENGINE_AGING_STOPS) { |
2242
512eae2cf006
(svn r2762) Simplify a loop, remove an unused variable and add many consts
tron
parents:
2204
diff
changeset
|
330 |
for (e = _engines; e != endof(_engines); e++) { |
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
331 |
/* Age the vehicle */ |
2242
512eae2cf006
(svn r2762) Simplify a loop, remove an unused variable and add many consts
tron
parents:
2204
diff
changeset
|
332 |
if (e->flags & ENGINE_AVAILABLE && e->age != 0xFFFF) { |
0 | 333 |
e->age++; |
334 |
CalcEngineReliability(e); |
|
335 |
} |
|
336 |
||
2990
2bbe7769ebd4
(svn r3565) - Fix: On loading a game, GetPlayerRailtypes() didn't account for the fact that vehicles are introduced a year after their introduction date. This will also relieve possible (rare) network desyncs.
peter1138
parents:
2962
diff
changeset
|
337 |
if (!(e->flags & ENGINE_AVAILABLE) && _date >= (e->intro_date + 365)) { |
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
338 |
/* Introduce it to all players */ |
0 | 339 |
NewVehicleAvailable(e); |
6174
0c743995213f
(svn r8944) -Codechange: Move the enum describing the bitmask of Engine.flags to engine.h and give the enum values better names.
maedhros
parents:
6125
diff
changeset
|
340 |
} else if (!(e->flags & (ENGINE_AVAILABLE|ENGINE_EXCLUSIVE_PREVIEW)) && _date >= e->intro_date) { |
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
341 |
/* Introduction date has passed.. show introducing dialog to one player. */ |
6174
0c743995213f
(svn r8944) -Codechange: Move the enum describing the bitmask of Engine.flags to engine.h and give the enum values better names.
maedhros
parents:
6125
diff
changeset
|
342 |
e->flags |= ENGINE_EXCLUSIVE_PREVIEW; |
257
0ff8a2e60a0d
(svn r262) Fix: [ 1028234 ] Monorail and MagLev infrastructure not available in 1920s any more
dominik
parents:
220
diff
changeset
|
343 |
|
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
344 |
/* Do not introduce new rail wagons */ |
964
fe9e7b220b9f
(svn r1456) Simplify isWagon(), make it static and give it a canonical name (IsWagon)
tron
parents:
938
diff
changeset
|
345 |
if (!IsWagon(e - _engines)) |
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
346 |
e->preview_player = (PlayerID)1; // Give to the player with the highest rating. |
0 | 347 |
} |
348 |
} |
|
349 |
} |
|
350 |
} |
|
351 |
||
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
352 |
/** Rename an engine. |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3222
diff
changeset
|
353 |
* @param tile unused |
6481
85ad87daf4b0
(svn r9662) -Documentation: Doxygen corrections and @file omissions
belugas
parents:
6259
diff
changeset
|
354 |
* @param flags operation to perfom |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
355 |
* @param p1 engine ID to rename |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
356 |
* @param p2 unused |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
357 |
*/ |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3222
diff
changeset
|
358 |
int32 CmdRenameEngine(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) |
0 | 359 |
{ |
360 |
StringID str; |
|
361 |
||
1840
ce40137a6ab4
(svn r2345) - Fix: Don't allow stuff to be renamed to nothing if we don't support it. Only valid ones are signs (delete) and waypoints (rename to default).
Darkvater
parents:
1820
diff
changeset
|
362 |
if (!IsEngineIndex(p1) || _cmd_text[0] == '\0') return CMD_ERROR; |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
363 |
|
1820
d03c56850dc2
(svn r2324) Introduce _cmd_text for passing strings with a command instead of abusing _decode_parameters as text buffer. This should prevent several possible buffer overruns and is a bit cleaner to use. As bonus it reduces the size of most command packets by 79 bytes.
tron
parents:
1802
diff
changeset
|
364 |
str = AllocateNameUnique(_cmd_text, 0); |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1560
diff
changeset
|
365 |
if (str == 0) return CMD_ERROR; |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
114
diff
changeset
|
366 |
|
0 | 367 |
if (flags & DC_EXEC) { |
368 |
StringID old_str = _engine_name_strings[p1]; |
|
369 |
_engine_name_strings[p1] = str; |
|
370 |
DeleteName(old_str); |
|
371 |
_vehicle_design_names |= 3; |
|
372 |
MarkWholeScreenDirty(); |
|
373 |
} else { |
|
374 |
DeleteName(str); |
|
375 |
} |
|
376 |
||
377 |
return 0; |
|
378 |
} |
|
379 |
||
380 |
||
2848 | 381 |
/* |
382 |
* returns true if an engine is valid, of the specified type, and buildable by |
|
5215
b8fb685df4c5
(svn r7330) -Fix (r7304): Data invalidation doesn't always happen as the local
peter1138
parents:
5037
diff
changeset
|
383 |
* the given player, false otherwise |
2848 | 384 |
* |
385 |
* engine = index of the engine to check |
|
386 |
* type = the type the engine should be of (VEH_xxx) |
|
5215
b8fb685df4c5
(svn r7330) -Fix (r7304): Data invalidation doesn't always happen as the local
peter1138
parents:
5037
diff
changeset
|
387 |
* player = index of the player |
2848 | 388 |
*/ |
5215
b8fb685df4c5
(svn r7330) -Fix (r7304): Data invalidation doesn't always happen as the local
peter1138
parents:
5037
diff
changeset
|
389 |
bool IsEngineBuildable(EngineID engine, byte type, PlayerID player) |
2848 | 390 |
{ |
391 |
const Engine *e; |
|
392 |
||
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
393 |
/* check if it's an engine that is in the engine array */ |
2848 | 394 |
if (!IsEngineIndex(engine)) return false; |
395 |
||
396 |
e = GetEngine(engine); |
|
397 |
||
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
398 |
/* check if it's an engine of specified type */ |
2848 | 399 |
if (e->type != type) return false; |
400 |
||
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
401 |
/* check if it's available */ |
5215
b8fb685df4c5
(svn r7330) -Fix (r7304): Data invalidation doesn't always happen as the local
peter1138
parents:
5037
diff
changeset
|
402 |
if (!HASBIT(e->player_avail, player)) return false; |
2848 | 403 |
|
404 |
return true; |
|
405 |
} |
|
406 |
||
6505
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
407 |
/** Get the default cargo type for a certain engine type |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
408 |
* @param engine The ID to get the cargo for |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
409 |
* @return The cargo type. CT_INVALID means no cargo capacity |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
410 |
*/ |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
411 |
CargoID GetEngineCargoType(EngineID engine) |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
412 |
{ |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
413 |
assert(IsEngineIndex(engine)); |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
414 |
|
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
415 |
switch (GetEngine(engine)->type) { |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
416 |
case VEH_TRAIN: |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
417 |
if (RailVehInfo(engine)->capacity == 0) return CT_INVALID; |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
418 |
return RailVehInfo(engine)->cargo_type; |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
419 |
|
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
420 |
case VEH_ROAD: |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
421 |
if (RoadVehInfo(engine)->capacity == 0) return CT_INVALID; |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
422 |
return RoadVehInfo(engine)->cargo_type; |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
423 |
|
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
424 |
case VEH_SHIP: |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
425 |
if (ShipVehInfo(engine)->capacity == 0) return CT_INVALID; |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
426 |
return ShipVehInfo(engine)->cargo_type; |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
427 |
|
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
428 |
case VEH_AIRCRAFT: |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
429 |
/* all aircraft starts as passenger planes with cargo capacity */ |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
430 |
return CT_PASSENGERS; |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
431 |
|
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
432 |
default: NOT_REACHED(); return CT_INVALID; |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
433 |
} |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
434 |
} |
8b4c20ddacd3
(svn r9688) -Codechange: Created a function to get default cargo type for a cargo type
bjarni
parents:
6481
diff
changeset
|
435 |
|
2848 | 436 |
/************************************************************************ |
437 |
* Engine Replacement stuff |
|
438 |
************************************************************************/ |
|
439 |
||
4974
2b7c9ba5604c
(svn r6977) Use the pool macros for the EngineRenew pool
tron
parents:
4848
diff
changeset
|
440 |
static void EngineRenewPoolNewBlock(uint start_item); |
2848 | 441 |
|
5216
8bd14ee39af2
(svn r7331) - Codechange: Rename all memory pool macro's and types to "old pool", so the new pool implementation can be committed alongside it.
matthijs
parents:
5215
diff
changeset
|
442 |
DEFINE_OLD_POOL(EngineRenew, EngineRenew, EngineRenewPoolNewBlock, NULL) |
2848 | 443 |
|
444 |
static void EngineRenewPoolNewBlock(uint start_item) |
|
445 |
{ |
|
446 |
EngineRenew *er; |
|
447 |
||
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
448 |
/* We don't use FOR_ALL here, because FOR_ALL skips invalid items. |
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
449 |
* TODO - This is just a temporary stage, this will be removed. */ |
4974
2b7c9ba5604c
(svn r6977) Use the pool macros for the EngineRenew pool
tron
parents:
4848
diff
changeset
|
450 |
for (er = GetEngineRenew(start_item); er != NULL; er = (er->index + 1U < GetEngineRenewPoolSize()) ? GetEngineRenew(er->index + 1U) : NULL) { |
2848 | 451 |
er->index = start_item++; |
452 |
er->from = INVALID_ENGINE; |
|
453 |
} |
|
454 |
} |
|
455 |
||
456 |
||
6247 | 457 |
static EngineRenew *AllocateEngineRenew() |
2848 | 458 |
{ |
459 |
EngineRenew *er; |
|
460 |
||
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
461 |
/* We don't use FOR_ALL here, because FOR_ALL skips invalid items. |
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
462 |
* TODO - This is just a temporary stage, this will be removed. */ |
4974
2b7c9ba5604c
(svn r6977) Use the pool macros for the EngineRenew pool
tron
parents:
4848
diff
changeset
|
463 |
for (er = GetEngineRenew(0); er != NULL; er = (er->index + 1U < GetEngineRenewPoolSize()) ? GetEngineRenew(er->index + 1U) : NULL) { |
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
464 |
if (IsValidEngineRenew(er)) continue; |
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
465 |
|
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
466 |
er->to = INVALID_ENGINE; |
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
467 |
er->next = NULL; |
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
468 |
return er; |
2848 | 469 |
} |
470 |
||
471 |
/* Check if we can add a block to the pool */ |
|
4974
2b7c9ba5604c
(svn r6977) Use the pool macros for the EngineRenew pool
tron
parents:
4848
diff
changeset
|
472 |
if (AddBlockToPool(&_EngineRenew_pool)) return AllocateEngineRenew(); |
2848 | 473 |
|
474 |
return NULL; |
|
475 |
} |
|
476 |
||
477 |
/** |
|
478 |
* Retrieves the EngineRenew that specifies the replacement of the given |
|
479 |
* engine type from the given renewlist */ |
|
480 |
static EngineRenew *GetEngineReplacement(EngineRenewList erl, EngineID engine) |
|
481 |
{ |
|
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
482 |
EngineRenew *er = (EngineRenew *)erl; |
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
483 |
|
2848 | 484 |
while (er) { |
485 |
if (er->from == engine) return er; |
|
486 |
er = er->next; |
|
487 |
} |
|
488 |
return NULL; |
|
489 |
} |
|
490 |
||
4171 | 491 |
void RemoveAllEngineReplacement(EngineRenewList *erl) |
2848 | 492 |
{ |
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
493 |
EngineRenew *er = (EngineRenew *)(*erl); |
4384
7e0d3ed719d9
(svn r6137) -Codechange: some very minor cleanups:
truelight
parents:
4358
diff
changeset
|
494 |
EngineRenew *next; |
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
495 |
|
2848 | 496 |
while (er) { |
4384
7e0d3ed719d9
(svn r6137) -Codechange: some very minor cleanups:
truelight
parents:
4358
diff
changeset
|
497 |
next = er->next; |
7e0d3ed719d9
(svn r6137) -Codechange: some very minor cleanups:
truelight
parents:
4358
diff
changeset
|
498 |
DeleteEngineRenew(er); |
7e0d3ed719d9
(svn r6137) -Codechange: some very minor cleanups:
truelight
parents:
4358
diff
changeset
|
499 |
er = next; |
2848 | 500 |
} |
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
501 |
*erl = NULL; // Empty list |
2848 | 502 |
} |
503 |
||
504 |
EngineID EngineReplacement(EngineRenewList erl, EngineID engine) |
|
505 |
{ |
|
506 |
const EngineRenew *er = GetEngineReplacement(erl, engine); |
|
507 |
return er == NULL ? INVALID_ENGINE : er->to; |
|
508 |
} |
|
509 |
||
4171 | 510 |
int32 AddEngineReplacement(EngineRenewList *erl, EngineID old_engine, EngineID new_engine, uint32 flags) |
2848 | 511 |
{ |
512 |
EngineRenew *er; |
|
513 |
||
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
514 |
/* Check if the old vehicle is already in the list */ |
2848 | 515 |
er = GetEngineReplacement(*erl, old_engine); |
516 |
if (er != NULL) { |
|
517 |
if (flags & DC_EXEC) er->to = new_engine; |
|
518 |
return 0; |
|
519 |
} |
|
520 |
||
521 |
er = AllocateEngineRenew(); |
|
522 |
if (er == NULL) return CMD_ERROR; |
|
523 |
||
524 |
if (flags & DC_EXEC) { |
|
525 |
er->from = old_engine; |
|
526 |
er->to = new_engine; |
|
527 |
||
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
528 |
/* Insert before the first element */ |
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
529 |
er->next = (EngineRenew *)(*erl); |
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
530 |
*erl = (EngineRenewList)er; |
2848 | 531 |
} |
532 |
||
533 |
return 0; |
|
534 |
} |
|
535 |
||
4171 | 536 |
int32 RemoveEngineReplacement(EngineRenewList *erl, EngineID engine, uint32 flags) |
2848 | 537 |
{ |
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
538 |
EngineRenew *er = (EngineRenew *)(*erl); |
4171 | 539 |
EngineRenew *prev = NULL; |
2848 | 540 |
|
541 |
while (er) |
|
542 |
{ |
|
543 |
if (er->from == engine) { |
|
544 |
if (flags & DC_EXEC) { |
|
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
545 |
if (prev == NULL) { // First element |
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
546 |
/* The second becomes the new first element */ |
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
547 |
*erl = (EngineRenewList)er->next; |
2848 | 548 |
} else { |
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
549 |
/* Cut this element out */ |
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
550 |
prev->next = er->next; |
2848 | 551 |
} |
4384
7e0d3ed719d9
(svn r6137) -Codechange: some very minor cleanups:
truelight
parents:
4358
diff
changeset
|
552 |
DeleteEngineRenew(er); |
2848 | 553 |
} |
554 |
return 0; |
|
555 |
} |
|
556 |
prev = er; |
|
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
557 |
er = er->next; |
2848 | 558 |
} |
559 |
||
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
560 |
return CMD_ERROR; |
2848 | 561 |
} |
562 |
||
563 |
static const SaveLoad _engine_renew_desc[] = { |
|
564 |
SLE_VAR(EngineRenew, from, SLE_UINT16), |
|
565 |
SLE_VAR(EngineRenew, to, SLE_UINT16), |
|
566 |
||
567 |
SLE_REF(EngineRenew, next, REF_ENGINE_RENEWS), |
|
568 |
||
569 |
SLE_END() |
|
570 |
}; |
|
571 |
||
6247 | 572 |
static void Save_ERNW() |
2848 | 573 |
{ |
574 |
EngineRenew *er; |
|
575 |
||
576 |
FOR_ALL_ENGINE_RENEWS(er) { |
|
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
577 |
SlSetArrayIndex(er->index); |
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
578 |
SlObject(er, _engine_renew_desc); |
2848 | 579 |
} |
580 |
} |
|
581 |
||
6247 | 582 |
static void Load_ERNW() |
2848 | 583 |
{ |
584 |
int index; |
|
585 |
||
586 |
while ((index = SlIterateArray()) != -1) { |
|
587 |
EngineRenew *er; |
|
588 |
||
4974
2b7c9ba5604c
(svn r6977) Use the pool macros for the EngineRenew pool
tron
parents:
4848
diff
changeset
|
589 |
if (!AddBlockIfNeeded(&_EngineRenew_pool, index)) |
2848 | 590 |
error("EngineRenews: failed loading savegame: too many EngineRenews"); |
591 |
||
592 |
er = GetEngineRenew(index); |
|
593 |
SlObject(er, _engine_renew_desc); |
|
594 |
} |
|
595 |
} |
|
596 |
||
1881
435d39bd6ee0
(svn r2387) - CodeChange: made the saveload code more readable and also removed the 'byte' saveload arrays which means you can save an array of more than 255 elements, or bigger structs than 255 bytes. This doesn't yet solve the problem that a chunk can be a maximum of 16384 big.
Darkvater
parents:
1855
diff
changeset
|
597 |
static const SaveLoad _engine_desc[] = { |
4344
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
598 |
SLE_CONDVAR(Engine, intro_date, SLE_FILE_U16 | SLE_VAR_I32, 0, 30), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
599 |
SLE_CONDVAR(Engine, intro_date, SLE_INT32, 31, SL_MAX_VERSION), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
600 |
SLE_CONDVAR(Engine, age, SLE_FILE_U16 | SLE_VAR_I32, 0, 30), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
601 |
SLE_CONDVAR(Engine, age, SLE_INT32, 31, SL_MAX_VERSION), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
602 |
SLE_VAR(Engine, reliability, SLE_UINT16), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
603 |
SLE_VAR(Engine, reliability_spd_dec, SLE_UINT16), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
604 |
SLE_VAR(Engine, reliability_start, SLE_UINT16), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
605 |
SLE_VAR(Engine, reliability_max, SLE_UINT16), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
606 |
SLE_VAR(Engine, reliability_final, SLE_UINT16), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
607 |
SLE_VAR(Engine, duration_phase_1, SLE_UINT16), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
608 |
SLE_VAR(Engine, duration_phase_2, SLE_UINT16), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
609 |
SLE_VAR(Engine, duration_phase_3, SLE_UINT16), |
0 | 610 |
|
4344
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
611 |
SLE_VAR(Engine, lifelength, SLE_UINT8), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
612 |
SLE_VAR(Engine, flags, SLE_UINT8), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
613 |
SLE_VAR(Engine, preview_player, SLE_UINT8), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
614 |
SLE_VAR(Engine, preview_wait, SLE_UINT8), |
5823 | 615 |
SLE_CONDNULL(1, 0, 44), |
4344
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
616 |
SLE_VAR(Engine, player_avail, SLE_UINT8), |
0 | 617 |
|
6125
a6fff965707c
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
belugas
parents:
5971
diff
changeset
|
618 |
/* reserve extra space in savegame here. (currently 16 bytes) */ |
3222
6de22e06a1e9
(svn r3895) - Add proper SLE(G)_CONDNULL macros for the empty space reservation in savegames and update where used
Darkvater
parents:
3047
diff
changeset
|
619 |
SLE_CONDNULL(16, 2, SL_MAX_VERSION), |
0 | 620 |
|
621 |
SLE_END() |
|
622 |
}; |
|
623 |
||
6247 | 624 |
static void Save_ENGN() |
0 | 625 |
{ |
2242
512eae2cf006
(svn r2762) Simplify a loop, remove an unused variable and add many consts
tron
parents:
2204
diff
changeset
|
626 |
uint i; |
512eae2cf006
(svn r2762) Simplify a loop, remove an unused variable and add many consts
tron
parents:
2204
diff
changeset
|
627 |
|
512eae2cf006
(svn r2762) Simplify a loop, remove an unused variable and add many consts
tron
parents:
2204
diff
changeset
|
628 |
for (i = 0; i != lengthof(_engines); i++) { |
0 | 629 |
SlSetArrayIndex(i); |
2242
512eae2cf006
(svn r2762) Simplify a loop, remove an unused variable and add many consts
tron
parents:
2204
diff
changeset
|
630 |
SlObject(&_engines[i], _engine_desc); |
0 | 631 |
} |
632 |
} |
|
633 |
||
6247 | 634 |
static void Load_ENGN() |
0 | 635 |
{ |
636 |
int index; |
|
637 |
while ((index = SlIterateArray()) != -1) { |
|
1926
530480d14685
(svn r2432) Use GetEngine() instead of DEREF_ENGINE() or even _engines[]
tron
parents:
1908
diff
changeset
|
638 |
SlObject(GetEngine(index), _engine_desc); |
0 | 639 |
} |
640 |
} |
|
641 |
||
6247 | 642 |
static void LoadSave_ENGS() |
0 | 643 |
{ |
644 |
SlArray(_engine_name_strings, lengthof(_engine_name_strings), SLE_STRINGID); |
|
645 |
} |
|
646 |
||
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
647 |
extern const ChunkHandler _engine_chunk_handlers[] = { |
2848 | 648 |
{ 'ENGN', Save_ENGN, Load_ENGN, CH_ARRAY }, |
649 |
{ 'ENGS', LoadSave_ENGS, LoadSave_ENGS, CH_RIFF }, |
|
650 |
{ 'ERNW', Save_ERNW, Load_ERNW, CH_ARRAY | CH_LAST}, |
|
0 | 651 |
}; |
652 |
||
6247 | 653 |
void InitializeEngines() |
1197 | 654 |
{ |
2848 | 655 |
/* Clean the engine renew pool and create 1 block in it */ |
4974
2b7c9ba5604c
(svn r6977) Use the pool macros for the EngineRenew pool
tron
parents:
4848
diff
changeset
|
656 |
CleanPool(&_EngineRenew_pool); |
2b7c9ba5604c
(svn r6977) Use the pool macros for the EngineRenew pool
tron
parents:
4848
diff
changeset
|
657 |
AddBlockToPool(&_EngineRenew_pool); |
1196
67f7f3017d99
(svn r1700) - Fix: Hacked clients can no longer be used to build vehicles that are not available yet (Hackykid)
bjarni
parents:
1096
diff
changeset
|
658 |
} |