Files @ r12410:4bb7a12b2f71
Branch filter:

Location: cpp/openttd-patchpack/source/src/waypoint.cpp - annotation

rubidium
(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.
r5584:545d748cc681
r5584:545d748cc681
r9111:983de9c5a848
r6432:3f618c3647c2
r5584:545d748cc681
r5584:545d748cc681
r11349:d10cdef1879d
r8138:f851b4cbdad1
r8785:8312063c5ee4
r5584:545d748cc681
r5584:545d748cc681
r8131:7a50db7be0ff
r8787:4e60a460f8ef
r11349:d10cdef1879d
r11967:df0600d2c7e7
r5584:545d748cc681
r11967:df0600d2c7e7
r11967:df0600d2c7e7
r5584:545d748cc681
r6432:3f618c3647c2
r6432:3f618c3647c2
r6432:3f618c3647c2
r12381:5e06b887e97b
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r12381:5e06b887e97b
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r6432:3f618c3647c2
r6432:3f618c3647c2
r6432:3f618c3647c2
r6247:96e840dbefcc
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r12406:d60713d1c3ad
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r6432:3f618c3647c2
r6432:3f618c3647c2
r6432:3f618c3647c2
r6432:3f618c3647c2
r6432:3f618c3647c2
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r5734:df644aea31d5
r5734:df644aea31d5
r5734:df644aea31d5
r5739:85c6eccb968b
r5734:df644aea31d5
r5584:545d748cc681
r5584:545d748cc681
r11917:612c11f7ab47
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r6432:3f618c3647c2
r6432:3f618c3647c2
r6432:3f618c3647c2
r6432:3f618c3647c2
r6432:3f618c3647c2
r6432:3f618c3647c2
r6432:3f618c3647c2
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r5584:545d748cc681
r7381:7ca8ddb92031
r7381:7ca8ddb92031
r8258:08100da56269
r7413:3ccdde9800e0
r7413:3ccdde9800e0
r9964:c2a3e9be6d4b
r7381:7ca8ddb92031
r7381:7ca8ddb92031
r12334:57fa457522c9
r7381:7ca8ddb92031
r7381:7ca8ddb92031
r6247:96e840dbefcc
r5584:545d748cc681
r11967:df0600d2c7e7
r5584:545d748cc681
/* $Id$ */

/** @file waypoint.cpp Handling of waypoints. */

#include "stdafx.h"

#include "strings_type.h"
#include "rail.h"
#include "station_base.h"
#include "town.h"
#include "waypoint.h"
#include "window_func.h"
#include "newgrf_station.h"
#include "order_func.h"
#include "core/pool_func.hpp"

WaypointPool _waypoint_pool("Waypoint");
INSTANTIATE_POOL_METHODS(Waypoint)

/**
 * Update all signs
 */
void UpdateAllWaypointVirtCoords()
{
	Waypoint *wp;

	FOR_ALL_WAYPOINTS(wp) {
		wp->UpdateVirtCoord();
	}
}

/**
 * Daily loop for waypoints
 */
void WaypointsDailyLoop()
{
	Waypoint *wp;

	/* Check if we need to delete a waypoint */
	FOR_ALL_WAYPOINTS(wp) {
		if (wp->delete_ctr != 0 && --wp->delete_ctr == 0) delete wp;
	}
}

/**
 * This hacks together some dummy one-shot Station structure for a waypoint.
 * @param tile on which to work
 * @return pointer to a Station
 */
Station *ComposeWaypointStation(TileIndex tile)
{
	Waypoint *wp = GetWaypointByTile(tile);

	/* instead of 'static Station stat' use byte array to avoid Station's destructor call upon exit. As
	 * a side effect, the station is not constructed now. */
	static byte stat_raw[sizeof(Station)];
	static Station &stat = *(Station*)stat_raw;

	stat.train_tile = stat.xy = wp->xy;
	stat.town = Town::Get(wp->town_index);
	stat.build_date = wp->build_date;

	return &stat;
}

/**
 * Draw a waypoint
 * @param x coordinate
 * @param y coordinate
 * @param stat_id station id
 * @param railtype RailType to use for
 */
void DrawWaypointSprite(int x, int y, int stat_id, RailType railtype)
{
	x += 33;
	y += 17;

	if (!DrawStationTile(x, y, railtype, AXIS_X, STAT_CLASS_WAYP, stat_id)) {
		DrawDefaultWaypointSprite(x, y, railtype);
	}
}

Waypoint::~Waypoint()
{
	free(this->name);

	if (CleaningPool()) return;
	DeleteWindowById(WC_WAYPOINT_VIEW, this->index);
	RemoveOrderFromAllVehicles(OT_GOTO_WAYPOINT, this->index);

	this->sign.MarkDirty();
}

void InitializeWaypoints()
{
	_waypoint_pool.CleanPool();
}