(svn r1378) Fix: train engines are now only replaced if the engine is really set to be replaced and they are replaced to the type that engine type is set to be replaced to (instead of whtat the first engine in the train is set to)
This commit is contained in:
		
							
								
								
									
										15
									
								
								vehicle.c
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								vehicle.c
									
									
									
									
									
								
							| @@ -1604,23 +1604,20 @@ void MaybeReplaceVehicle(Vehicle *v) | |||||||
| 	 This way the max is 6553 millions and it is more than the 32 bit that is stored in _patches | 	 This way the max is 6553 millions and it is more than the 32 bit that is stored in _patches | ||||||
| 	 This is a nice way to send 32 bit and only use 16 bit | 	 This is a nice way to send 32 bit and only use 16 bit | ||||||
| 	 the last 8 bit is the engine. The 8 bits in front of the engine is free so it have room for 16 bit engine entries */ | 	 the last 8 bit is the engine. The 8 bits in front of the engine is free so it have room for 16 bit engine entries */ | ||||||
| 	new_engine_and_autoreplace_money = (((_patches.autorenew_money / 100000) & 0xFFFF) << 16) | 	new_engine_and_autoreplace_money = ((_patches.autorenew_money / 100000) << 16) + _autoreplace_array[v->engine_type]; | ||||||
| 	 + _autoreplace_array[v->engine_type]; |  | ||||||
| 	 | 	 | ||||||
| 	assert(v->type == _engines[ _autoreplace_array[v->engine_type] ].type); | 	assert(v->type == _engines[ _autoreplace_array[v->engine_type] ].type); | ||||||
| 	 | 	 | ||||||
| 	if ( v->type != VEH_Train ) { | 	if ( v->type != VEH_Train ) { | ||||||
| 		DoCommandP(v->tile, v->index, new_engine_and_autoreplace_money, NULL, CMD_REPLACE_VEHICLE | CMD_SHOW_NO_ERROR); | 		DoCommandP(v->tile, v->index, new_engine_and_autoreplace_money, NULL, CMD_REPLACE_VEHICLE | CMD_SHOW_NO_ERROR); | ||||||
| 	} else { | 	} else { | ||||||
| 	// checks if the front engine is outdated | 	// checks if any of the engines in the train are either old or listed for replacement | ||||||
| 		if (v->engine_type != _autoreplace_array[v->engine_type] )   | 		do { | ||||||
| 			DoCommandP(v->tile, v->index, new_engine_and_autoreplace_money, NULL, CMD_REPLACE_VEHICLE | CMD_SHOW_NO_ERROR); | 			if ( v->engine_type != _autoreplace_array[v->engine_type] || (v->age - v->max_age) > (_patches.autorenew_months * 30)) { | ||||||
| 	//we will check all the cars and engines if they should be replaced | 				new_engine_and_autoreplace_money = (new_engine_and_autoreplace_money & 0xFFFF0000) + _autoreplace_array[v->engine_type]; // sets the new engine replacement type | ||||||
| 		while (v->next != NULL){ |  | ||||||
| 			v = v->next; |  | ||||||
| 			if (v->engine_type != _autoreplace_array[v->engine_type] || v->age - v->max_age < (_patches.autorenew_months * 30)) |  | ||||||
| 				DoCommandP(v->tile, v->index, new_engine_and_autoreplace_money, NULL, CMD_REPLACE_VEHICLE | CMD_SHOW_NO_ERROR); | 				DoCommandP(v->tile, v->index, new_engine_and_autoreplace_money, NULL, CMD_REPLACE_VEHICLE | CMD_SHOW_NO_ERROR); | ||||||
| 			} | 			} | ||||||
|  | 		} while ((v=v->next) != NULL); | ||||||
| 	} | 	} | ||||||
| 	_current_player = OWNER_NONE; | 	_current_player = OWNER_NONE; | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 bjarni
					bjarni