Mercurial > hg > openttd
annotate src/rail_map.h @ 8954:454ba10a0cff draft
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
author | smatz <smatz@openttd.org> |
---|---|
date | Thu, 17 Apr 2008 00:44:20 +0000 |
parents | 8207d9e330cc |
children | c8a0fa0e208a |
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" |
8761
30b1c1db062a
(svn r12457) -Codechange: Move signal enums on their own header.
belugas <belugas@openttd.org>
parents:
8632
diff
changeset
|
13 #include "signal_type.h" |
8775
8207d9e330cc
(svn r12474) -Codechange: split type related stuff from waypoints from waypoint.h (and openttd.h) to waypoint_type.h.
rubidium <rubidium@openttd.org>
parents:
8761
diff
changeset
|
14 #include "waypoint_type.h" |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
15 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
16 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
17 /** 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
|
18 enum RailTileType { |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
19 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
|
20 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
|
21 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
|
22 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
|
23 }; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
24 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
25 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
26 * 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
|
27 * waypoint or depot). |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
28 * @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
|
29 * @pre IsTileType(t, MP_RAILWAY) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
30 * @return the RailTileType |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
31 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
32 static inline RailTileType GetRailTileType(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
33 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
34 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
|
35 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
|
36 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
37 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
38 /** |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
39 * 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
|
40 * 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
|
41 * @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
|
42 * @pre IsTileType(t, MP_RAILWAY) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
43 * @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
|
44 */ |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
45 static inline bool IsPlainRailTile(TileIndex t) |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
46 { |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
47 RailTileType rtt = GetRailTileType(t); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
48 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
|
49 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
50 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
51 /** |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
52 * 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
|
53 * @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
|
54 * @pre IsTileType(t, MP_RAILWAY) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
55 * @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
|
56 */ |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
57 static inline bool HasSignals(TileIndex t) |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
58 { |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
59 return GetRailTileType(t) == RAIL_TILE_SIGNALS; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
60 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
61 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
62 /** |
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
|
63 * 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
|
64 * @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
|
65 * @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
|
66 * @pre IsPlainRailTile(tile) |
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 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
|
69 { |
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
|
70 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
|
71 SB(_m[tile].m5, 6, 1, signals); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
72 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
73 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
74 /** |
8954
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
75 * Is this rail tile a rail waypoint? |
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
76 * @param t the tile to get the information from |
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
77 * @pre IsTileType(t, MP_RAILWAY) |
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
78 * @return true if and only if the tile is a rail waypoint |
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
79 */ |
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
80 static inline bool IsRailWaypoint(TileIndex t) |
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
81 { |
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
82 return GetRailTileType(t) == RAIL_TILE_WAYPOINT; |
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
83 } |
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
84 |
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
85 /** |
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
86 * Is this rail tile a rail depot? |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
87 * @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
|
88 * @pre IsTileType(t, MP_RAILWAY) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
89 * @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
|
90 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
91 static inline bool IsRailDepot(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
92 { |
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
|
93 return GetRailTileType(t) == RAIL_TILE_DEPOT; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
94 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
95 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
96 /** |
8954
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
97 * Is this tile rail tile and a rail depot? |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
98 * @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
|
99 * @pre IsTileType(t, MP_RAILWAY) |
8954
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
100 * @return true if and only if the tile is a rail depot |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
101 */ |
8954
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
102 static inline bool IsRailDepotTile(TileIndex t) |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
103 { |
8954
454ba10a0cff
(svn r12745) -Codechange: a bit of naming conventions, introduce Is*DepotTile()
smatz <smatz@openttd.org>
parents:
8775
diff
changeset
|
104 return IsTileType(t, MP_RAILWAY) && IsRailDepot(t); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
105 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
106 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
107 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
108 * 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
|
109 * @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
|
110 * @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
|
111 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
112 static inline RailType GetRailType(TileIndex t) |
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 return (RailType)GB(_m[t].m3, 0, 4); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
115 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
116 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
117 /** |
8632
fdd5fc74ffa0
(svn r12239) -Fix [FS#1800] (r9729): inverted comments for SetRailType() and GetTrackBits() (michi_cc)
glx <glx@openttd.org>
parents:
8523
diff
changeset
|
118 * Sets the rail type of the given tile |
fdd5fc74ffa0
(svn r12239) -Fix [FS#1800] (r9729): inverted comments for SetRailType() and GetTrackBits() (michi_cc)
glx <glx@openttd.org>
parents:
8523
diff
changeset
|
119 * @param t the tile to set the rail type of |
fdd5fc74ffa0
(svn r12239) -Fix [FS#1800] (r9729): inverted comments for SetRailType() and GetTrackBits() (michi_cc)
glx <glx@openttd.org>
parents:
8523
diff
changeset
|
120 * @param r the new rail type for the tile |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
121 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
122 static inline void SetRailType(TileIndex t, RailType r) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
123 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
124 SB(_m[t].m3, 0, 4, r); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
125 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
126 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
127 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
128 /** |
8632
fdd5fc74ffa0
(svn r12239) -Fix [FS#1800] (r9729): inverted comments for SetRailType() and GetTrackBits() (michi_cc)
glx <glx@openttd.org>
parents:
8523
diff
changeset
|
129 * Gets the track bits of the given tile |
fdd5fc74ffa0
(svn r12239) -Fix [FS#1800] (r9729): inverted comments for SetRailType() and GetTrackBits() (michi_cc)
glx <glx@openttd.org>
parents:
8523
diff
changeset
|
130 * @param t the tile to get the track bits from |
fdd5fc74ffa0
(svn r12239) -Fix [FS#1800] (r9729): inverted comments for SetRailType() and GetTrackBits() (michi_cc)
glx <glx@openttd.org>
parents:
8523
diff
changeset
|
131 * @return the track bits of the tile |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
132 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
133 static inline TrackBits GetTrackBits(TileIndex tile) |
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 return (TrackBits)GB(_m[tile].m5, 0, 6); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
136 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
137 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
138 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
139 * 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
|
140 * @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
|
141 * @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
|
142 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
143 static inline void SetTrackBits(TileIndex t, TrackBits b) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
144 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
145 SB(_m[t].m5, 0, 6, b); |
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 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
148 /** |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
149 * 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
|
150 * @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
|
151 * @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
|
152 * @pre IsPlainRailTile(tile) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
153 * @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
|
154 */ |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
155 static inline bool HasTrack(TileIndex tile, Track track) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
156 { |
7928
4e8dfd103163
(svn r11481) -Codechange: Rename the HASBIT function to fit with the naming style
skidd13 <skidd13@openttd.org>
parents:
7771
diff
changeset
|
157 return HasBit(GetTrackBits(tile), track); |
5475
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 direction the depot is facing to |
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 depot facing from |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
163 * @pre IsRailDepotTile(t) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
164 * @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
|
165 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
166 static inline DiagDirection GetRailDepotDirection(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 (DiagDirection)GB(_m[t].m5, 0, 2); |
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 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
171 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
172 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
173 * Returns the axis of the waypoint |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
174 * @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
|
175 * @pre IsRailWaypointTile(t) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
176 * @return the axis of the waypoint |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
177 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
178 static inline Axis GetWaypointAxis(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
179 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
180 return (Axis)GB(_m[t].m5, 0, 1); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
181 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
182 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
183 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
184 * Returns the track of the waypoint |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
185 * @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
|
186 * @pre IsRailWaypointTile(t) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
187 * @return the track of the waypoint |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
188 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
189 static inline Track GetRailWaypointTrack(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
190 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
191 return AxisToTrack(GetWaypointAxis(t)); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
192 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
193 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
194 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
195 * 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
|
196 * @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
|
197 * @pre IsRailWaypointTile(t) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
198 * @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
|
199 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
200 static inline TrackBits GetRailWaypointBits(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
201 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
202 return TrackToTrackBits(GetRailWaypointTrack(t)); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
203 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
204 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
205 /** |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
206 * 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
|
207 * @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
|
208 * @pre IsRailWaypointTile(t) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
209 * @return the waypoint index |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
210 */ |
6182
e1626f2e63ad
(svn r8954) -Codechange: remove direct map accesses from non-map-accessor headers.
rubidium <rubidium@openttd.org>
parents:
6172
diff
changeset
|
211 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
|
212 { |
e1626f2e63ad
(svn r8954) -Codechange: remove direct map accesses from non-map-accessor headers.
rubidium <rubidium@openttd.org>
parents:
6172
diff
changeset
|
213 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
|
214 } |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
215 |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
216 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
|
217 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
218 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
|
219 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
|
220 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
|
221 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
222 |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
223 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
|
224 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
225 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
|
226 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
|
227 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
|
228 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
|
229 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
230 |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
231 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
|
232 { |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
233 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
|
234 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
235 |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
236 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
|
237 { |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
238 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
|
239 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
240 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
241 static inline void CycleSignalSide(TileIndex t, Track track) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
242 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
243 byte sig; |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
244 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
|
245 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
246 sig = GB(_m[t].m3, pos, 2); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
247 if (--sig == 0) sig = 3; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
248 SB(_m[t].m3, pos, 2, sig); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
249 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
250 |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
251 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
|
252 { |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
253 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
|
254 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
|
255 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
256 |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
257 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
|
258 { |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
259 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
|
260 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
|
261 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
|
262 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
263 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
264 /** 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
|
265 * 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
|
266 * 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
|
267 */ |
6248
0789677a15a0
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
rubidium <rubidium@openttd.org>
parents:
6182
diff
changeset
|
268 enum SignalState { |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
269 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
|
270 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
|
271 }; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
272 |
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
|
273 /** |
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
|
274 * 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
|
275 * @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
|
276 * @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
|
277 */ |
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 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
|
279 { |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
280 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
|
281 } |
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
|
282 |
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 * 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
|
285 * @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
|
286 * @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
|
287 */ |
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 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
|
289 { |
6770
93b0e6996fcc
(svn r10006) -Fix (FS#362): allow different signal types on one tile
glx <glx@openttd.org>
parents:
6753
diff
changeset
|
290 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
|
291 } |
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
|
292 |
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 * 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
|
295 * @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
|
296 * @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
|
297 * @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
|
298 */ |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
299 static inline SignalState GetSingleSignalState(TileIndex t, byte signalbit) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
300 { |
7928
4e8dfd103163
(svn r11481) -Codechange: Rename the HASBIT function to fit with the naming style
skidd13 <skidd13@openttd.org>
parents:
7771
diff
changeset
|
301 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
|
302 } |
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
|
303 |
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 * 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
|
306 * @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
|
307 * @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
|
308 */ |
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 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
|
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 SB(_m[tile].m3, 4, 4, signals); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
312 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
313 |
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
|
314 /** |
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
|
315 * 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
|
316 * @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
|
317 * @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
|
318 */ |
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 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
|
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 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
|
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 |
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 * 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
|
326 * @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
|
327 * @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
|
328 * @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
|
329 */ |
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 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
|
331 { |
7928
4e8dfd103163
(svn r11481) -Codechange: Rename the HASBIT function to fit with the naming style
skidd13 <skidd13@openttd.org>
parents:
7771
diff
changeset
|
332 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
|
333 } |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
334 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
335 /** |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
336 * 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
|
337 * given rail tile. |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
338 */ |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
339 static inline bool HasSignalOnTrack(TileIndex tile, Track track) |
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 assert(IsValidTrack(track)); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
342 return |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
343 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
|
344 (GetPresentSignals(tile) & SignalOnTrack(track)) != 0; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
345 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
346 |
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 * 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
|
349 * rail tile. |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
350 * |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
351 * 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
|
352 * 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
|
353 */ |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
354 static inline bool HasSignalOnTrackdir(TileIndex tile, Trackdir trackdir) |
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 assert (IsValidTrackdir(trackdir)); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
357 return |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
358 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
|
359 GetPresentSignals(tile) & SignalAlongTrackdir(trackdir); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
360 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
361 |
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 * 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
|
364 * |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
365 * 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
|
366 * 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
|
367 */ |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
368 static inline SignalState GetSignalStateByTrackdir(TileIndex tile, Trackdir trackdir) |
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 assert(IsValidTrackdir(trackdir)); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
371 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
|
372 return GetSignalStates(tile) & SignalAlongTrackdir(trackdir) ? |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
373 SIGNAL_STATE_GREEN : SIGNAL_STATE_RED; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
374 } |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
375 |
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
|
376 /** |
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
|
377 * 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
|
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 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
|
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 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
|
382 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
|
383 } 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
|
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 } |
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 } |
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 |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
388 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
389 /** |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
390 * 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
|
391 */ |
6154 | 392 RailType GetTileRailType(TileIndex tile); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
393 |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
394 /** 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
|
395 enum RailGroundType { |
6540
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
396 RAIL_GROUND_BARREN = 0, ///< Nothing (dirt) |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
397 RAIL_GROUND_GRASS = 1, ///< Grassy |
b71c1ad2239c
(svn r9729) -Documentation: add some documentation in various places
rubidium <rubidium@openttd.org>
parents:
6393
diff
changeset
|
398 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
|
399 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
|
400 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
|
401 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
|
402 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
|
403 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
|
404 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
|
405 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
|
406 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
|
407 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
|
408 RAIL_GROUND_ICE_DESERT = 12, ///< Icy or sandy |
8414
124ea89a5409
(svn r11984) -Fix: Also draw corner shores under rail tracks.
frosch <frosch@openttd.org>
parents:
8238
diff
changeset
|
409 RAIL_GROUND_WATER = 13, ///< Grass with a fence and shore or water on the free halftile |
8523
76d0527eea17
(svn r12098) -Fix: make snow appear on rail tiles dependant on track height, not on height of the lowest part of the tile
smatz <smatz@openttd.org>
parents:
8414
diff
changeset
|
410 RAIL_GROUND_HALF_SNOW = 14, ///< Snow only on higher part of slope (steep or one corner raised) |
6248
0789677a15a0
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
rubidium <rubidium@openttd.org>
parents:
6182
diff
changeset
|
411 }; |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
412 |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
413 static inline void SetRailGroundType(TileIndex t, RailGroundType rgt) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
414 { |
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
|
415 SB(_m[t].m4, 0, 4, rgt); |
5475
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
416 } |
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 static inline RailGroundType GetRailGroundType(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
419 { |
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
|
420 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
|
421 } |
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 static inline bool IsSnowRailGround(TileIndex t) |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
424 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
425 return GetRailGroundType(t) == RAIL_GROUND_ICE_DESERT; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
426 } |
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 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
|
430 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
431 SetTileType(t, MP_RAILWAY); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
432 SetTileOwner(t, o); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
433 _m[t].m2 = 0; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
434 _m[t].m3 = r; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
435 _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
|
436 _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
|
437 } |
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 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
|
441 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
442 SetTileType(t, MP_RAILWAY); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
443 SetTileOwner(t, o); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
444 _m[t].m2 = 0; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
445 _m[t].m3 = r; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
446 _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
|
447 _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
|
448 } |
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 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
|
452 { |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
453 SetTileType(t, MP_RAILWAY); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
454 SetTileOwner(t, o); |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
455 _m[t].m2 = index; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
456 _m[t].m3 = r; |
eabf4b86aed6
(svn r7759) -Merge: makefile rewrite. This merge features:
rubidium <rubidium@openttd.org>
parents:
diff
changeset
|
457 _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
|
458 _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
|
459 } |
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 #endif /* RAIL_MAP_H */ |