Files
@ r12410:4bb7a12b2f71
Branch filter:
Location: cpp/openttd-patchpack/source/src/waypoint.h - annotation
r12410:4bb7a12b2f71
1.9 KiB
text/x-c
(svn r16854) -Fix (r2046): savegames from before this version would get the town id as their 'index' (#<num). For stations with custom names that custom name would be dropped and the lowest 6 bits of the StringID would be used for the 'index'. In other words, it resulted in a mess.
r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r9111:983de9c5a848 r6432:3f618c3647c2 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r8775:89b76da3c46f r5475:3f5cd13d1b63 r8237:d8e599249043 r12407:c9f407c3673a r8962:cfbdc736c8db r9129:db82b80b0a0b r10571:99cb9a95b4cf r11969:3526c3cc75dc r5475:3f5cd13d1b63 r11967:df0600d2c7e7 r11967:df0600d2c7e7 r7381:7ca8ddb92031 r11967:df0600d2c7e7 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r8579:67a13a9a84e5 r12406:d60713d1c3ad r8258:08100da56269 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r10207:a1fc2f2a33db r5475:3f5cd13d1b63 r12407:c9f407c3673a r5475:3f5cd13d1b63 r12406:d60713d1c3ad r5475:3f5cd13d1b63 r11967:df0600d2c7e7 r7381:7ca8ddb92031 r12381:5e06b887e97b r12381:5e06b887e97b r7381:7ca8ddb92031 r5475:3f5cd13d1b63 r11966:921bea0ca112 r11966:921bea0ca112 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r10099:43337737dc84 r11917:612c11f7ab47 r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 r11090:9276cea703d4 r5475:3f5cd13d1b63 r9949:5ac3bf61abad r7318:844268a38029 r12381:5e06b887e97b r5475:3f5cd13d1b63 r5475:3f5cd13d1b63 | /* $Id$ */
/** @file waypoint.h Base of waypoints. */
#ifndef WAYPOINT_H
#define WAYPOINT_H
#include "waypoint_type.h"
#include "rail_map.h"
#include "command_type.h"
#include "station_base.h"
#include "town_type.h"
#include "viewport_type.h"
#include "date_type.h"
#include "core/pool_type.hpp"
typedef Pool<Waypoint, WaypointID, 32, 64000> WaypointPool;
extern WaypointPool _waypoint_pool;
struct Waypoint : WaypointPool::PoolItem<&_waypoint_pool> {
TileIndex xy; ///< Tile of waypoint
TownID town_index; ///< Town associated with the waypoint
uint16 town_cn; ///< The Nth waypoint for this town (consecutive number)
StringID string_id;///< C000-C03F have special meaning in old games
char *name; ///< Custom name. If not set, town + town_cn is used for naming
ViewportSign sign; ///< Dimensions of sign (not saved)
Date build_date; ///< Date of construction
OwnerByte owner; ///< Whom this waypoint belongs to
StationSpecList spec; ///< NewGRF specification of the station
byte delete_ctr; ///< Delete counter. If greater than 0 then it is decremented until it reaches 0; the waypoint is then is deleted.
Waypoint(TileIndex tile = INVALID_TILE) : xy(tile) { }
~Waypoint();
void UpdateVirtCoord();
};
#define FOR_ALL_WAYPOINTS_FROM(var, start) FOR_ALL_ITEMS_FROM(Waypoint, waypoint_index, var, start)
#define FOR_ALL_WAYPOINTS(var) FOR_ALL_WAYPOINTS_FROM(var, 0)
/**
* Fetch a waypoint by tile
* @param tile Tile of waypoint
* @return Waypoint
*/
static inline Waypoint *GetWaypointByTile(TileIndex tile)
{
assert(IsRailWaypointTile(tile));
return Waypoint::Get(GetWaypointIndex(tile));
}
CommandCost RemoveTrainWaypoint(TileIndex tile, DoCommandFlag flags, bool justremove);
Station *ComposeWaypointStation(TileIndex tile);
void ShowWaypointWindow(const Waypoint *wp);
void DrawWaypointSprite(int x, int y, int stat_id, RailType railtype);
void UpdateAllWaypointVirtCoords();
#endif /* WAYPOINT_H */
|