From 3a7c8cc88d0fb4b3135979a45effc1bf7ac51fad Mon Sep 17 00:00:00 2001 From: rubidium Date: Wed, 31 Oct 2007 22:13:41 +0000 Subject: (svn r11366) -Fix [FS#1258]: road vehicles must not drive through eachother on bridges/in tunnels. --- src/roadveh_cmd.cpp | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/src/roadveh_cmd.cpp b/src/roadveh_cmd.cpp index edb2c222a..542cd3f73 100644 --- a/src/roadveh_cmd.cpp +++ b/src/roadveh_cmd.cpp @@ -884,25 +884,30 @@ static Vehicle* RoadVehFindCloseTo(Vehicle* v, int x, int y, Direction dir) { RoadVehFindData rvf; Vehicle *u; + Vehicle *front = v->First(); - if (v->u.road.reverse_ctr != 0) return NULL; + if (front->u.road.reverse_ctr != 0) return NULL; rvf.x = x; rvf.y = y; rvf.dir = dir; rvf.veh = v; - u = (Vehicle*)VehicleFromPosXY(x, y, &rvf, EnumCheckRoadVehClose); + if (front->u.road.state == RVSB_WORMHOLE) { + u = (Vehicle*)VehicleFromPos(v->tile, &rvf, EnumCheckRoadVehClose); + } else { + u = (Vehicle*)VehicleFromPosXY(x, y, &rvf, EnumCheckRoadVehClose); + } /* This code protects a roadvehicle from being blocked for ever * If more than 1480 / 74 days a road vehicle is blocked, it will * drive just through it. The ultimate backup-code of TTD. * It can be disabled. */ if (u == NULL) { - v->u.road.blocked_ctr = 0; + front->u.road.blocked_ctr = 0; return NULL; } - if (++v->u.road.blocked_ctr > 1480) return NULL; + if (++front->u.road.blocked_ctr > 1480) return NULL; return u; } -- cgit v1.2.3-70-g09d2