From 54b57fbfeb951095a789a5fdaef5daaeea9e1a05 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Guilloux?= Date: Fri, 12 Jan 2024 21:19:08 +0100 Subject: [PATCH] Codechange: [Script] Use ScriptList::FillList() in more locations (#11762) --- src/script/api/script_stationlist.cpp | 8 +++++--- src/script/api/script_storypageelementlist.cpp | 8 +++----- src/script/api/script_storypagelist.cpp | 8 +++----- src/script/api/script_waypointlist.cpp | 12 ++++++++---- 4 files changed, 19 insertions(+), 17 deletions(-) diff --git a/src/script/api/script_stationlist.cpp b/src/script/api/script_stationlist.cpp index e3bca735ba4f4..2051679ecaf82 100644 --- a/src/script/api/script_stationlist.cpp +++ b/src/script/api/script_stationlist.cpp @@ -21,9 +21,11 @@ ScriptStationList::ScriptStationList(ScriptStation::StationType station_type) EnforceDeityOrCompanyModeValid_Void(); bool is_deity = ScriptCompanyMode::IsDeity(); CompanyID owner = ScriptObject::GetCompany(); - for (Station *st : Station::Iterate()) { - if ((is_deity || st->owner == owner) && (st->facilities & station_type) != 0) this->AddItem(st->index); - } + ScriptList::FillList(this, + [is_deity, owner, station_type](const Station *st) { + return (is_deity || st->owner == owner) && (st->facilities & station_type) != 0; + } + ); } ScriptStationList_Vehicle::ScriptStationList_Vehicle(VehicleID vehicle_id) diff --git a/src/script/api/script_storypageelementlist.cpp b/src/script/api/script_storypageelementlist.cpp index ce60963f24f4b..506342c7c6ff6 100644 --- a/src/script/api/script_storypageelementlist.cpp +++ b/src/script/api/script_storypageelementlist.cpp @@ -17,9 +17,7 @@ ScriptStoryPageElementList::ScriptStoryPageElementList(ScriptStoryPage::StoryPag { if (!ScriptStoryPage::IsValidStoryPage(story_page_id)) return; - for (StoryPageElement *pe : StoryPageElement::Iterate()) { - if (pe->page == story_page_id) { - this->AddItem(pe->index); - } - } + ScriptList::FillList(this, + [story_page_id](const StoryPageElement *pe) {return pe->page == story_page_id; } + ); } diff --git a/src/script/api/script_storypagelist.cpp b/src/script/api/script_storypagelist.cpp index 9bff9e4eb7fc7..90001a77a646d 100644 --- a/src/script/api/script_storypagelist.cpp +++ b/src/script/api/script_storypagelist.cpp @@ -19,9 +19,7 @@ ScriptStoryPageList::ScriptStoryPageList(ScriptCompany::CompanyID company) uint8_t c = company; if (company == ScriptCompany::COMPANY_INVALID) c = INVALID_COMPANY; - for (StoryPage *p : StoryPage::Iterate()) { - if (p->company == c || p->company == INVALID_COMPANY) { - this->AddItem(p->index); - } - } + ScriptList::FillList(this, + [c](const StoryPage *p) {return p->company == c || p->company == INVALID_COMPANY; } + ); } diff --git a/src/script/api/script_waypointlist.cpp b/src/script/api/script_waypointlist.cpp index 5e1e1ca07954a..f137bea19077b 100644 --- a/src/script/api/script_waypointlist.cpp +++ b/src/script/api/script_waypointlist.cpp @@ -18,10 +18,14 @@ ScriptWaypointList::ScriptWaypointList(ScriptWaypoint::WaypointType waypoint_type) { EnforceDeityOrCompanyModeValid_Void(); - for (const Waypoint *wp : Waypoint::Iterate()) { - if ((wp->facilities & waypoint_type) && - (wp->owner == ScriptObject::GetCompany() || ScriptCompanyMode::IsDeity() || wp->owner == OWNER_NONE)) this->AddItem(wp->index); - } + + bool is_deity = ScriptCompanyMode::IsDeity(); + CompanyID owner = ScriptObject::GetCompany(); + ScriptList::FillList(this, + [is_deity, owner, waypoint_type](const Waypoint *wp) { + return (is_deity || wp->owner == owner || wp->owner == OWNER_NONE) && (wp->facilities & waypoint_type) != 0; + } + ); } ScriptWaypointList_Vehicle::ScriptWaypointList_Vehicle(VehicleID vehicle_id)