summaryrefslogtreecommitdiff
path: root/src/train_cmd.cpp
diff options
context:
space:
mode:
authorpeter1138 <peter1138@openttd.org>2007-07-30 08:49:41 +0000
committerpeter1138 <peter1138@openttd.org>2007-07-30 08:49:41 +0000
commit9b9bca40b94fe7e44887004d28efc6b175005e1d (patch)
tree3a919447e032e1fc18a1e2e780c0d9f53dec26d5 /src/train_cmd.cpp
parent2800a49f0361b586573e8d3c78a1ecb13e414b18 (diff)
downloadopenttd-9b9bca40b94fe7e44887004d28efc6b175005e1d.tar.xz
(svn r10734) -Fix [FS#1030]: Revert r10513) and add special cases for collision detection on bridges/tunnels.
Diffstat (limited to 'src/train_cmd.cpp')
-rw-r--r--src/train_cmd.cpp11
1 files changed, 10 insertions, 1 deletions
diff --git a/src/train_cmd.cpp b/src/train_cmd.cpp
index 69ed022e8..047725269 100644
--- a/src/train_cmd.cpp
+++ b/src/train_cmd.cpp
@@ -2760,7 +2760,16 @@ static void CheckTrainCollision(Vehicle *v)
tcc.num = 0;
/* find colliding vehicles */
- VehicleFromPosXY(v->x_pos, v->y_pos, &tcc, FindTrainCollideEnum);
+ if (v->u.rail.track == TRACK_BIT_WORMHOLE) {
+ VehicleFromPos(v->tile, &tcc, FindTrainCollideEnum);
+ if (IsBridgeTile(v->tile)) {
+ VehicleFromPos(GetOtherBridgeEnd(v->tile), &tcc, FindTrainCollideEnum);
+ } else {
+ VehicleFromPos(GetOtherTunnelEnd(v->tile), &tcc, FindTrainCollideEnum);
+ }
+ } else {
+ VehicleFromPosXY(v->x_pos, v->y_pos, &tcc, FindTrainCollideEnum);
+ }
/* any dead -> no crash */
if (tcc.num == 0) return;