(svn r6143) -Codechange: DeleteWaypoint removes a waypoint from the pool
-Codechange: DestroyWaypoint is called by DeleteWaypoint to remove all things where a waypoint depends on. Last 2 changes to prepare for new pool system. Not pretty now, will be soon.
This commit is contained in:
		
							
								
								
									
										24
									
								
								waypoint.c
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								waypoint.c
									
									
									
									
									
								
							| @@ -95,6 +95,16 @@ void UpdateAllWaypointSigns(void) | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /* Internal handler to delete a waypoint */ | ||||||
|  | void DestroyWaypoint(Waypoint *wp) | ||||||
|  | { | ||||||
|  | 	RemoveOrderFromAllVehicles(OT_GOTO_WAYPOINT, (DestinationID)wp->index); | ||||||
|  |  | ||||||
|  | 	if (wp->string != STR_NULL) DeleteName(wp->string); | ||||||
|  |  | ||||||
|  | 	RedrawWaypointSign(wp); | ||||||
|  | } | ||||||
|  |  | ||||||
| /* Set the default name for a waypoint */ | /* Set the default name for a waypoint */ | ||||||
| static void MakeDefaultWaypointName(Waypoint* wp) | static void MakeDefaultWaypointName(Waypoint* wp) | ||||||
| { | { | ||||||
| @@ -244,18 +254,6 @@ int32 CmdBuildTrainWaypoint(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) | |||||||
| 	return _price.build_train_depot; | 	return _price.build_train_depot; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* Internal handler to delete a waypoint */ |  | ||||||
| static void DoDeleteWaypoint(Waypoint *wp) |  | ||||||
| { |  | ||||||
| 	wp->xy = 0; |  | ||||||
|  |  | ||||||
| 	RemoveOrderFromAllVehicles(OT_GOTO_WAYPOINT, (DestinationID)wp->index); |  | ||||||
|  |  | ||||||
| 	if (wp->string != STR_NULL) DeleteName(wp->string); |  | ||||||
|  |  | ||||||
| 	RedrawWaypointSign(wp); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* Daily loop for waypoints */ | /* Daily loop for waypoints */ | ||||||
| void WaypointsDailyLoop(void) | void WaypointsDailyLoop(void) | ||||||
| { | { | ||||||
| @@ -263,7 +261,7 @@ void WaypointsDailyLoop(void) | |||||||
|  |  | ||||||
| 	/* Check if we need to delete a waypoint */ | 	/* Check if we need to delete a waypoint */ | ||||||
| 	FOR_ALL_WAYPOINTS(wp) { | 	FOR_ALL_WAYPOINTS(wp) { | ||||||
| 		if (wp->deleted != 0 && --wp->deleted == 0) DoDeleteWaypoint(wp); | 		if (wp->deleted != 0 && --wp->deleted == 0) DestroyWaypoint(wp); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -55,6 +55,14 @@ static inline bool IsValidWaypointID(WaypointID index) | |||||||
| 	return index < GetWaypointPoolSize() && IsValidWaypoint(GetWaypoint(index)); | 	return index < GetWaypointPoolSize() && IsValidWaypoint(GetWaypoint(index)); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void DestroyWaypoint(Waypoint *wp); | ||||||
|  |  | ||||||
|  | static inline void DeleteWaypoint(Waypoint *wp) | ||||||
|  | { | ||||||
|  | 	DestroyWaypoint(wp); | ||||||
|  | 	wp->xy = 0; | ||||||
|  | } | ||||||
|  |  | ||||||
| #define FOR_ALL_WAYPOINTS_FROM(wp, start) for (wp = GetWaypoint(start); wp != NULL; wp = (wp->index + 1 < GetWaypointPoolSize()) ? GetWaypoint(wp->index + 1) : NULL) if (IsValidWaypoint(wp)) | #define FOR_ALL_WAYPOINTS_FROM(wp, start) for (wp = GetWaypoint(start); wp != NULL; wp = (wp->index + 1 < GetWaypointPoolSize()) ? GetWaypoint(wp->index + 1) : NULL) if (IsValidWaypoint(wp)) | ||||||
| #define FOR_ALL_WAYPOINTS(wp) FOR_ALL_WAYPOINTS_FROM(wp, 0) | #define FOR_ALL_WAYPOINTS(wp) FOR_ALL_WAYPOINTS_FROM(wp, 0) | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 truelight
					truelight