2 * This file is part of OpenTTD.
3 * OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
4 * OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
5 * See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <http://www.gnu.org/licenses/>.
9 * @file elrail_data.h Stores all the data for overhead wire and pylon drawing.
17 * Tile Location group.
18 * This defines whether the X and or Y coordinate of a tile is even
29 * When determining the pylon configuration on the edge, two tiles are taken
30 * into account: the tile being drawn itself (the home tile, the one in
31 * ti->tile), and the neighbouring tile
40 static const uint NUM_TRACKS_AT_PCP
= 6;
42 /** Which PPPs are possible at all on a given PCP */
43 static const uint8_t AllowedPPPonPCP
[DIAGDIR_END
] = {
44 1 << DIR_N
| 1 << DIR_E
| 1 << DIR_SE
| 1 << DIR_S
| 1 << DIR_W
| 1 << DIR_NW
,
45 1 << DIR_N
| 1 << DIR_NE
| 1 << DIR_E
| 1 << DIR_S
| 1 << DIR_SW
| 1 << DIR_W
,
46 1 << DIR_N
| 1 << DIR_E
| 1 << DIR_SE
| 1 << DIR_S
| 1 << DIR_W
| 1 << DIR_NW
,
47 1 << DIR_N
| 1 << DIR_NE
| 1 << DIR_E
| 1 << DIR_S
| 1 << DIR_SW
| 1 << DIR_W
,
51 * Which of the PPPs are inside the tile. For the two PPPs on the tile border
52 * the following system is used: if you rotate the PCP so that it is in the
53 * north, the eastern PPP belongs to the tile.
55 static const uint8_t OwnedPPPonPCP
[DIAGDIR_END
] = {
56 1 << DIR_SE
| 1 << DIR_S
| 1 << DIR_SW
| 1 << DIR_W
,
57 1 << DIR_N
| 1 << DIR_SW
| 1 << DIR_W
| 1 << DIR_NW
,
58 1 << DIR_N
| 1 << DIR_NE
| 1 << DIR_E
| 1 << DIR_NW
,
59 1 << DIR_NE
| 1 << DIR_E
| 1 << DIR_SE
| 1 << DIR_S
62 /** Maps a track bit onto two PCP positions */
63 static const DiagDirection PCPpositions
[TRACK_END
][2] = {
64 {DIAGDIR_NE
, DIAGDIR_SW
}, // X
65 {DIAGDIR_SE
, DIAGDIR_NW
}, // Y
66 {DIAGDIR_NW
, DIAGDIR_NE
}, // UPPER
67 {DIAGDIR_SE
, DIAGDIR_SW
}, // LOWER
68 {DIAGDIR_SW
, DIAGDIR_NW
}, // LEFT
69 {DIAGDIR_NE
, DIAGDIR_SE
}, // RIGHT
72 #define PCP_NOT_ON_TRACK 0xFF
74 * Preferred points of each trackbit. Those are the ones perpendicular to the
75 * track, plus the point in extension of the track (to mark end-of-track). PCPs
76 * which are not on either end of the track are fully preferred.
79 static const uint8_t PreferredPPPofTrackAtPCP
[TRACK_END
][DIAGDIR_END
] = {
81 1 << DIR_NE
| 1 << DIR_SE
| 1 << DIR_NW
, // NE
82 PCP_NOT_ON_TRACK
, // SE
83 1 << DIR_SE
| 1 << DIR_SW
| 1 << DIR_NW
, // SW
84 PCP_NOT_ON_TRACK
// NE
87 1 << DIR_NE
| 1 << DIR_SE
| 1 << DIR_SW
,
89 1 << DIR_SW
| 1 << DIR_NW
| 1 << DIR_NE
91 1 << DIR_E
| 1 << DIR_N
| 1 << DIR_S
,
94 1 << DIR_W
| 1 << DIR_N
| 1 << DIR_S
97 1 << DIR_E
| 1 << DIR_N
| 1 << DIR_S
,
98 1 << DIR_W
| 1 << DIR_N
| 1 << DIR_S
,
103 1 << DIR_S
| 1 << DIR_E
| 1 << DIR_W
,
104 1 << DIR_N
| 1 << DIR_E
| 1 << DIR_W
106 1 << DIR_N
| 1 << DIR_E
| 1 << DIR_W
,
107 1 << DIR_S
| 1 << DIR_E
| 1 << DIR_W
,
112 #undef PCP_NOT_ON_TRACK
115 #define NUM_IGNORE_GROUPS 3
116 #define IGNORE_NONE 0xFF
118 * In case we have a straight line, we place pylon only every two tiles,
119 * so there are certain tiles which we ignore. A straight line is found if
120 * we have exactly two PPPs.
122 static const uint8_t IgnoredPCP
[NUM_IGNORE_GROUPS
][TLG_END
][DIAGDIR_END
] = {
123 { // Ignore group 1, X and Y tracks
126 1 << DIR_NE
| 1 << DIR_SW
,
127 1 << DIR_NW
| 1 << DIR_SE
,
129 }, { // X even, Y odd
132 1 << DIR_NW
| 1 << DIR_SE
,
133 1 << DIR_NE
| 1 << DIR_SW
134 }, { // X odd, Y even
135 1 << DIR_NW
| 1 << DIR_SE
,
136 1 << DIR_NE
| 1 << DIR_SW
,
140 1 << DIR_NW
| 1 << DIR_SE
,
143 1 << DIR_NE
| 1 << DIR_SW
146 { // Ignore group 2, LEFT and RIGHT tracks
148 1 << DIR_E
| 1 << DIR_W
,
151 1 << DIR_E
| 1 << DIR_W
154 1 << DIR_E
| 1 << DIR_W
,
155 1 << DIR_E
| 1 << DIR_W
,
159 1 << DIR_E
| 1 << DIR_W
,
160 1 << DIR_E
| 1 << DIR_W
,
163 1 << DIR_E
| 1 << DIR_W
,
166 1 << DIR_E
| 1 << DIR_W
169 { // Ignore group 3, UPPER and LOWER tracks
171 1 << DIR_N
| 1 << DIR_S
,
172 1 << DIR_N
| 1 << DIR_S
,
178 1 << DIR_N
| 1 << DIR_S
,
179 1 << DIR_N
| 1 << DIR_S
183 1 << DIR_N
| 1 << DIR_S
,
184 1 << DIR_N
| 1 << DIR_S
186 1 << DIR_N
| 1 << DIR_S
,
187 1 << DIR_N
| 1 << DIR_S
,
196 /** Which pylons can definitely NOT be built */
197 static const uint8_t DisallowedPPPofTrackAtPCP
[TRACK_END
][DIAGDIR_END
] = {
198 {1 << DIR_SW
| 1 << DIR_NE
, 0, 1 << DIR_SW
| 1 << DIR_NE
, 0 }, // X
199 {0, 1 << DIR_NW
| 1 << DIR_SE
, 0, 1 << DIR_NW
| 1 << DIR_SE
}, // Y
200 {1 << DIR_W
| 1 << DIR_E
, 0, 0, 1 << DIR_W
| 1 << DIR_E
}, // UPPER
201 {0, 1 << DIR_W
| 1 << DIR_E
, 1 << DIR_W
| 1 << DIR_E
, 0 }, // LOWER
202 {0, 0, 1 << DIR_S
| 1 << DIR_N
, 1 << DIR_N
| 1 << DIR_S
}, // LEFT
203 {1 << DIR_S
| 1 << DIR_N
, 1 << DIR_S
| 1 << DIR_N
, 0, 0, }, // RIGHT
206 /* This array stores which track bits can meet at a tile edge */
207 static const Track TracksAtPCP
[DIAGDIR_END
][NUM_TRACKS_AT_PCP
] = {
208 {TRACK_X
, TRACK_X
, TRACK_UPPER
, TRACK_LOWER
, TRACK_LEFT
, TRACK_RIGHT
},
209 {TRACK_Y
, TRACK_Y
, TRACK_UPPER
, TRACK_LOWER
, TRACK_LEFT
, TRACK_RIGHT
},
210 {TRACK_X
, TRACK_X
, TRACK_UPPER
, TRACK_LOWER
, TRACK_LEFT
, TRACK_RIGHT
},
211 {TRACK_Y
, TRACK_Y
, TRACK_UPPER
, TRACK_LOWER
, TRACK_LEFT
, TRACK_RIGHT
},
214 /* takes each of the 6 track bits from the array above and
215 * assigns it to the home tile or neighbour tile */
216 static const TileSource TrackSourceTile
[DIAGDIR_END
][NUM_TRACKS_AT_PCP
] = {
217 {TS_HOME
, TS_NEIGHBOUR
, TS_HOME
, TS_NEIGHBOUR
, TS_NEIGHBOUR
, TS_HOME
},
218 {TS_HOME
, TS_NEIGHBOUR
, TS_NEIGHBOUR
, TS_HOME
, TS_NEIGHBOUR
, TS_HOME
},
219 {TS_HOME
, TS_NEIGHBOUR
, TS_NEIGHBOUR
, TS_HOME
, TS_HOME
, TS_NEIGHBOUR
},
220 {TS_HOME
, TS_NEIGHBOUR
, TS_HOME
, TS_NEIGHBOUR
, TS_HOME
, TS_NEIGHBOUR
},
223 /* Several PPPs maybe exist, here they are sorted in order of preference. */
224 static const Direction PPPorder
[DIAGDIR_END
][TLG_END
][DIR_END
] = { // X - Y
226 {DIR_NE
, DIR_NW
, DIR_SE
, DIR_SW
, DIR_N
, DIR_E
, DIR_S
, DIR_W
}, // evn - evn
227 {DIR_NE
, DIR_SE
, DIR_SW
, DIR_NW
, DIR_S
, DIR_W
, DIR_N
, DIR_E
}, // evn - odd
228 {DIR_SW
, DIR_NW
, DIR_NE
, DIR_SE
, DIR_S
, DIR_W
, DIR_N
, DIR_E
}, // odd - evn
229 {DIR_SW
, DIR_SE
, DIR_NE
, DIR_NW
, DIR_N
, DIR_E
, DIR_S
, DIR_W
}, // odd - odd
231 {DIR_NE
, DIR_NW
, DIR_SE
, DIR_SW
, DIR_S
, DIR_E
, DIR_N
, DIR_W
}, // evn - evn
232 {DIR_NE
, DIR_SE
, DIR_SW
, DIR_NW
, DIR_N
, DIR_W
, DIR_S
, DIR_E
}, // evn - odd
233 {DIR_SW
, DIR_NW
, DIR_NE
, DIR_SE
, DIR_N
, DIR_W
, DIR_S
, DIR_E
}, // odd - evn
234 {DIR_SW
, DIR_SE
, DIR_NE
, DIR_NW
, DIR_S
, DIR_E
, DIR_N
, DIR_W
}, // odd - odd
236 {DIR_NE
, DIR_NW
, DIR_SE
, DIR_SW
, DIR_S
, DIR_W
, DIR_N
, DIR_E
}, // evn - evn
237 {DIR_NE
, DIR_SE
, DIR_SW
, DIR_NW
, DIR_N
, DIR_E
, DIR_S
, DIR_W
}, // evn - odd
238 {DIR_SW
, DIR_NW
, DIR_NE
, DIR_SE
, DIR_N
, DIR_E
, DIR_S
, DIR_W
}, // odd - evn
239 {DIR_SW
, DIR_SE
, DIR_NE
, DIR_NW
, DIR_S
, DIR_W
, DIR_N
, DIR_E
}, // odd - odd
241 {DIR_NE
, DIR_NW
, DIR_SE
, DIR_SW
, DIR_N
, DIR_W
, DIR_S
, DIR_E
}, // evn - evn
242 {DIR_NE
, DIR_SE
, DIR_SW
, DIR_NW
, DIR_S
, DIR_E
, DIR_N
, DIR_W
}, // evn - odd
243 {DIR_SW
, DIR_NW
, DIR_NE
, DIR_SE
, DIR_S
, DIR_E
, DIR_N
, DIR_W
}, // odd - evn
244 {DIR_SW
, DIR_SE
, DIR_NE
, DIR_NW
, DIR_N
, DIR_W
, DIR_S
, DIR_E
}, // odd - odd
247 /* Geometric placement of the PCP relative to the tile origin */
248 static const int8_t x_pcp_offsets
[DIAGDIR_END
] = {0, 8, 16, 8};
249 static const int8_t y_pcp_offsets
[DIAGDIR_END
] = {8, 16, 8, 0};
250 /* Geometric placement of the PPP relative to the PCP*/
251 static const int8_t x_ppp_offsets
[DIR_END
] = {-2, -4, -2, 0, 2, 4, 2, 0};
252 static const int8_t y_ppp_offsets
[DIR_END
] = {-2, 0, 2, 4, 2, 0, -2, -4};
255 * Offset for pylon sprites from the base pylon sprite.
257 enum PylonSpriteOffset
{
268 /* The type of pylon to draw at each PPP */
269 static const uint8_t pylon_sprites
[] = {
281 * Offset for wire sprites from the base wire sprite.
283 enum WireSpriteOffset
{
317 struct SortableSpriteStruct
{
318 uint8_t image_offset
;
327 /** Distance between wire and rail */
328 static const uint ELRAIL_ELEVATION
= 10;
329 /** Wires that a draw one level higher than the north corner. */
330 static const uint ELRAIL_ELEVRAISE
= ELRAIL_ELEVATION
+ TILE_HEIGHT
+ 1;
331 /** Wires that a draw one level lower than the north corner. */
332 static const uint ELRAIL_ELEVLOWER
= ELRAIL_ELEVATION
- 1;
334 static const SortableSpriteStruct RailCatenarySpriteData
[] = {
338 { WSO_X_SW
, 0, 7, 15, 1, 1, ELRAIL_ELEVATION
}, //! 0: Wire in X direction, pylon on the SW end only
339 { WSO_X_NE
, 0, 7, 15, 1, 1, ELRAIL_ELEVATION
}, //! 1: Wire in X direction, pylon on the NE end
340 { WSO_X_SHORT
, 0, 7, 15, 1, 1, ELRAIL_ELEVATION
}, //! 2: Wire in X direction, pylon on both ends
344 { WSO_X_SW_UP
, 0, 7, 15, 8, 1, ELRAIL_ELEVRAISE
}, //! 3: Wire in X pitch up, pylon on the SW end only
345 { WSO_X_NE_UP
, 0, 7, 15, 8, 1, ELRAIL_ELEVRAISE
}, //! 4: Wire in X pitch up, pylon on the NE end
346 { WSO_X_SHORT_UP
, 0, 7, 15, 8, 1, ELRAIL_ELEVRAISE
}, //! 5: Wire in X pitch up, pylon on both ends
350 { WSO_X_SW_DOWN
, 0, 7, 15, 8, 1, ELRAIL_ELEVLOWER
}, //! 6: Wire in X pitch down, pylon on the SW end
351 { WSO_X_NE_DOWN
, 0, 7, 15, 8, 1, ELRAIL_ELEVLOWER
}, //! 7: Wire in X pitch down, pylon on the NE end
352 { WSO_X_SHORT_DOWN
, 0, 7, 15, 8, 1, ELRAIL_ELEVLOWER
}, //! 8: Wire in X pitch down, pylon on both ends
358 { WSO_Y_SE
, 7, 0, 1, 15, 1, ELRAIL_ELEVATION
}, //! 9: Wire in Y direction, pylon on the SE end only
359 { WSO_Y_NW
, 7, 0, 1, 15, 1, ELRAIL_ELEVATION
}, //!10: Wire in Y direction, pylon on the NW end
360 { WSO_Y_SHORT
, 7, 0, 1, 15, 1, ELRAIL_ELEVATION
}, //!11: Wire in Y direction, pylon on both ends
364 { WSO_Y_SE_UP
, 7, 0, 8, 15, 1, ELRAIL_ELEVRAISE
}, //!12: Wire in Y pitch up, pylon on the SE end only
365 { WSO_Y_NW_UP
, 7, 0, 8, 15, 1, ELRAIL_ELEVRAISE
}, //!13: Wire in Y pitch up, pylon on the NW end
366 { WSO_Y_SHORT_UP
, 7, 0, 8, 15, 1, ELRAIL_ELEVRAISE
}, //!14: Wire in Y pitch up, pylon on both ends
370 { WSO_Y_SE_DOWN
, 7, 0, 8, 15, 1, ELRAIL_ELEVLOWER
}, //!15: Wire in Y pitch down, pylon on the SE end
371 { WSO_Y_NW_DOWN
, 7, 0, 8, 15, 1, ELRAIL_ELEVLOWER
}, //!16: Wire in Y pitch down, pylon on the NW end
372 { WSO_Y_SHORT_DOWN
, 7, 0, 8, 15, 1, ELRAIL_ELEVLOWER
}, //!17: Wire in Y pitch down, pylon on both ends
375 { WSO_NS_SHORT
, 8, 0, 8, 8, 1, ELRAIL_ELEVATION
}, //!18: LEFT trackbit wire, pylon on both ends
376 { WSO_NS_SHORT
, 0, 8, 8, 8, 1, ELRAIL_ELEVATION
}, //!19: RIGHT trackbit wire, pylon on both ends
378 { WSO_NS_N
, 8, 0, 8, 8, 1, ELRAIL_ELEVATION
}, //!20: LEFT trackbit wire, pylon on N end
379 { WSO_NS_N
, 0, 8, 8, 8, 1, ELRAIL_ELEVATION
}, //!21: RIGHT trackbit wire, pylon on N end
381 { WSO_NS_S
, 8, 0, 8, 8, 1, ELRAIL_ELEVATION
}, //!22: LEFT trackbit wire, pylon on S end
382 { WSO_NS_S
, 0, 8, 8, 8, 1, ELRAIL_ELEVATION
}, //!23: RIGHT trackbit wire, pylon on S end
385 { WSO_EW_SHORT
, 7, 0, 1, 1, 1, ELRAIL_ELEVATION
}, //!24: UPPER trackbit wire, pylon on both ends
386 { WSO_EW_SHORT
, 15, 8, 3, 3, 1, ELRAIL_ELEVATION
}, //!25: LOWER trackbit wire, pylon on both ends
388 { WSO_EW_W
, 7, 0, 1, 1, 1, ELRAIL_ELEVATION
}, //!28: UPPER trackbit wire, pylon on both ends
389 { WSO_EW_W
, 15, 8, 3, 3, 1, ELRAIL_ELEVATION
}, //!29: LOWER trackbit wire, pylon on both ends
391 { WSO_EW_E
, 7, 0, 1, 1, 1, ELRAIL_ELEVATION
}, //!32: UPPER trackbit wire, pylon on both ends
392 { WSO_EW_E
, 15, 8, 3, 3, 1, ELRAIL_ELEVATION
} //!33: LOWER trackbit wire, pylon on both ends
395 static const SortableSpriteStruct RailCatenarySpriteData_Depot
[] = {
396 { WSO_ENTRANCE_NE
, 0, 7, 15, 1, 1, ELRAIL_ELEVATION
}, //! Wire for NE depot exit
397 { WSO_ENTRANCE_SE
, 7, 0, 1, 15, 1, ELRAIL_ELEVATION
}, //! Wire for SE depot exit
398 { WSO_ENTRANCE_SW
, 0, 7, 15, 1, 1, ELRAIL_ELEVATION
}, //! Wire for SW depot exit
399 { WSO_ENTRANCE_NW
, 7, 0, 1, 15, 1, ELRAIL_ELEVATION
} //! Wire for NW depot exit
402 static const SortableSpriteStruct RailCatenarySpriteData_Tunnel
[] = {
403 { WSO_ENTRANCE_SW
, 0, 7, 15, 1, 1, ELRAIL_ELEVATION
}, //! Wire for NE tunnel (SW facing exit)
404 { WSO_ENTRANCE_NW
, 7, 0, 1, 15, 1, ELRAIL_ELEVATION
}, //! Wire for SE tunnel (NW facing exit)
405 { WSO_ENTRANCE_NE
, 0, 7, 15, 1, 1, ELRAIL_ELEVATION
}, //! Wire for SW tunnel (NE facing exit)
406 { WSO_ENTRANCE_SE
, 7, 0, 1, 15, 1, ELRAIL_ELEVATION
} //! Wire for NW tunnel (SE facing exit)
411 * Refers to a certain element of the catenary.
412 * Identifiers for Wires:
413 * <ol><li>Direction of the wire</li>
414 * <li>Slope of the tile for diagonals, placement inside the track for horiz/vertical pieces</li>
415 * <li>Place where a pylon should be</li></ol>
416 * Identifiers for Pylons:
417 * <ol><li>Direction of the wire</li>
418 * <li>Slope of the tile</li>
419 * <li>Position of the Pylon relative to the track</li>
420 * <li>Position of the Pylon inside the tile</li></ol>
422 enum RailCatenarySprite
{
465 INVALID_CATENARY
= 0xFF
468 /* Selects a Wire (with white and grey ends) depending on whether:
469 * a) none (should never happen)
474 static const RailCatenarySprite Wires
[5][TRACK_END
][4] = {
476 {INVALID_CATENARY
, WIRE_X_FLAT_NE
, WIRE_X_FLAT_SW
, WIRE_X_FLAT_BOTH
},
477 {INVALID_CATENARY
, WIRE_Y_FLAT_SE
, WIRE_Y_FLAT_NW
, WIRE_Y_FLAT_BOTH
},
478 {INVALID_CATENARY
, WIRE_EW_N_W
, WIRE_EW_N_E
, WIRE_EW_N_BOTH
},
479 {INVALID_CATENARY
, WIRE_EW_S_E
, WIRE_EW_S_W
, WIRE_EW_S_BOTH
},
480 {INVALID_CATENARY
, WIRE_NS_W_S
, WIRE_NS_W_N
, WIRE_NS_W_BOTH
},
481 {INVALID_CATENARY
, WIRE_NS_E_N
, WIRE_NS_E_S
, WIRE_NS_E_BOTH
},
483 {INVALID_CATENARY
, WIRE_X_UP_NE
, WIRE_X_UP_SW
, WIRE_X_UP_BOTH
},
484 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
485 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
486 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
487 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
488 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
490 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
491 {INVALID_CATENARY
, WIRE_Y_UP_SE
, WIRE_Y_UP_NW
, WIRE_Y_UP_BOTH
},
492 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
493 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
494 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
495 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
497 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
498 {INVALID_CATENARY
, WIRE_Y_DOWN_SE
, WIRE_Y_DOWN_NW
, WIRE_Y_DOWN_BOTH
},
499 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
500 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
501 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
502 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
504 {INVALID_CATENARY
, WIRE_X_DOWN_NE
, WIRE_X_DOWN_SW
, WIRE_X_DOWN_BOTH
},
505 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
506 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
507 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
508 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
509 {INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
, INVALID_CATENARY
},
513 #endif /* ELRAIL_DATA_H */