(svn r1016) Make the cargo sorter not consider the number of wagons of a particular cargo type but the sum of their capacity.
Also add the number sorter to sort by vehicle number if the cargo capacity is equal.
This commit is contained in:
		| @@ -246,24 +246,21 @@ int CDECL VehicleProfitLastYearSorter(const void *a, const void *b) | |||||||
|  |  | ||||||
| int CDECL VehicleCargoSorter(const void *a, const void *b) | int CDECL VehicleCargoSorter(const void *a, const void *b) | ||||||
| { | { | ||||||
| 	// FIXME - someone write a normal cargo sorter that also works by cargo_cap, |  | ||||||
| 	// FIXME - since I seem to be unable to do so :S |  | ||||||
| 	const Vehicle *va = DEREF_VEHICLE((*(const SortStruct*)a).index); | 	const Vehicle *va = DEREF_VEHICLE((*(const SortStruct*)a).index); | ||||||
| 	const Vehicle *vb = DEREF_VEHICLE((*(const SortStruct*)b).index); | 	const Vehicle *vb = DEREF_VEHICLE((*(const SortStruct*)b).index); | ||||||
|  | 	const Vehicle *v; | ||||||
| 	int r = 0; | 	int r = 0; | ||||||
| 	int i; | 	int i; | ||||||
| 	byte _cargo_counta[NUM_CARGO]; | 	uint _cargo_counta[NUM_CARGO]; | ||||||
| 	byte _cargo_countb[NUM_CARGO]; | 	uint _cargo_countb[NUM_CARGO]; | ||||||
| 	memset(_cargo_counta, 0, sizeof(_cargo_counta)); | 	memset(_cargo_counta, 0, sizeof(_cargo_counta)); | ||||||
| 	memset(_cargo_countb, 0, sizeof(_cargo_countb)); | 	memset(_cargo_countb, 0, sizeof(_cargo_countb)); | ||||||
|  |  | ||||||
| 	do { | 	for (v = va; v != NULL; v = v->next) | ||||||
| 		_cargo_counta[va->cargo_type]++; | 		_cargo_counta[v->cargo_type] += v->cargo_cap; | ||||||
| 	} while ( (va = va->next) != NULL); |  | ||||||
|  |  | ||||||
| 	do { | 	for (v = vb; v != NULL; v = v->next) | ||||||
| 		_cargo_countb[vb->cargo_type]++; | 		_cargo_countb[v->cargo_type] += v->cargo_cap; | ||||||
| 	} while ( (vb = vb->next) != NULL); |  | ||||||
|  |  | ||||||
| 	for (i = 0; i < NUM_CARGO; i++) { | 	for (i = 0; i < NUM_CARGO; i++) { | ||||||
| 		r = _cargo_counta[i] - _cargo_countb[i]; | 		r = _cargo_counta[i] - _cargo_countb[i]; | ||||||
| @@ -271,6 +268,8 @@ int CDECL VehicleCargoSorter(const void *a, const void *b) | |||||||
| 			break; | 			break; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	VEHICLEUNITNUMBERSORTER(r, va, vb); | ||||||
|  |  | ||||||
| 	return (_internal_sort_order & 1) ? -r : r; | 	return (_internal_sort_order & 1) ? -r : r; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 tron
					tron