author | glx |
Wed, 06 Sep 2006 14:24:43 +0000 | |
changeset 4563 | 241260bd5505 |
parent 4559 | aa0c13e39840 |
child 5385 | 3868f2e6db9b |
permissions | -rw-r--r-- |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
1 |
/* $Id$ */ |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
2 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
3 |
#ifndef FOLLOW_TRACK_HPP |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
4 |
#define FOLLOW_TRACK_HPP |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
5 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
6 |
#include "yapf.hpp" |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
7 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
8 |
/** Track follower helper template class (can serve pathfinders and vehicle |
4549
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4407
diff
changeset
|
9 |
* controllers). See 6 different typedefs below for 3 different transport |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4407
diff
changeset
|
10 |
* types w/ of w/o 90-deg turns allowed */ |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
11 |
template <TransportType Ttr_type_, bool T90deg_turns_allowed_ = true> |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
12 |
struct CFollowTrackT : public FollowTrack_t |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
13 |
{ |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
14 |
CPerformanceTimer* m_pPerf; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
15 |
|
3915
914d45c135c7
(svn r5033) -CodeChange: [YAPF] RoadFindPathToStop() can now use YAPF for multistop handling.
KUDr
parents:
3912
diff
changeset
|
16 |
FORCEINLINE CFollowTrackT(const Vehicle* v = NULL, CPerformanceTimer* pPerf = NULL) |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
17 |
{ |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
18 |
Init(v, pPerf); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
19 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
20 |
|
3915
914d45c135c7
(svn r5033) -CodeChange: [YAPF] RoadFindPathToStop() can now use YAPF for multistop handling.
KUDr
parents:
3912
diff
changeset
|
21 |
FORCEINLINE void Init(const Vehicle* v, CPerformanceTimer* pPerf) |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
22 |
{ |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
23 |
assert(!IsRailTT() || (v != NULL && v->type == VEH_Train)); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
24 |
m_veh = v; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
25 |
m_pPerf = pPerf; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
26 |
// don't worry, all is inlined so compiler should remove unnecessary initializations |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
27 |
m_new_tile = INVALID_TILE; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
28 |
m_new_td_bits = TRACKDIR_BIT_NONE; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
29 |
m_exitdir = INVALID_DIAGDIR; |
3977
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
30 |
m_is_station = m_is_tunnel = false; |
3931
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
31 |
m_tiles_skipped = 0; |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
32 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
33 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
34 |
FORCEINLINE static TransportType TT() {return Ttr_type_;} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
35 |
FORCEINLINE static bool IsWaterTT() {return TT() == TRANSPORT_WATER;} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
36 |
FORCEINLINE static bool IsRailTT() {return TT() == TRANSPORT_RAIL;} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
37 |
FORCEINLINE static bool IsRoadTT() {return TT() == TRANSPORT_ROAD;} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
38 |
FORCEINLINE static bool Allow90degTurns() {return T90deg_turns_allowed_;} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
39 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
40 |
/** main follower routine. Fills all members and return true on success. |
4549
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4407
diff
changeset
|
41 |
* Otherwise returns false if track can't be followed. */ |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
42 |
FORCEINLINE bool Follow(TileIndex old_tile, Trackdir old_td) |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
43 |
{ |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
44 |
m_old_tile = old_tile; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
45 |
m_old_td = old_td; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
46 |
assert((GetTileTrackStatus(m_old_tile, TT()) & TrackdirToTrackdirBits(m_old_td)) != 0); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
47 |
m_exitdir = TrackdirToExitdir(m_old_td); |
3976
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
48 |
if (EnteredDepot()) return true; |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
49 |
if (!CanExitOldTile()) return false; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
50 |
FollowTileExit(); |
3976
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
51 |
if (!QueryNewTileTrackStatus()) return TryReverse(); |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
52 |
if (!CanEnterNewTile()) return false; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
53 |
m_new_td_bits &= DiagdirReachesTrackdirs(m_exitdir); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
54 |
if (!Allow90degTurns()) |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
55 |
m_new_td_bits &= (TrackdirBits)~(int)TrackdirCrossesTrackdirs(m_old_td); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
56 |
return (m_new_td_bits != TRACKDIR_BIT_NONE); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
57 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
58 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
59 |
protected: |
3931
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
60 |
/** Follow the m_exitdir from m_old_tile and fill m_new_tile and m_tiles_skipped */ |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
61 |
FORCEINLINE void FollowTileExit() |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
62 |
{ |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
63 |
// extra handling for tunnels in our direction |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
64 |
if (IsTunnelTile(m_old_tile)) { |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
65 |
DiagDirection tunnel_enterdir = GetTunnelDirection(m_old_tile); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
66 |
if (tunnel_enterdir == m_exitdir) { |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
67 |
// we are entering the tunnel |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
68 |
FindLengthOfTunnelResult flotr = FindLengthOfTunnel(m_old_tile, m_exitdir); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
69 |
m_new_tile = flotr.tile; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
70 |
m_is_tunnel = true; |
3931
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
71 |
m_tiles_skipped = flotr.length - 1; |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
72 |
return; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
73 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
74 |
assert(ReverseDiagDir(tunnel_enterdir) == m_exitdir); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
75 |
} |
3977
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
76 |
// not a tunnel or station |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
77 |
m_is_tunnel = false; |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
78 |
m_tiles_skipped = 0; |
3931
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
79 |
|
3977
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
80 |
// normal or station tile |
4559
aa0c13e39840
(svn r6406) -Codechange: Rename TileOffsByDir to TileOffsByDiagDir because it accepts
Darkvater
parents:
4549
diff
changeset
|
81 |
TileIndexDiff diff = TileOffsByDiagDir(m_exitdir); |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
82 |
m_new_tile = TILE_ADD(m_old_tile, diff); |
3931
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
83 |
|
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
84 |
// special handling for stations |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
85 |
if (IsRailTT() && IsRailwayStationTile(m_new_tile)) { |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
86 |
m_is_station = true; |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
87 |
} else if (IsRoadTT() && IsRoadStopTile(m_new_tile)) { |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
88 |
m_is_station = true; |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
89 |
} else { |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
90 |
m_is_station = false; |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
91 |
} |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
92 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
93 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
94 |
/** stores track status (available trackdirs) for the new tile into m_new_td_bits */ |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
95 |
FORCEINLINE bool QueryNewTileTrackStatus() |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
96 |
{ |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
97 |
CPerfStart perf(*m_pPerf); |
3912
08c70885ec45
(svn r5013) -Fix: [YAPF] RVs trying to plan route through railway.
KUDr
parents:
3900
diff
changeset
|
98 |
if (IsRailTT() && GetTileType(m_new_tile) == MP_RAILWAY && IsPlainRailTile(m_new_tile)) { |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
99 |
m_new_td_bits = (TrackdirBits)(GetTrackBits(m_new_tile) * 0x101); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
100 |
} else { |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
101 |
uint32 ts = GetTileTrackStatus(m_new_tile, TT()); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
102 |
m_new_td_bits = (TrackdirBits)(ts & TRACKDIR_BIT_MASK); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
103 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
104 |
return (m_new_td_bits != TRACKDIR_BIT_NONE); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
105 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
106 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
107 |
/** return true if we can leave m_old_tile in m_exitdir */ |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
108 |
FORCEINLINE bool CanExitOldTile() |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
109 |
{ |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
110 |
// road stop can be left at one direction only |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
111 |
if (IsRoadTT() && IsRoadStopTile(m_old_tile)) { |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
112 |
DiagDirection exitdir = GetRoadStopDir(m_old_tile); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
113 |
if (exitdir != m_exitdir) |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
114 |
return false; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
115 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
116 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
117 |
// road depots can be also left in one direction only |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
118 |
if (IsRoadTT() && IsTileDepotType(m_old_tile, TT())) { |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
119 |
DiagDirection exitdir = GetRoadDepotDirection(m_old_tile); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
120 |
if (exitdir != m_exitdir) |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
121 |
return false; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
122 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
123 |
return true; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
124 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
125 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
126 |
/** return true if we can enter m_new_tile from m_exitdir */ |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
127 |
FORCEINLINE bool CanEnterNewTile() |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
128 |
{ |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
129 |
if (IsRoadTT() && IsRoadStopTile(m_new_tile)) { |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
130 |
// road stop can be entered from one direction only |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
131 |
DiagDirection exitdir = GetRoadStopDir(m_new_tile); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
132 |
if (ReverseDiagDir(exitdir) != m_exitdir) |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
133 |
return false; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
134 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
135 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
136 |
// road and rail depots can also be entered from one direction only |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
137 |
if (IsRoadTT() && IsTileDepotType(m_new_tile, TT())) { |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
138 |
DiagDirection exitdir = GetRoadDepotDirection(m_new_tile); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
139 |
if (ReverseDiagDir(exitdir) != m_exitdir) |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
140 |
return false; |
4407
685c613f3fec
(svn r6160) -Fix [ 1519167 ] Bus trying to service in depot of other company (mart3p)
KUDr
parents:
3977
diff
changeset
|
141 |
// don't try to enter other player's depots |
685c613f3fec
(svn r6160) -Fix [ 1519167 ] Bus trying to service in depot of other company (mart3p)
KUDr
parents:
3977
diff
changeset
|
142 |
if (GetTileOwner(m_new_tile) != m_veh->owner) { |
685c613f3fec
(svn r6160) -Fix [ 1519167 ] Bus trying to service in depot of other company (mart3p)
KUDr
parents:
3977
diff
changeset
|
143 |
return false; |
685c613f3fec
(svn r6160) -Fix [ 1519167 ] Bus trying to service in depot of other company (mart3p)
KUDr
parents:
3977
diff
changeset
|
144 |
} |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
145 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
146 |
if (IsRailTT() && IsTileDepotType(m_new_tile, TT())) { |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
147 |
DiagDirection exitdir = GetRailDepotDirection(m_new_tile); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
148 |
if (ReverseDiagDir(exitdir) != m_exitdir) |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
149 |
return false; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
150 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
151 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
152 |
// rail transport is possible only on tiles with the same owner as vehicle |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
153 |
if (IsRailTT() && GetTileOwner(m_new_tile) != m_veh->owner) { |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
154 |
// different owner |
3977
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
155 |
if (IsBridgeTile(m_new_tile)) { |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
156 |
if (IsBridgeMiddle(m_new_tile)) { |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
157 |
// bridge middle has no owner - tile is owned by the owner of the under-bridge track |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
158 |
if (GetBridgeAxis(m_new_tile) != DiagDirToAxis(m_exitdir)) { |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
159 |
// so it must be under bridge track (and wrong owner) |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
160 |
return false; |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
161 |
} |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
162 |
// in the middle of the bridge - when we came here, it should be ok |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
163 |
} else { |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
164 |
// different owner, on the bridge ramp |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
165 |
return false; |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
166 |
} |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
167 |
} else { |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
168 |
// different owner, not a bridge |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
169 |
return false; |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
170 |
} |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
171 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
172 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
173 |
// rail transport is possible only on compatible rail types |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
174 |
if (IsRailTT()) { |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
175 |
RailType rail_type = GetTileRailType(m_new_tile, DiagdirToDiagTrackdir(m_exitdir)); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
176 |
if (((1 << rail_type) & m_veh->u.rail.compatible_railtypes) == 0) { |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
177 |
// incompatible rail type |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
178 |
return false; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
179 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
180 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
181 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
182 |
// tunnel tiles can be entered only from proper direction |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
183 |
if (!IsWaterTT() && !m_is_tunnel && IsTunnelTile(m_new_tile)) { |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
184 |
DiagDirection tunnel_enterdir = GetTunnelDirection(m_new_tile); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
185 |
if (tunnel_enterdir != m_exitdir) |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
186 |
return false; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
187 |
} |
3931
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
188 |
|
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
189 |
// special handling for rail stations - get to the end of platform |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
190 |
if (IsRailTT() && m_is_station) { |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
191 |
// entered railway station |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
192 |
// get platform length |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
193 |
uint length = GetPlatformLength(m_new_tile, TrackdirToExitdir(m_old_td)); |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
194 |
// how big step we must do to get to the last platform tile; |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
195 |
m_tiles_skipped = length - 1; |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
196 |
// move to the platform end |
4559
aa0c13e39840
(svn r6406) -Codechange: Rename TileOffsByDir to TileOffsByDiagDir because it accepts
Darkvater
parents:
4549
diff
changeset
|
197 |
TileIndexDiff diff = TileOffsByDiagDir(m_exitdir); |
3931
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
198 |
diff *= m_tiles_skipped; |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
199 |
m_new_tile = TILE_ADD(m_new_tile, diff); |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
200 |
return true; |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
201 |
} |
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
202 |
|
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
203 |
return true; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
204 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
205 |
|
3976
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
206 |
/** return true if we entered depot and reversed inside */ |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
207 |
FORCEINLINE bool EnteredDepot() |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
208 |
{ |
3976
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
209 |
// rail and road depots cause reversing |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
210 |
if (!IsWaterTT() && IsTileDepotType(m_old_tile, TT())) { |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
211 |
DiagDirection exitdir = IsRailTT() ? GetRailDepotDirection(m_old_tile) : GetRoadDepotDirection(m_old_tile); |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
212 |
if (exitdir != m_exitdir) { |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
213 |
// reverse |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
214 |
m_new_tile = m_old_tile; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
215 |
m_new_td_bits = TrackdirToTrackdirBits(ReverseTrackdir(m_old_td)); |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
216 |
m_exitdir = exitdir; |
3931
b946fc6e7188
(svn r5066) -Feature: [YAPF] Train selects the best station platform by length
KUDr
parents:
3915
diff
changeset
|
217 |
m_tiles_skipped = 0; |
3977
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
218 |
m_is_tunnel = m_is_station = false; |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
219 |
return true; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
220 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
221 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
222 |
return false; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
223 |
} |
3976
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
224 |
|
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
225 |
/** return true if we successfully reversed at end of road/track */ |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
226 |
FORCEINLINE bool TryReverse() |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
227 |
{ |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
228 |
if (IsRoadTT()) { |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
229 |
// if we reached the end of road, we can reverse the RV and continue moving |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
230 |
m_exitdir = ReverseDiagDir(m_exitdir); |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
231 |
// new tile will be the same as old one |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
232 |
m_new_tile = m_old_tile; |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
233 |
// set new trackdir bits to all reachable trackdirs |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
234 |
QueryNewTileTrackStatus(); |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
235 |
m_new_td_bits &= DiagdirReachesTrackdirs(m_exitdir); |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
236 |
if (m_new_td_bits != TRACKDIR_BIT_NONE) { |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
237 |
// we have some trackdirs reachable after reversal |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
238 |
return true; |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
239 |
} |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
240 |
} |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
241 |
return false; |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
242 |
} |
6135bc445350
(svn r5153) - Fix: [YAPF] RVs can now plan path reversing in depot or end of road
KUDr
parents:
3933
diff
changeset
|
243 |
|
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
244 |
public: |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
245 |
/** Helper for pathfinders - get min/max speed on the m_old_tile/m_old_td */ |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
246 |
int GetSpeedLimit(int *pmin_speed = NULL) |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
247 |
{ |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
248 |
int min_speed = 0; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
249 |
int max_speed = INT_MAX; // no limit |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
250 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
251 |
// for now we handle only on-bridge speed limit |
3977
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
252 |
if (IsBridgeTile(m_old_tile) && !IsWaterTT() && IsDiagonalTrackdir(m_old_td)) { |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
253 |
bool is_on_bridge = true; |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
254 |
if (IsBridgeMiddle(m_old_tile)) { |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
255 |
// get track axis |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
256 |
Axis track_axis = DiagDirToAxis(TrackdirToExitdir(m_old_td)); |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
257 |
// get under-bridge axis |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
258 |
Axis bridge_axis = GetBridgeAxis(m_old_tile); |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
259 |
if (track_axis != bridge_axis) is_on_bridge = false; |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
260 |
} |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
261 |
if (is_on_bridge) { |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
262 |
int spd = _bridge[GetBridgeType(m_old_tile)].speed; |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
263 |
if (IsRoadTT()) spd *= 2; |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
264 |
if (max_speed > spd) max_speed = spd; |
513433ebd092
(svn r5155) - Remove the bridge branch merge (revision r5070)
tron
parents:
3976
diff
changeset
|
265 |
} |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
266 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
267 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
268 |
// if min speed was requested, return it |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
269 |
if (pmin_speed) *pmin_speed = min_speed; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
270 |
return max_speed; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
271 |
} |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
272 |
}; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
273 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
274 |
typedef CFollowTrackT<TRANSPORT_WATER, true > CFollowTrackWater; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
275 |
typedef CFollowTrackT<TRANSPORT_ROAD , true > CFollowTrackRoad; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
276 |
typedef CFollowTrackT<TRANSPORT_RAIL , true > CFollowTrackRail; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
277 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
278 |
typedef CFollowTrackT<TRANSPORT_WATER, false> CFollowTrackWaterNo90; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
279 |
typedef CFollowTrackT<TRANSPORT_ROAD , false> CFollowTrackRoadNo90; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
280 |
typedef CFollowTrackT<TRANSPORT_RAIL , false> CFollowTrackRailNo90; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
281 |
|
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
diff
changeset
|
282 |
#endif /* FOLLOW_TRACK_HPP */ |