summaryrefslogtreecommitdiff
path: root/pathfind.c
diff options
context:
space:
mode:
authorKUDr <KUDr@openttd.org>2006-12-29 17:51:16 +0000
committerKUDr <KUDr@openttd.org>2006-12-29 17:51:16 +0000
commit324e805d5153efcb1c44c1998cfd92b20fb7c2cc (patch)
treec8f7c1c86261904ef8c7840d102da68825de810f /pathfind.c
parentd78d12fdfe09eb6d1b08baf6725cd5aed9b4ea07 (diff)
downloadopenttd-324e805d5153efcb1c44c1998cfd92b20fb7c2cc.tar.xz
(svn r7620) -Fix: [OPF] signal update was incorrectly propagated:
- through incompatible rail types - from under bridge track to the bridge ramp (peter1138) - same for tunnels (from track on top of tunnel entry to the tunnel)
Diffstat (limited to 'pathfind.c')
-rw-r--r--pathfind.c62
1 files changed, 44 insertions, 18 deletions
diff --git a/pathfind.c b/pathfind.c
index 97c5e3521..a0b5f064e 100644
--- a/pathfind.c
+++ b/pathfind.c
@@ -253,7 +253,7 @@ const byte _ffb_64[128] = {
static void TPFMode1(TrackPathFinder* tpf, TileIndex tile, DiagDirection direction)
{
- uint bits;
+ uint bits = 0;
int i;
RememberData rd;
TileIndex tile_org = tile;
@@ -282,28 +282,54 @@ static void TPFMode1(TrackPathFinder* tpf, TileIndex tile, DiagDirection directi
}
tile += TileOffsByDiagDir(direction);
- /* Check in case of rail if the owner is the same */
- if (tpf->tracktype == TRANSPORT_RAIL) {
- // don't enter train depot from the back
- if (IsTileDepotType(tile, TRANSPORT_RAIL) && GetRailDepotDirection(tile) == direction) return;
+ /* check if the new tile can be entered from that direction */
+ /* Inside this block we should not use 'return' to indicate 'no way' condition (at least for rail transport type) */
+ if (tpf->tracktype == TRANSPORT_ROAD || tpf->tracktype == TRANSPORT_RAIL) {
+ if (tpf->tracktype == TRANSPORT_RAIL) {
+ /* don't enter train depot from the back */
+ if (IsTileDepotType(tile, TRANSPORT_RAIL) && GetRailDepotDirection(tile) == direction) goto no_way;
+
+ /* Check in case of rail if the owner is the same */
+ if (IsTileType(tile_org, MP_RAILWAY) || IsTileType(tile_org, MP_STATION) || IsTileType(tile_org, MP_TUNNELBRIDGE))
+ if (IsTileType(tile, MP_RAILWAY) || IsTileType(tile, MP_STATION) || IsTileType(tile, MP_TUNNELBRIDGE))
+ if (GetTileOwner(tile_org) != GetTileOwner(tile)) goto no_way;
+ }
- if (IsTileType(tile_org, MP_RAILWAY) || IsTileType(tile_org, MP_STATION) || IsTileType(tile_org, MP_TUNNELBRIDGE))
- if (IsTileType(tile, MP_RAILWAY) || IsTileType(tile, MP_STATION) || IsTileType(tile, MP_TUNNELBRIDGE))
- if (GetTileOwner(tile_org) != GetTileOwner(tile)) return;
- }
+ if (tpf->tracktype == TRANSPORT_ROAD) {
+ /* road stops and depots now have a track (r4419) */
+ /* don't enter road stop from the back */
+ if (IsRoadStopTile(tile) && ReverseDiagDir(GetRoadStopDir(tile)) != direction) goto no_way;
+ /* don't enter road depot from the back */
+ if (IsTileDepotType(tile, TRANSPORT_ROAD) && ReverseDiagDir(GetRoadDepotDirection(tile)) != direction) goto no_way;
+ }
- // check if the new tile can be entered from that direction
- if (tpf->tracktype == TRANSPORT_ROAD) {
- // road stops and depots now have a track (r4419)
- // don't enter road stop from the back
- if (IsRoadStopTile(tile) && ReverseDiagDir(GetRoadStopDir(tile)) != direction) return;
- // don't enter road depot from the back
- if (IsTileDepotType(tile, TRANSPORT_ROAD) && ReverseDiagDir(GetRoadDepotDirection(tile)) != direction) return;
+ if (IsTileType(tile, MP_TUNNELBRIDGE)) {
+ if (IsTunnel(tile)) {
+ /* tunnel hole can be entered only from one direction */
+ if (GetTunnelDirection(tile) != direction) goto no_way;
+ } else if (IsBridge(tile)) {
+ /* bridge ramp can be entered only from one direction (without custom bridge heads) */
+ if (GetBridgeRampDirection(tile) != direction) goto no_way;
+ }
+ }
+ if (tpf->tracktype == TRANSPORT_RAIL) {
+ /* check for the rail type compatibility */
+ Trackdir td = DiagdirToDiagTrackdir(direction);
+ RailType type_org = GetTileRailType(tile_org, td);
+ RailType type = GetTileRailType(tile, td);
+ if (type != type_org) {
+ // they can be compatible only if one is normal and the other one is elrail
+ if (type_org == RAILTYPE_RAIL && type != RAILTYPE_ELECTRIC) goto no_way;
+ if (type == RAILTYPE_RAIL && type_org != RAILTYPE_ELECTRIC) goto no_way;
+ }
+ }
}
- tpf->rd.cur_length++;
-
+ /* the next line is skipped when the new tile can't be entered from tile_org */
bits = GetTileTrackStatus(tile, tpf->tracktype);
+no_way:
+
+ tpf->rd.cur_length++;
if ((byte)bits != tpf->var2) {
bits &= _tpfmode1_and[direction];