summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/newgrf_station.cpp19
-rw-r--r--src/newgrf_station.h1
-rw-r--r--src/rail_gui.cpp15
3 files changed, 14 insertions, 21 deletions
diff --git a/src/newgrf_station.cpp b/src/newgrf_station.cpp
index cdbdac87e..1cee614bb 100644
--- a/src/newgrf_station.cpp
+++ b/src/newgrf_station.cpp
@@ -98,25 +98,6 @@ StringID GetStationClassName(StationClassID sclass)
return station_classes[sclass].name;
}
-/** Build a list of station class name StringIDs to use in a dropdown list
- * @return Pointer to a (static) array of StringIDs
- */
-StringID *BuildStationClassDropdown()
-{
- /* Allow room for all station classes, plus a terminator entry */
- static StringID names[STAT_CLASS_MAX + 1];
- uint i;
-
- /* Add each name */
- for (i = 0; i < STAT_CLASS_MAX && station_classes[i].id != 0; i++) {
- names[i] = station_classes[i].name;
- }
- /* Terminate the list */
- names[i] = INVALID_STRING_ID;
-
- return names;
-}
-
/**
* Get the number of station classes in use.
* @return Number of station classes.
diff --git a/src/newgrf_station.h b/src/newgrf_station.h
index cb969bc86..1bd02818f 100644
--- a/src/newgrf_station.h
+++ b/src/newgrf_station.h
@@ -102,7 +102,6 @@ void ResetStationClasses();
StationClassID AllocateStationClass(uint32 cls);
void SetStationClassName(StationClassID sclass, StringID name);
StringID GetStationClassName(StationClassID sclass);
-StringID *BuildStationClassDropdown();
uint GetNumStationClasses();
uint GetNumCustomStations(StationClassID sclass);
diff --git a/src/rail_gui.cpp b/src/rail_gui.cpp
index 207c9e1a2..d0a74b420 100644
--- a/src/rail_gui.cpp
+++ b/src/rail_gui.cpp
@@ -27,6 +27,7 @@
#include "sound_func.h"
#include "player_func.h"
#include "settings_type.h"
+#include "widgets/dropdown_type.h"
#include "widgets/dropdown_func.h"
#include "bridge_map.h"
@@ -774,6 +775,18 @@ static void CheckSelectedSize(Window *w, const StationSpec *statspec)
}
}
+static DropDownList *BuildStationClassDropDown()
+{
+ DropDownList *list = new DropDownList();
+
+ for (uint i = 0; i < GetNumStationClasses(); i++) {
+ if (i == STAT_CLASS_WAYP) continue;
+ list->push_back(new DropDownListStringItem(GetStationClassName((StationClassID)i), i, false));
+ }
+
+ return list;
+}
+
static void StationBuildWndProc(Window *w, WindowEvent *e)
{
switch (e->event) {
@@ -992,7 +1005,7 @@ static void StationBuildWndProc(Window *w, WindowEvent *e)
case BRSW_NEWST_DROPDOWN:
case BRSW_NEWST_DROPDOWN_TEXT:
- ShowDropDownMenu(w, BuildStationClassDropdown(), _railstation.station_class, 23, 0, 1 << STAT_CLASS_WAYP);
+ ShowDropDownList(w, BuildStationClassDropDown(), _railstation.station_class, BRSW_NEWST_DROPDOWN_TEXT);
break;
case BRSW_NEWST_LIST: {