(svn r6580) -Fix r6552: [depot window] fixed issue where vehicles sometimes failed to restart after being replaced
Also fixed an issue where cost animation could fail to show (trigger events appeared to be linked for those two issues)
This commit is contained in:
		
							
								
								
									
										26
									
								
								vehicle.c
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								vehicle.c
									
									
									
									
									
								
							| @@ -591,7 +591,7 @@ void Ship_Tick(Vehicle *v); | |||||||
| void Train_Tick(Vehicle *v); | void Train_Tick(Vehicle *v); | ||||||
| static void EffectVehicle_Tick(Vehicle *v); | static void EffectVehicle_Tick(Vehicle *v); | ||||||
| void DisasterVehicle_Tick(Vehicle *v); | void DisasterVehicle_Tick(Vehicle *v); | ||||||
| static int32 MaybeReplaceVehicle(Vehicle **original_vehicle, bool check, bool display_costs); | static int32 MaybeReplaceVehicle(Vehicle *v, bool check, bool display_costs); | ||||||
|  |  | ||||||
| // head of the linked list to tell what vehicles that visited a depot in a tick | // head of the linked list to tell what vehicles that visited a depot in a tick | ||||||
| static Vehicle* _first_veh_in_depot_list; | static Vehicle* _first_veh_in_depot_list; | ||||||
| @@ -671,7 +671,7 @@ void CallVehicleTicks(void) | |||||||
| 	while (v != NULL) { | 	while (v != NULL) { | ||||||
| 		Vehicle *w = v->depot_list; | 		Vehicle *w = v->depot_list; | ||||||
| 		v->depot_list = NULL; // it should always be NULL at the end of each tick | 		v->depot_list = NULL; // it should always be NULL at the end of each tick | ||||||
| 		MaybeReplaceVehicle(&v, false, true); | 		MaybeReplaceVehicle(v, false, true); | ||||||
| 		v = w; | 		v = w; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| @@ -1729,16 +1729,19 @@ int32 CmdDepotMassAutoReplace(TileIndex tile, uint32 flags, uint32 p1, uint32 p2 | |||||||
| 			(vehicle_type == VEH_Ship     && !IsShipInDepot(v)           ) || | 			(vehicle_type == VEH_Ship     && !IsShipInDepot(v)           ) || | ||||||
| 			(vehicle_type == VEH_Aircraft && !IsAircraftInHangar(v))     ) continue; | 			(vehicle_type == VEH_Aircraft && !IsAircraftInHangar(v))     ) continue; | ||||||
|  |  | ||||||
| 		if (stopped) v->vehstatus |= VS_STOPPED; // Stop the vehicle | 		x = v->x_pos; | ||||||
| 		ret = MaybeReplaceVehicle(&v, !(flags & DC_EXEC), false); | 		y = v->y_pos; | ||||||
| 		if (stopped) v->vehstatus &= ~VS_STOPPED; // restart the vehicle if we stopped it for being replaced | 		z = v->z_pos; | ||||||
|  |  | ||||||
|  | 		if (stopped) { | ||||||
|  | 			v->vehstatus |= VS_STOPPED; // Stop the vehicle | ||||||
|  | 			v->leave_depot_instantly = true; | ||||||
|  | 		} | ||||||
|  | 		ret = MaybeReplaceVehicle(v, !(flags & DC_EXEC), false); | ||||||
|  |  | ||||||
| 		if (!CmdFailed(ret)) { | 		if (!CmdFailed(ret)) { | ||||||
| 			cost += ret; | 			cost += ret; | ||||||
| 			if (!(flags & DC_EXEC)) break; | 			if (!(flags & DC_EXEC)) break; | ||||||
| 			x = v->x_pos; |  | ||||||
| 			y = v->y_pos; |  | ||||||
| 			z = v->z_pos; |  | ||||||
| 			/* There is a problem with autoreplace and newgrf | 			/* There is a problem with autoreplace and newgrf | ||||||
| 			 * It's impossible to tell the length of a train after it's being replaced before it's actually done | 			 * It's impossible to tell the length of a train after it's being replaced before it's actually done | ||||||
| 			 * Because of this, we can't estimate costs due to wagon removal and we will have to always return 0 and pay manually | 			 * Because of this, we can't estimate costs due to wagon removal and we will have to always return 0 and pay manually | ||||||
| @@ -2069,9 +2072,8 @@ static int32 ReplaceVehicle(Vehicle **w, byte flags, int32 total_cost) | |||||||
|  * @param display_costs If set, a cost animation is shown (only if check is false) |  * @param display_costs If set, a cost animation is shown (only if check is false) | ||||||
|  * @return CMD_ERROR if something went wrong. Otherwise the price of the replace |  * @return CMD_ERROR if something went wrong. Otherwise the price of the replace | ||||||
|  */ |  */ | ||||||
| static int32 MaybeReplaceVehicle(Vehicle **original_vehicle, bool check, bool display_costs) | static int32 MaybeReplaceVehicle(Vehicle *v, bool check, bool display_costs) | ||||||
| { | { | ||||||
| 	Vehicle *v = *original_vehicle; |  | ||||||
| 	Vehicle *w; | 	Vehicle *w; | ||||||
| 	const Player *p = GetPlayer(v->owner); | 	const Player *p = GetPlayer(v->owner); | ||||||
| 	byte flags = 0; | 	byte flags = 0; | ||||||
| @@ -2150,7 +2152,7 @@ static int32 MaybeReplaceVehicle(Vehicle **original_vehicle, bool check, bool di | |||||||
| 				AddNewsItem(message, NEWS_FLAGS(NM_SMALL, NF_VIEWPORT|NF_VEHICLE, NT_ADVICE, 0), v->index, 0); | 				AddNewsItem(message, NEWS_FLAGS(NM_SMALL, NF_VIEWPORT|NF_VEHICLE, NT_ADVICE, 0), v->index, 0); | ||||||
| 			} | 			} | ||||||
| 			if (stopped) v->vehstatus &= ~VS_STOPPED; | 			if (stopped) v->vehstatus &= ~VS_STOPPED; | ||||||
| 			_current_player = OWNER_NONE; | 			if (display_costs) _current_player = OWNER_NONE; | ||||||
| 			return CMD_ERROR; | 			return CMD_ERROR; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| @@ -2189,8 +2191,6 @@ static int32 MaybeReplaceVehicle(Vehicle **original_vehicle, bool check, bool di | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	original_vehicle = &v; |  | ||||||
|  |  | ||||||
| 	if (stopped) v->vehstatus &= ~VS_STOPPED; | 	if (stopped) v->vehstatus &= ~VS_STOPPED; | ||||||
| 	if (display_costs) { | 	if (display_costs) { | ||||||
| 		if (IsLocalPlayer()) ShowCostOrIncomeAnimation(v->x_pos, v->y_pos, v->z_pos, cost); | 		if (IsLocalPlayer()) ShowCostOrIncomeAnimation(v->x_pos, v->y_pos, v->z_pos, cost); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 bjarni
					bjarni