mirror of https://github.com/OpenTTD/OpenTTD
(svn r1695) -Fix: I broke maximum speed sorting for anything but trains with the new acceleration. Sorry
parent
1bdd01867a
commit
6eec07257a
|
@ -302,17 +302,22 @@ int CDECL VehicleMaxSpeedSorter(const void *a, const void *b)
|
||||||
int max_speed_a = 0xFFFF, max_speed_b = 0xFFFF;
|
int max_speed_a = 0xFFFF, max_speed_b = 0xFFFF;
|
||||||
int r;
|
int r;
|
||||||
const Vehicle *ua = va, *ub = vb;
|
const Vehicle *ua = va, *ub = vb;
|
||||||
do {
|
|
||||||
if (RailVehInfo(ua->engine_type)->max_speed != 0)
|
|
||||||
max_speed_a = min(max_speed_a, RailVehInfo(ua->engine_type)->max_speed);
|
|
||||||
} while ((ua = ua->next) != NULL);
|
|
||||||
|
|
||||||
do {
|
if (va->type == VEH_Train && vb->type == VEH_Train) {
|
||||||
if (RailVehInfo(ub->engine_type)->max_speed != 0)
|
do {
|
||||||
max_speed_b = min(max_speed_b, RailVehInfo(ub->engine_type)->max_speed);
|
if (RailVehInfo(ua->engine_type)->max_speed != 0)
|
||||||
} while ((ub = ub->next) != NULL);
|
max_speed_a = min(max_speed_a, RailVehInfo(ua->engine_type)->max_speed);
|
||||||
|
} while ((ua = ua->next) != NULL);
|
||||||
|
|
||||||
r = max_speed_a - max_speed_b;
|
do {
|
||||||
|
if (RailVehInfo(ub->engine_type)->max_speed != 0)
|
||||||
|
max_speed_b = min(max_speed_b, RailVehInfo(ub->engine_type)->max_speed);
|
||||||
|
} while ((ub = ub->next) != NULL);
|
||||||
|
|
||||||
|
r = max_speed_a - max_speed_b;
|
||||||
|
} else {
|
||||||
|
r = va->max_speed - vb->max_speed;
|
||||||
|
}
|
||||||
|
|
||||||
VEHICLEUNITNUMBERSORTER(r, va, vb);
|
VEHICLEUNITNUMBERSORTER(r, va, vb);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue