aboutsummaryrefslogtreecommitdiff
path: root/frontend
diff options
context:
space:
mode:
authorLoek Le Blansch <loek@pipeframe.xyz>2024-10-31 14:14:09 +0100
committerLoek Le Blansch <loek@pipeframe.xyz>2024-10-31 14:14:09 +0100
commitf8d8d7499ba4433678db2a68fb1cae74448ca31e (patch)
treefc96bef89fc3206277d1fcf1e3df5ad733b7e652 /frontend
parenta0e14fa424494ed35da1bd6e5e54bb36178259a7 (diff)
make ListIterator continue working on a changing list
Diffstat (limited to 'frontend')
-rw-r--r--frontend/cmd/get.cpp4
-rw-r--r--frontend/cmd/search.cpp5
2 files changed, 3 insertions, 6 deletions
diff --git a/frontend/cmd/get.cpp b/frontend/cmd/get.cpp
index 0d6d12c..359a5c5 100644
--- a/frontend/cmd/get.cpp
+++ b/frontend/cmd/get.cpp
@@ -12,13 +12,13 @@ FollowupAction Player::cmd_get(string & target_name) {
for (Object * object : this->location.get_visible_objects()) {
if (str_lower(object->get_name().c_str()) != str_lower(target_name)) continue;
target = unique_ptr<Object>(object);
+ this->location.remove_visible_object(object);
break;
}
if (target == nullptr) {
lprtf("Object \"%s\" niet gevonden.\n", target_name.c_str());
return FollowupAction::NONE;
}
- this->location.remove_visible_object(target.get());
// gold objects are collected and (implicitly) destroyed
GoldObject * gold = dynamic_cast<GoldObject *>(target.get());
@@ -30,7 +30,7 @@ FollowupAction Player::cmd_get(string & target_name) {
}
// other objects go in the inventory
- lprtf("Je voegt %s toe aan je bezit.\n", target->get_displayname().c_str());
+ lprtf("Je voegt %s toe aan je bezit.\n", target->get_name().c_str());
this->inventory.push_back(std::move(target));
return FollowupAction::NONE;
}
diff --git a/frontend/cmd/search.cpp b/frontend/cmd/search.cpp
index 16e4592..f10709a 100644
--- a/frontend/cmd/search.cpp
+++ b/frontend/cmd/search.cpp
@@ -7,17 +7,14 @@ using namespace std;
FollowupAction Player::cmd_search(string &) {
bool found = false;
- List<Object *> to_unhide;
for (Object * object : this->location.get_hidden_objects()) {
if (!found) lprtf("Je vindt:\n");
lprtf("- %s\n", object->get_displayname().c_str());
- to_unhide.push_back(object);
+ this->location.unhide_object(object);
found = true;
}
if (!found)
lprtf("Je hebt niks gevonden.\n");
- for (Object * object : to_unhide)
- this->location.unhide_object(object);
return FollowupAction::UPDATE;
}