summaryrefslogtreecommitdiff
path: root/ai.c
diff options
context:
space:
mode:
authordarkvater <darkvater@openttd.org>2004-11-19 19:13:32 +0000
committerdarkvater <darkvater@openttd.org>2004-11-19 19:13:32 +0000
commit249438be886bfc9be4f8048ac7a6b0e695dcc2ac (patch)
tree5c9ff0e5738b435a8d51a83e7e7abdf5ea641c61 /ai.c
parentd51daeab1add65308ed8ddf193fd43a7348b2ce1 (diff)
downloadopenttd-249438be886bfc9be4f8048ac7a6b0e695dcc2ac.tar.xz
(svn r677) -newgrf: Fix some custom electric trains appearing in maglev depots (pasky).
Diffstat (limited to 'ai.c')
-rw-r--r--ai.c20
1 files changed, 7 insertions, 13 deletions
diff --git a/ai.c b/ai.c
index 857ef9ab2..afed9d234 100644
--- a/ai.c
+++ b/ai.c
@@ -113,25 +113,19 @@ static void AiStateVehLoop(Player *p)
p->ai.state_counter = 0;
}
-// XXX
-static const byte _rail_locos_count[3] = {
- 27, 3, 5
-};
-extern const byte _rail_engines_start[3];
-
static int AiChooseTrainToBuild(byte railtype, int32 money, byte flag)
{
int best_veh_index = -1;
byte best_veh_score = 0;
int32 r;
+ int i;
- int i = _rail_engines_start[railtype];
- int end = i + _rail_locos_count[railtype];
- Engine *e = &_engines[i];
- do {
- assert(!(_rail_vehicle_info[i].flags & RVI_WAGON));
+ for (i = 0; i < NUM_TRAIN_ENGINES; i++) {
+ RailVehicleInfo *rvi = &rail_vehinfo(i);
+ Engine *e = DEREF_ENGINE(i);
- if (!HASBIT(e->player_avail, _current_player) || e->reliability < 0x8A3D)
+ if (e->railtype != railtype || rvi->flags & RVI_WAGON
+ || !HASBIT(e->player_avail, _current_player) || e->reliability < 0x8A3D)
continue;
r = DoCommandByTile(0, i, 0, 0, CMD_BUILD_RAIL_VEHICLE);
@@ -142,7 +136,7 @@ static int AiChooseTrainToBuild(byte railtype, int32 money, byte flag)
best_veh_score = _cmd_build_rail_veh_score;
best_veh_index = i;
}
- } while (++e, ++i != end);
+ }
return best_veh_index;
}