From 38905d596fa8e0f2c194a5cae3e84128fdb37597 Mon Sep 17 00:00:00 2001 From: rubidium Date: Sun, 17 Aug 2008 11:04:37 +0000 Subject: [PATCH] (svn r14089) -Fix [FS#2219]: trains not being able to find a route to a depot when the front is already in the depot. --- src/train_cmd.cpp | 9 ++++++++- src/vehicle.cpp | 6 +----- 2 files changed, 9 insertions(+), 6 deletions(-) diff --git a/src/train_cmd.cpp b/src/train_cmd.cpp index 29b9076548..c7423f3ee7 100644 --- a/src/train_cmd.cpp +++ b/src/train_cmd.cpp @@ -2128,9 +2128,14 @@ static TrainFindDepotData FindClosestTrainDepot(Vehicle *v, int max_distance) TrainFindDepotData tfdd; tfdd.owner = v->owner; - tfdd.best_length = UINT_MAX; tfdd.reverse = false; + if (IsRailDepotTile(v->tile)) { + tfdd.tile = v->tile; + tfdd.best_length = 0; + return tfdd; + } + PBSTileInfo origin = FollowTrainReservation(v); if (IsRailDepotTile(origin.tile)) { tfdd.tile = origin.tile; @@ -2138,6 +2143,8 @@ static TrainFindDepotData FindClosestTrainDepot(Vehicle *v, int max_distance) return tfdd; } + tfdd.best_length = UINT_MAX; + uint8 pathfinder = _settings_game.pf.pathfinder_for_trains; if ((_settings_game.pf.reserve_paths || HasReservedTracks(v->tile, v->u.rail.track)) && pathfinder == VPF_NTP) pathfinder = VPF_NPF; diff --git a/src/vehicle.cpp b/src/vehicle.cpp index bd64a4d691..ce9d6caa6c 100644 --- a/src/vehicle.cpp +++ b/src/vehicle.cpp @@ -2496,7 +2496,7 @@ CommandCost Vehicle::SendToDepot(uint32 flags, DepotCommand command) { if (!CheckOwnership(this->owner)) return CMD_ERROR; if (this->vehstatus & VS_CRASHED) return CMD_ERROR; - if (this->IsInDepot()) return CMD_ERROR; + if (this->IsStoppedInDepot()) return CMD_ERROR; if (this->current_order.IsType(OT_GOTO_DEPOT)) { bool halt_in_depot = this->current_order.GetDepotActionType() & ODATFB_HALT; @@ -2524,10 +2524,6 @@ CommandCost Vehicle::SendToDepot(uint32 flags, DepotCommand command) return CommandCost(); } - /* check if at a standstill (not stopped only) in a depot - * the check is down here to make it possible to alter stop/service for trains entering the depot */ - if (this->type == VEH_TRAIN && IsRailDepotTile(this->tile) && this->cur_speed == 0) return CMD_ERROR; - TileIndex location; DestinationID destination; bool reverse;