summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/autoreplace_gui.cpp54
1 files changed, 27 insertions, 27 deletions
diff --git a/src/autoreplace_gui.cpp b/src/autoreplace_gui.cpp
index 60c10fb0d..6a5346565 100644
--- a/src/autoreplace_gui.cpp
+++ b/src/autoreplace_gui.cpp
@@ -99,14 +99,14 @@ void AddRemoveEngineFromAutoreplaceAndBuildWindows(VehicleType type)
* Window for the autoreplacing of vehicles.
*/
class ReplaceVehicleWindow : public Window {
- EngineID sel_engine[2];
- bool wagon_btnstate; ///< true means engine is selected
- GUIEngineList list[2];
- bool update_left;
- bool update_right;
- bool init_lists;
- GroupID sel_group;
- static RailType sel_railtype;
+ EngineID sel_engine[2]; ///< Selected engine left and right.
+ GUIEngineList list[2]; ///< Left and right list of engines.
+ bool replace_engines; ///< If \c true, engines are replaced, if \c false, wagons are replaced (only for trains).
+ bool update_left; ///< Rebuild left list.
+ bool update_right; ///< Rebuild right list.
+ bool reset_sel_engine; ///< Also reset #sel_engine while updating left and/or right (#update_left and/or #update_right) and no valid engine selected.
+ GroupID sel_group; ///< Group selected to replace.
+ static RailType sel_railtype; ///< Type of rail tracks selected.
/** Figure out if an engine should be added to a list.
* @param e The EngineID.
@@ -144,7 +144,7 @@ class ReplaceVehicleWindow : public Window {
const Engine *e;
FOR_ALL_ENGINES_OF_TYPE(e, type) {
EngineID eid = e->index;
- if (type == VEH_TRAIN && !GenerateReplaceRailList(eid, draw_left, this->wagon_btnstate)) continue; // special rules for trains
+ if (type == VEH_TRAIN && !GenerateReplaceRailList(eid, draw_left, this->replace_engines)) continue; // special rules for trains
if (draw_left) {
const GroupID selected_group = this->sel_group;
@@ -172,7 +172,7 @@ class ReplaceVehicleWindow : public Window {
/* We need to rebuild the left list */
GenerateReplaceVehList(true);
this->vscroll.SetCount(this->list[0].Length());
- if (this->init_lists && this->sel_engine[0] == INVALID_ENGINE && this->list[0].Length() != 0) {
+ if (this->reset_sel_engine && this->sel_engine[0] == INVALID_ENGINE && this->list[0].Length() != 0) {
this->sel_engine[0] = this->list[0][0];
}
}
@@ -186,24 +186,24 @@ class ReplaceVehicleWindow : public Window {
} else {
GenerateReplaceVehList(false);
this->vscroll2.SetCount(this->list[1].Length());
- if (this->init_lists && this->sel_engine[1] == INVALID_ENGINE && this->list[1].Length() != 0) {
+ if (this->reset_sel_engine && this->sel_engine[1] == INVALID_ENGINE && this->list[1].Length() != 0) {
this->sel_engine[1] = this->list[1][0];
}
}
}
/* Reset the flags about needed updates */
- this->update_left = false;
- this->update_right = false;
- this->init_lists = false;
+ this->update_left = false;
+ this->update_right = false;
+ this->reset_sel_engine = false;
}
public:
ReplaceVehicleWindow(const WindowDesc *desc, VehicleType vehicletype, GroupID id_g) : Window(desc, vehicletype)
{
- this->wagon_btnstate = true; // start with locomotives (all other vehicles will not read this bool)
- this->update_left = true;
- this->update_right = true;
- this->init_lists = true;
+ this->replace_engines = true; // start with locomotives (all other vehicles will not read this bool)
+ this->update_left = true;
+ this->update_right = true;
+ this->reset_sel_engine = true;
this->sel_engine[0] = INVALID_ENGINE;
this->sel_engine[1] = INVALID_ENGINE;
@@ -269,7 +269,7 @@ public:
SetDParam(1, c->settings.renew_keep_length ? STR_CONFIG_SETTING_ON : STR_CONFIG_SETTING_OFF);
/* set wagon/engine button */
- SetDParam(2, this->wagon_btnstate ? STR_REPLACE_ENGINES : STR_REPLACE_WAGONS);
+ SetDParam(2, this->replace_engines ? STR_REPLACE_ENGINES : STR_REPLACE_WAGONS);
/* sets the colour of that art thing */
this->widget[RVW_WIDGET_TRAIN_FLUFF_LEFT].colour = _company_colours[_local_company];
@@ -326,9 +326,9 @@ public:
{
switch (widget) {
case RVW_WIDGET_TRAIN_ENGINEWAGON_TOGGLE:
- this->wagon_btnstate = !(this->wagon_btnstate);
- this->update_left = true;
- this->init_lists = true;
+ this->replace_engines = !(this->replace_engines);
+ this->update_left = true;
+ this->reset_sel_engine = true;
this->SetDirty();
break;
@@ -376,8 +376,8 @@ public:
if (e == this->sel_engine[click_side]) break; // we clicked the one we already selected
this->sel_engine[click_side] = e;
if (click_side == 0) {
- this->update_right = true;
- this->init_lists = true;
+ this->update_right = true;
+ this->reset_sel_engine = true;
}
this->SetDirty();
}
@@ -395,9 +395,9 @@ public:
this->vscroll.SetPosition(0);
this->vscroll2.SetPosition(0);
/* Rebuild the lists */
- this->update_left = true;
- this->update_right = true;
- this->init_lists = true;
+ this->update_left = true;
+ this->update_right = true;
+ this->reset_sel_engine = true;
this->SetDirty();
}