(svn r4320) -Fix/Codechange: rs->num_vehicles is no longer saved or loaded, but computed on the fly. Partly fixes FS#101
authorcelestar
Sat, 08 Apr 2006 05:44:37 +0000
changeset 3475 150d89779e96
parent 3474 acaa3ba24f2e
child 3476 f64649b414ac
(svn r4320) -Fix/Codechange: rs->num_vehicles is no longer saved or loaded, but computed on the fly. Partly fixes FS#101
station_cmd.c
--- a/station_cmd.c	Sat Apr 08 05:24:29 2006 +0000
+++ b/station_cmd.c	Sat Apr 08 05:44:37 2006 +0000
@@ -2749,7 +2749,7 @@
 	SLE_REF(RoadStop,prev,         REF_ROADSTOPS),
 
 	SLE_CONDNULL(4, 0, 24),
-	SLE_CONDVAR(RoadStop, num_vehicles, SLE_UINT8, 25, SL_MAX_VERSION),
+	SLE_CONDNULL(1, 25, 25),
 
 	SLE_END()
 };
@@ -2910,6 +2910,7 @@
 static void Load_ROADSTOP(void)
 {
 	int index;
+	Vehicle *v;
 
 	while ((index = SlIterateArray()) != -1) {
 		RoadStop *rs;
@@ -2918,9 +2919,12 @@
 			error("RoadStops: failed loading savegame: too many RoadStops");
 
 		rs = GetRoadStop(index);
-		rs->num_vehicles = 0;
 		SlObject(rs, _roadstop_desc);
 	}
+
+	FOR_ALL_VEHICLES(v) {
+		if (v->type == VEH_Road && v->u.road.slot != NULL) GetRoadStopByTile(v->dest_tile, v->cargo_type == CT_PASSENGERS ? RS_BUS : RS_TRUCK)->num_vehicles++;
+	}
 }
 
 const ChunkHandler _station_chunk_handlers[] = {