summaryrefslogtreecommitdiff
path: root/src/station_gui.cpp
diff options
context:
space:
mode:
authorfrosch <frosch@openttd.org>2014-11-18 20:12:42 +0000
committerfrosch <frosch@openttd.org>2014-11-18 20:12:42 +0000
commit861b9bc85e8d6e418ca695d2f3eee74ef9edbcdf (patch)
tree15d9ebe7c946ac02bc2f2f97a63b126123af5174 /src/station_gui.cpp
parentc00e48eedb0799edeec6625dc0b6398e1455d0e8 (diff)
downloadopenttd-861b9bc85e8d6e418ca695d2f3eee74ef9edbcdf.tar.xz
(svn r27063) -Fix [FS#6172]: Some lists did not use natural string sorting.
Diffstat (limited to 'src/station_gui.cpp')
-rw-r--r--src/station_gui.cpp7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/station_gui.cpp b/src/station_gui.cpp
index 92b98dd39..b5e705f73 100644
--- a/src/station_gui.cpp
+++ b/src/station_gui.cpp
@@ -19,6 +19,7 @@
#include "cargotype.h"
#include "station_gui.h"
#include "strings_func.h"
+#include "string_func.h"
#include "window_func.h"
#include "viewport_func.h"
#include "widgets/dropdown_func.h"
@@ -222,7 +223,9 @@ protected:
GetString(buf_cache, STR_STATION_NAME, lastof(buf_cache));
}
- return strcmp(buf, buf_cache);
+ int r = strnatcmp(buf, buf_cache); // Sort by name (natural sorting).
+ if (r == 0) return (*a)->index - (*b)->index;
+ return r;
}
/** Sort stations by their type */
@@ -1186,7 +1189,7 @@ bool CargoSorter::SortStation(StationID st1, StationID st2) const
SetDParam(0, st2);
GetString(buf2, STR_STATION_NAME, lastof(buf2));
- int res = strcmp(buf1, buf2);
+ int res = strnatcmp(buf1, buf2); // Sort by name (natural sorting).
if (res == 0) {
return this->SortId(st1, st2);
} else {