Mercurial > hg > openttd
annotate src/rail_map.h @ 8238:e9d8b0764f38 draft
(svn r11802) -Fix [FS#716]: do not crash trains when leaving depot to a very long track
-Codechange: use dedicated pathfinder for signal updating, resulting in better performance and possible future improvements
author | smatz <smatz@openttd.org> |
---|---|
date | Wed, 09 Jan 2008 23:00:59 +0000 |
parents | 60ea0f95de91 |
children | 124ea89a5409 |
rev | line source |
---|---|
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
1 /* $Id$ */ |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
2 |
6393
ffd35446c110
(svn r9523) -Cleanup: doxygen changes. Time to take care of "R"
belugas <belugas@openttd.org>
parents:
6248
diff
changeset
|
3 /** @file rail_map.h Hides the direct accesses to the map array with map accessors */ |
ffd35446c110
(svn r9523) -Cleanup: doxygen changes. Time to take care of "R"
belugas <belugas@openttd.org>
parents:
6248
diff
changeset
|
4 |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
5 #ifndef RAIL_MAP_H |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
6 #define RAIL_MAP_H |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
7 |
8138
60ea0f95de91
(svn r11700) -Codechange: reduce the amount of unnecessary includes.
rubidium <rubidium@openttd.org>
parents:
8108
diff
changeset
|
8 #include "rail_type.h" |
60ea0f95de91
(svn r11700) -Codechange: reduce the amount of unnecessary includes.
rubidium <rubidium@openttd.org>
parents:
8108
diff
changeset
|
9 #include "signal_func.h" |
8100
6d739a5490a9
(svn r11661) -Codechange: some header reworks in order to try to reduce the compile time of OpenTTD by reduce the amount of circular-ish dependencies.
rubidium <rubidium@openttd.org>
parents:
7928
diff
changeset
|
10 #include "direction_func.h" |
8101
b222582555cb
(svn r11662) -Codechange: move some rail types/related functions around.
rubidium <rubidium@openttd.org>
parents:
8100
diff
changeset
|
11 #include "track_func.h" |
8108
4faab45e2603
(svn r11669) -Codechange: refactor tile.h -> tile_type.h and tile_map.h
rubidium <rubidium@openttd.org>
parents:
8101
diff
changeset
|
12 #include "tile_map.h" |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
13 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
14 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
15 /** Different types of Rail-related tiles */ |
6248
0789677a15a0
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
rubidium <rubidium@openttd.org>
parents:
6182
diff
changeset
|
16 enum RailTileType { |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
17 RAIL_TILE_NORMAL = 0, ///< Normal rail tile without signals |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
18 RAIL_TILE_SIGNALS = 1, ///< Normal rail tile with signals |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
19 RAIL_TILE_WAYPOINT = 2, ///< Waypoint (X or Y direction) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
20 RAIL_TILE_DEPOT = 3, ///< Depot (one entrance) |
6248
0789677a15a0
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
rubidium <rubidium@openttd.org>
parents:
6182
diff
changeset
|
21 }; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
22 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
23 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
24 * Returns the RailTileType (normal with or without signals, |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
25 * waypoint or depot). |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
26 * @param t the tile to get the information from |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
27 * @pre IsTileType(t, MP_RAILWAY) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
28 * @return the RailTileType |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
29 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
30 static inline RailTileType GetRailTileType(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
31 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
32 assert(IsTileType(t, MP_RAILWAY)); |
6172
b3b8cbc5e854
(svn r8935) -Codechange: unification of track type between road and rail tiles, unification of ground type between normal rail tiles and depots/waypoints and removing the need for RailTileSubType.
rubidium <rubidium@openttd.org>
parents:
6154
diff
changeset
|
33 return (RailTileType)GB(_m[t].m5, 6, 2); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
34 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
35 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
36 /** |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
37 * Returns whether this is plain rails, with or without signals. Iow, if this |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
38 * tiles RailTileType is RAIL_TILE_NORMAL or RAIL_TILE_SIGNALS. |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
39 * @param t the tile to get the information from |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
40 * @pre IsTileType(t, MP_RAILWAY) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
41 * @return true if and only if the tile is normal rail (with or without signals) |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
42 */ |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
43 static inline bool IsPlainRailTile(TileIndex t) |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
44 { |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
45 RailTileType rtt = GetRailTileType(t); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
46 return rtt == RAIL_TILE_NORMAL || rtt == RAIL_TILE_SIGNALS; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
47 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
48 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
49 /** |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
50 * Checks if a rail tile has signals. |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
51 * @param t the tile to get the information from |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
52 * @pre IsTileType(t, MP_RAILWAY) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
53 * @return true if and only if the tile has signals |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
54 */ |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
55 static inline bool HasSignals(TileIndex t) |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
56 { |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
57 return GetRailTileType(t) == RAIL_TILE_SIGNALS; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
58 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
59 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
60 /** |
6172
b3b8cbc5e854
(svn r8935) -Codechange: unification of track type between road and rail tiles, unification of ground type between normal rail tiles and depots/waypoints and removing the need for RailTileSubType.
rubidium <rubidium@openttd.org>
parents:
6154
diff
changeset
|
61 * Add/remove the 'has signal' bit from the RailTileType |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
62 * @param tile the tile to add/remove the signals to/from |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
63 * @param signals whether the rail tile should have signals or not |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
64 * @pre IsPlainRailTile(tile) |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
65 */ |
6172
b3b8cbc5e854
(svn r8935) -Codechange: unification of track type between road and rail tiles, unification of ground type between normal rail tiles and depots/waypoints and removing the need for RailTileSubType.
rubidium <rubidium@openttd.org>
parents:
6154
diff
changeset
|
66 static inline void SetHasSignals(TileIndex tile, bool signals) |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
67 { |
6172
b3b8cbc5e854
(svn r8935) -Codechange: unification of track type between road and rail tiles, unification of ground type between normal rail tiles and depots/waypoints and removing the need for RailTileSubType.
rubidium <rubidium@openttd.org>
parents:
6154
diff
changeset
|
68 assert(IsPlainRailTile(tile)); |
b3b8cbc5e854
(svn r8935) -Codechange: unification of track type between road and rail tiles, unification of ground type between normal rail tiles and depots/waypoints and removing the need for RailTileSubType.
rubidium <rubidium@openttd.org>
parents:
6154
diff
changeset
|
69 SB(_m[tile].m5, 6, 1, signals); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
70 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
71 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
72 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
73 * Is this tile a rail depot? |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
74 * @param t the tile to get the information from |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
75 * @pre IsTileType(t, MP_RAILWAY) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
76 * @return true if and only if the tile is a rail depot |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
77 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
78 static inline bool IsRailDepot(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
79 { |
6172
b3b8cbc5e854
(svn r8935) -Codechange: unification of track type between road and rail tiles, unification of ground type between normal rail tiles and depots/waypoints and removing the need for RailTileSubType.
rubidium <rubidium@openttd.org>
parents:
6154
diff
changeset
|
80 return GetRailTileType(t) == RAIL_TILE_DEPOT; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
81 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
82 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
83 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
84 * Is this tile a rail waypoint? |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
85 * @param t the tile to get the information from |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
86 * @pre IsTileType(t, MP_RAILWAY) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
87 * @return true if and only if the tile is a rail waypoint |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
88 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
89 static inline bool IsRailWaypoint(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
90 { |
6172
b3b8cbc5e854
(svn r8935) -Codechange: unification of track type between road and rail tiles, unification of ground type between normal rail tiles and depots/waypoints and removing the need for RailTileSubType.
rubidium <rubidium@openttd.org>
parents:
6154
diff
changeset
|
91 return GetRailTileType(t) == RAIL_TILE_WAYPOINT; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
92 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
93 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
94 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
95 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
96 * Gets the rail type of the given tile |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
97 * @param t the tile to get the rail type from |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
98 * @return the rail type of the tile |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
99 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
100 static inline RailType GetRailType(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
101 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
102 return (RailType)GB(_m[t].m3, 0, 4); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
103 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
104 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
105 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
106 * Sets the track bits of the given tile |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
107 * @param t the tile to set the track bits of |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
108 * @param r the new track bits for the tile |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
109 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
110 static inline void SetRailType(TileIndex t, RailType r) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
111 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
112 SB(_m[t].m3, 0, 4, r); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
113 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
114 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
115 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
116 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
117 * Gets the rail type of the given tile |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
118 * @param t the tile to get the rail type from |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
119 * @return the rail type of the tile |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
120 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
121 static inline TrackBits GetTrackBits(TileIndex tile) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
122 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
123 return (TrackBits)GB(_m[tile].m5, 0, 6); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
124 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
125 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
126 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
127 * Sets the track bits of the given tile |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
128 * @param t the tile to set the track bits of |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
129 * @param b the new track bits for the tile |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
130 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
131 static inline void SetTrackBits(TileIndex t, TrackBits b) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
132 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
133 SB(_m[t].m5, 0, 6, b); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
134 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
135 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
136 /** |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
137 * Returns whether the given track is present on the given tile. |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
138 * @param tile the tile to check the track presence of |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
139 * @param track the track to search for on the tile |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
140 * @pre IsPlainRailTile(tile) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
141 * @return true if and only if the given track exists on the tile |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
142 */ |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
143 static inline bool HasTrack(TileIndex tile, Track track) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
144 { |
7928
4e8dfd103163
(svn r11481) -Codechange: Rename the HASBIT function to fit with the naming style
skidd13 <skidd13@openttd.org>
parents:
7771
diff
changeset
|
145 return HasBit(GetTrackBits(tile), track); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
146 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
147 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
148 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
149 * Returns the direction the depot is facing to |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
150 * @param t the tile to get the depot facing from |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
151 * @pre IsRailDepotTile(t) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
152 * @return the direction the depot is facing |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
153 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
154 static inline DiagDirection GetRailDepotDirection(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
155 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
156 return (DiagDirection)GB(_m[t].m5, 0, 2); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
157 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
158 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
159 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
160 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
161 * Returns the axis of the waypoint |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
162 * @param t the tile to get the waypoint axis from |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
163 * @pre IsRailWaypointTile(t) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
164 * @return the axis of the waypoint |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
165 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
166 static inline Axis GetWaypointAxis(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
167 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
168 return (Axis)GB(_m[t].m5, 0, 1); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
169 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
170 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
171 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
172 * Returns the track of the waypoint |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
173 * @param t the tile to get the waypoint track from |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
174 * @pre IsRailWaypointTile(t) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
175 * @return the track of the waypoint |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
176 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
177 static inline Track GetRailWaypointTrack(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
178 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
179 return AxisToTrack(GetWaypointAxis(t)); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
180 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
181 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
182 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
183 * Returns the track bits of the waypoint |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
184 * @param t the tile to get the waypoint track bits from |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
185 * @pre IsRailWaypointTile(t) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
186 * @return the track bits of the waypoint |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
187 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
188 static inline TrackBits GetRailWaypointBits(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
189 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
190 return TrackToTrackBits(GetRailWaypointTrack(t)); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
191 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
192 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
193 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
194 * Returns waypoint index (for the waypoint pool) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
195 * @param t the tile to get the waypoint index from |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
196 * @pre IsRailWaypointTile(t) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
197 * @return the waypoint index |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
198 */ |
6182
e1626f2e63ad
(svn r8954) -Codechange: remove direct map accesses from non-map-accessor headers.
rubidium <rubidium@openttd.org>
parents:
6172
diff
changeset
|
199 static inline WaypointID GetWaypointIndex(TileIndex t) |
e1626f2e63ad
(svn r8954) -Codechange: remove direct map accesses from non-map-accessor headers.
rubidium <rubidium@openttd.org>
parents:
6172
diff
changeset
|
200 { |
e1626f2e63ad
(svn r8954) -Codechange: remove direct map accesses from non-map-accessor headers.
rubidium <rubidium@openttd.org>
parents:
6172
diff
changeset
|
201 return (WaypointID)_m[t].m2; |
e1626f2e63ad
(svn r8954) -Codechange: remove direct map accesses from non-map-accessor headers.
rubidium <rubidium@openttd.org>
parents:
6172
diff
changeset
|
202 } |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
203 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
204 /** Type of signal, i.e. how does the signal behave? */ |
6248
0789677a15a0
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
rubidium <rubidium@openttd.org>
parents:
6182
diff
changeset
|
205 enum SignalType { |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
206 SIGTYPE_NORMAL = 0, ///< normal signal |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
207 SIGTYPE_ENTRY = 1, ///< presignal block entry |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
208 SIGTYPE_EXIT = 2, ///< presignal block exit |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
209 SIGTYPE_COMBO = 3 ///< presignal inter-block |
6248
0789677a15a0
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
rubidium <rubidium@openttd.org>
parents:
6182
diff
changeset
|
210 }; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
211 |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
212 static inline SignalType GetSignalType(TileIndex t, Track track) |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
213 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
214 assert(GetRailTileType(t) == RAIL_TILE_SIGNALS); |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
215 byte pos = (track == TRACK_LOWER || track == TRACK_RIGHT) ? 4 : 0; |
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
216 return (SignalType)GB(_m[t].m2, pos, 2); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
217 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
218 |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
219 static inline void SetSignalType(TileIndex t, Track track, SignalType s) |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
220 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
221 assert(GetRailTileType(t) == RAIL_TILE_SIGNALS); |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
222 byte pos = (track == TRACK_LOWER || track == TRACK_RIGHT) ? 4 : 0; |
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
223 SB(_m[t].m2, pos, 2, s); |
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
224 if (track == INVALID_TRACK) SB(_m[t].m2, 4, 2, s); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
225 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
226 |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
227 static inline bool IsPresignalEntry(TileIndex t, Track track) |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
228 { |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
229 return GetSignalType(t, track) == SIGTYPE_ENTRY || GetSignalType(t, track) == SIGTYPE_COMBO; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
230 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
231 |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
232 static inline bool IsPresignalExit(TileIndex t, Track track) |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
233 { |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
234 return GetSignalType(t, track) == SIGTYPE_EXIT || GetSignalType(t, track) == SIGTYPE_COMBO; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
235 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
236 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
237 static inline void CycleSignalSide(TileIndex t, Track track) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
238 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
239 byte sig; |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
240 byte pos = (track == TRACK_LOWER || track == TRACK_RIGHT) ? 4 : 6; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
241 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
242 sig = GB(_m[t].m3, pos, 2); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
243 if (--sig == 0) sig = 3; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
244 SB(_m[t].m3, pos, 2, sig); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
245 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
246 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
247 /** Variant of the signal, i.e. how does the signal look? */ |
6248
0789677a15a0
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
rubidium <rubidium@openttd.org>
parents:
6182
diff
changeset
|
248 enum SignalVariant { |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
249 SIG_ELECTRIC = 0, ///< Light signal |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
250 SIG_SEMAPHORE = 1 ///< Old-fashioned semaphore signal |
6248
0789677a15a0
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
rubidium <rubidium@openttd.org>
parents:
6182
diff
changeset
|
251 }; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
252 |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
253 static inline SignalVariant GetSignalVariant(TileIndex t, Track track) |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
254 { |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
255 byte pos = (track == TRACK_LOWER || track == TRACK_RIGHT) ? 6 : 2; |
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
256 return (SignalVariant)GB(_m[t].m2, pos, 1); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
257 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
258 |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
259 static inline void SetSignalVariant(TileIndex t, Track track, SignalVariant v) |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
260 { |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
261 byte pos = (track == TRACK_LOWER || track == TRACK_RIGHT) ? 6 : 2; |
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
262 SB(_m[t].m2, pos, 1, v); |
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
263 if (track == INVALID_TRACK) SB(_m[t].m2, 6, 1, v); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
264 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
265 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
266 /** These are states in which a signal can be. Currently these are only two, so |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
267 * simple boolean logic will do. But do try to compare to this enum instead of |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
268 * normal boolean evaluation, since that will make future additions easier. |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
269 */ |
6248
0789677a15a0
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
rubidium <rubidium@openttd.org>
parents:
6182
diff
changeset
|
270 enum SignalState { |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
271 SIGNAL_STATE_RED = 0, ///< The signal is red |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
272 SIGNAL_STATE_GREEN = 1, ///< The signal is green |
6248
0789677a15a0
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
rubidium <rubidium@openttd.org>
parents:
6182
diff
changeset
|
273 }; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
274 |
6753
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
275 /** |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
276 * Set the states of the signals (Along/AgainstTrackDir) |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
277 * @param tile the tile to set the states for |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
278 * @param state the new state |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
279 */ |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
280 static inline void SetSignalStates(TileIndex tile, uint state) |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
281 { |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
282 SB(_m[tile].m4, 4, 4, state); |
6753
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
283 } |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
284 |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
285 /** |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
286 * Set the states of the signals (Along/AgainstTrackDir) |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
287 * @param tile the tile to set the states for |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
288 * @param state the new state |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
289 */ |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
290 static inline uint GetSignalStates(TileIndex tile) |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
291 { |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
292 return GB(_m[tile].m4, 4, 4); |
6753
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
293 } |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
294 |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
295 /** |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
296 * Get the state of a single signal |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
297 * @param t the tile to get the signal state for |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
298 * @param signalbit the signal |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
299 * @return the state of the signal |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
300 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
301 static inline SignalState GetSingleSignalState(TileIndex t, byte signalbit) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
302 { |
7928
4e8dfd103163
(svn r11481) -Codechange: Rename the HASBIT function to fit with the naming style
skidd13 <skidd13@openttd.org>
parents:
7771
diff
changeset
|
303 return (SignalState)HasBit(GetSignalStates(t), signalbit); |
6753
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
304 } |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
305 |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
306 /** |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
307 * Set whether the given signals are present (Along/AgainstTrackDir) |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
308 * @param tile the tile to set the present signals for |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
309 * @param signals the signals that have to be present |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
310 */ |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
311 static inline void SetPresentSignals(TileIndex tile, uint signals) |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
312 { |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
313 SB(_m[tile].m3, 4, 4, signals); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
314 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
315 |
6753
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
316 /** |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
317 * Get whether the given signals are present (Along/AgainstTrackDir) |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
318 * @param tile the tile to get the present signals for |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
319 * @return the signals that are present |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
320 */ |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
321 static inline uint GetPresentSignals(TileIndex tile) |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
322 { |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
323 return GB(_m[tile].m3, 4, 4); |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
324 } |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
325 |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
326 /** |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
327 * Checks whether the given signals is present |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
328 * @param t the tile to check on |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
329 * @param signalbit the signal |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
330 * @return true if and only if the signal is present |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
331 */ |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
332 static inline bool IsSignalPresent(TileIndex t, byte signalbit) |
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
333 { |
7928
4e8dfd103163
(svn r11481) -Codechange: Rename the HASBIT function to fit with the naming style
skidd13 <skidd13@openttd.org>
parents:
7771
diff
changeset
|
334 return HasBit(GetPresentSignals(t), signalbit); |
6753
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
335 } |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
336 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
337 /** |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
338 * Checks for the presence of signals (either way) on the given track on the |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
339 * given rail tile. |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
340 */ |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
341 static inline bool HasSignalOnTrack(TileIndex tile, Track track) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
342 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
343 assert(IsValidTrack(track)); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
344 return |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
345 GetRailTileType(tile) == RAIL_TILE_SIGNALS && |
6753
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
346 (GetPresentSignals(tile) & SignalOnTrack(track)) != 0; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
347 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
348 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
349 /** |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
350 * Checks for the presence of signals along the given trackdir on the given |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
351 * rail tile. |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
352 * |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
353 * Along meaning if you are currently driving on the given trackdir, this is |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
354 * the signal that is facing us (for which we stop when it's red). |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
355 */ |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
356 static inline bool HasSignalOnTrackdir(TileIndex tile, Trackdir trackdir) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
357 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
358 assert (IsValidTrackdir(trackdir)); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
359 return |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
360 GetRailTileType(tile) == RAIL_TILE_SIGNALS && |
6753
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
361 GetPresentSignals(tile) & SignalAlongTrackdir(trackdir); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
362 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
363 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
364 /** |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
365 * Gets the state of the signal along the given trackdir. |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
366 * |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
367 * Along meaning if you are currently driving on the given trackdir, this is |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
368 * the signal that is facing us (for which we stop when it's red). |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
369 */ |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
370 static inline SignalState GetSignalStateByTrackdir(TileIndex tile, Trackdir trackdir) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
371 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
372 assert(IsValidTrackdir(trackdir)); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
373 assert(HasSignalOnTrack(tile, TrackdirToTrack(trackdir))); |
6753
72ae9d67f553
(svn r9988) -Codechange: remove the last direct map accesses, except the ones needed for the savegame saving/loading mechanisms.
rubidium <rubidium@openttd.org>
parents:
6540
diff
changeset
|
374 return GetSignalStates(tile) & SignalAlongTrackdir(trackdir) ? |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
375 SIGNAL_STATE_GREEN : SIGNAL_STATE_RED; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
376 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
377 |
8238
e9d8b0764f38
(svn r11802) -Fix [FS#716]: do not crash trains when leaving depot to a very long track
smatz <smatz@openttd.org>
parents:
8138
diff
changeset
|
378 /** |
e9d8b0764f38
(svn r11802) -Fix [FS#716]: do not crash trains when leaving depot to a very long track
smatz <smatz@openttd.org>
parents:
8138
diff
changeset
|
379 * Sets the state of the signal along the given trackdir. |
e9d8b0764f38
(svn r11802) -Fix [FS#716]: do not crash trains when leaving depot to a very long track
smatz <smatz@openttd.org>
parents:
8138
diff
changeset
|
380 */ |
e9d8b0764f38
(svn r11802) -Fix [FS#716]: do not crash trains when leaving depot to a very long track
smatz <smatz@openttd.org>
parents:
8138
diff
changeset
|
381 static inline void SetSignalStateByTrackdir(TileIndex tile, Trackdir trackdir, SignalState state) |
e9d8b0764f38
(svn r11802) -Fix [FS#716]: do not crash trains when leaving depot to a very long track
smatz <smatz@openttd.org>
parents:
8138
diff
changeset
|
382 { |
e9d8b0764f38
(svn r11802) -Fix [FS#716]: do not crash trains when leaving depot to a very long track
smatz <smatz@openttd.org>
parents:
8138
diff
changeset
|
383 if (state == SIGNAL_STATE_GREEN) { // set 1 |
e9d8b0764f38
(svn r11802) -Fix [FS#716]: do not crash trains when leaving depot to a very long track
smatz <smatz@openttd.org>
parents:
8138
diff
changeset
|
384 SetSignalStates(tile, GetSignalStates(tile) | SignalAlongTrackdir(trackdir)); |
e9d8b0764f38
(svn r11802) -Fix [FS#716]: do not crash trains when leaving depot to a very long track
smatz <smatz@openttd.org>
parents:
8138
diff
changeset
|
385 } else { |
e9d8b0764f38
(svn r11802) -Fix [FS#716]: do not crash trains when leaving depot to a very long track
smatz <smatz@openttd.org>
parents:
8138
diff
changeset
|
386 SetSignalStates(tile, GetSignalStates(tile) & ~SignalAlongTrackdir(trackdir)); |
e9d8b0764f38
(svn r11802) -Fix [FS#716]: do not crash trains when leaving depot to a very long track
smatz <smatz@openttd.org>
parents:
8138
diff
changeset
|
387 } |
e9d8b0764f38
(svn r11802) -Fix [FS#716]: do not crash trains when leaving depot to a very long track
smatz <smatz@openttd.org>
parents:
8138
diff
changeset
|
388 } |
e9d8b0764f38
(svn r11802) -Fix [FS#716]: do not crash trains when leaving depot to a very long track
smatz <smatz@openttd.org>
parents:
8138
diff
changeset
|
389 |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
390 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
391 /** |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
392 * Return the rail type of tile, or INVALID_RAILTYPE if this is no rail tile. |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
393 */ |
6154 | 394 RailType GetTileRailType(TileIndex tile); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
395 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
396 /** The ground 'under' the rail */ |
6248
0789677a15a0
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
rubidium <rubidium@openttd.org>
parents:
6182
diff
changeset
|
397 enum RailGroundType { |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
398 RAIL_GROUND_BARREN = 0, ///< Nothing (dirt) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
399 RAIL_GROUND_GRASS = 1, ///< Grassy |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
400 RAIL_GROUND_FENCE_NW = 2, ///< Grass with a fence at the NW edge |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
401 RAIL_GROUND_FENCE_SE = 3, ///< Grass with a fence at the SE edge |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
402 RAIL_GROUND_FENCE_SENW = 4, ///< Grass with a fence at the NW and SE edges |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
403 RAIL_GROUND_FENCE_NE = 5, ///< Grass with a fence at the NE edge |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
404 RAIL_GROUND_FENCE_SW = 6, ///< Grass with a fence at the SW edge |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
405 RAIL_GROUND_FENCE_NESW = 7, ///< Grass with a fence at the NE and SW edges |
7307
cf51670909bb
(svn r10659) -Codechange: updated documentation around RAIL_GROUND_FENCE_VERT[12] (frosch)
truelight <truelight@openttd.org>
parents:
6770
diff
changeset
|
406 RAIL_GROUND_FENCE_VERT1 = 8, ///< Grass with a fence at the eastern side |
cf51670909bb
(svn r10659) -Codechange: updated documentation around RAIL_GROUND_FENCE_VERT[12] (frosch)
truelight <truelight@openttd.org>
parents:
6770
diff
changeset
|
407 RAIL_GROUND_FENCE_VERT2 = 9, ///< Grass with a fence at the western side |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
408 RAIL_GROUND_FENCE_HORIZ1 = 10, ///< Grass with a fence at the southern side |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
409 RAIL_GROUND_FENCE_HORIZ2 = 11, ///< Grass with a fence at the northern side |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
410 RAIL_GROUND_ICE_DESERT = 12, ///< Icy or sandy |
7771
004a597e91a1
(svn r11320) -Codechange: make lower halftiles at coast floodable. Patch by frosch.
rubidium <rubidium@openttd.org>
parents:
7307
diff
changeset
|
411 RAIL_GROUND_WATER = 13, ///< Grass with a fence and water on the lower halftile |
6248
0789677a15a0
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
rubidium <rubidium@openttd.org>
parents:
6182
diff
changeset
|
412 }; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
413 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
414 static inline void SetRailGroundType(TileIndex t, RailGroundType rgt) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
415 { |
6172
b3b8cbc5e854
(svn r8935) -Codechange: unification of track type between road and rail tiles, unification of ground type between normal rail tiles and depots/waypoints and removing the need for RailTileSubType.
rubidium <rubidium@openttd.org>
parents:
6154
diff
changeset
|
416 SB(_m[t].m4, 0, 4, rgt); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
417 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
418 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
419 static inline RailGroundType GetRailGroundType(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
420 { |
6172
b3b8cbc5e854
(svn r8935) -Codechange: unification of track type between road and rail tiles, unification of ground type between normal rail tiles and depots/waypoints and removing the need for RailTileSubType.
rubidium <rubidium@openttd.org>
parents:
6154
diff
changeset
|
421 return (RailGroundType)GB(_m[t].m4, 0, 4); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
422 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
423 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
424 static inline bool IsSnowRailGround(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
425 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
426 return GetRailGroundType(t) == RAIL_GROUND_ICE_DESERT; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
427 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
428 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
429 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
430 static inline void MakeRailNormal(TileIndex t, Owner o, TrackBits b, RailType r) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
431 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
432 SetTileType(t, MP_RAILWAY); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
433 SetTileOwner(t, o); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
434 _m[t].m2 = 0; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
435 _m[t].m3 = r; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
436 _m[t].m4 = 0; |
6172
b3b8cbc5e854
(svn r8935) -Codechange: unification of track type between road and rail tiles, unification of ground type between normal rail tiles and depots/waypoints and removing the need for RailTileSubType.
rubidium <rubidium@openttd.org>
parents:
6154
diff
changeset
|
437 _m[t].m5 = RAIL_TILE_NORMAL << 6 | b; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
438 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
439 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
440 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
441 static inline void MakeRailDepot(TileIndex t, Owner o, DiagDirection d, RailType r) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
442 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
443 SetTileType(t, MP_RAILWAY); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
444 SetTileOwner(t, o); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
445 _m[t].m2 = 0; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
446 _m[t].m3 = r; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
447 _m[t].m4 = 0; |
6172
b3b8cbc5e854
(svn r8935) -Codechange: unification of track type between road and rail tiles, unification of ground type between normal rail tiles and depots/waypoints and removing the need for RailTileSubType.
rubidium <rubidium@openttd.org>
parents:
6154
diff
changeset
|
448 _m[t].m5 = RAIL_TILE_DEPOT << 6 | d; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
449 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
450 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
451 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
452 static inline void MakeRailWaypoint(TileIndex t, Owner o, Axis a, RailType r, uint index) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
453 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
454 SetTileType(t, MP_RAILWAY); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
455 SetTileOwner(t, o); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
456 _m[t].m2 = index; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
457 _m[t].m3 = r; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
458 _m[t].m4 = 0; |
6172
b3b8cbc5e854
(svn r8935) -Codechange: unification of track type between road and rail tiles, unification of ground type between normal rail tiles and depots/waypoints and removing the need for RailTileSubType.
rubidium <rubidium@openttd.org>
parents:
6154
diff
changeset
|
459 _m[t].m5 = RAIL_TILE_WAYPOINT << 6 | a; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
460 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
461 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
462 #endif /* RAIL_MAP_H */ |