diff options
author | Clyne Sullivan <tullivan99@gmail.com> | 2017-02-12 15:27:02 -0500 |
---|---|---|
committer | Clyne Sullivan <tullivan99@gmail.com> | 2017-02-12 15:27:02 -0500 |
commit | 7189e7d0d5130b7bb37c4d65e595b1608b3c39c8 (patch) | |
tree | f2e74ad947f6d018d8ea6431140b5f40d1ff7f81 /src | |
parent | 202b5a75428b2405eeff3080cde0e657b76978f9 (diff) |
quest requirements/rewards
Diffstat (limited to 'src')
-rw-r--r-- | src/components.cpp | 2 | ||||
-rw-r--r-- | src/inventory.cpp | 3 | ||||
-rw-r--r-- | src/quest.cpp | 39 |
3 files changed, 37 insertions, 7 deletions
diff --git a/src/components.cpp b/src/components.cpp index cbec9fc..dfce75c 100644 --- a/src/components.cpp +++ b/src/components.cpp @@ -257,7 +257,7 @@ void DialogSystem::receive(const MouseClickEvent &mce) else { qname = qxml->Attribute("check"); if (qname != nullptr) { - if (qname != nullptr && qsys->hasQuest(qname) && qsys->finish(qname) == 0) { + if (qname != nullptr && qsys->finish(qname) == 0) { d.index = 9999; } else { ui::dialogBox(name.name, "", false, "Finish my quest u nug"); diff --git a/src/inventory.cpp b/src/inventory.cpp index bf6b6bb..3995e3a 100644 --- a/src/inventory.cpp +++ b/src/inventory.cpp @@ -240,11 +240,12 @@ bool InventorySystem::take(const std::string& name, int count) return ie.item != nullptr && ie.item->name == name; }); - if (i == items.end()) + if (i >= items.end()) break; toDelete.push_front(i); taken += i->count; + next = i + 1; } if (taken < count) diff --git a/src/quest.cpp b/src/quest.cpp index a0f9a6d..71a37fd 100644 --- a/src/quest.cpp +++ b/src/quest.cpp @@ -2,8 +2,20 @@ #include <algorithm> +#include <engine.hpp> +#include <inventory.hpp> #include <tokens.hpp> +std::string& trim(std::string& s) +{ + auto start = std::find_if(s.begin(), s.end(), + [](char c) { return !isspace(c); }) - s.begin(); + auto end = std::find_if(s.rbegin(), s.rend(), + [](char c) { return !isspace(c); }).base() - s.begin(); + s = s.substr(start, end - start); + return s; +} + void QuestSystem::update(entityx::EntityManager &en, entityx::EventManager &ev, entityx::TimeDelta dt) { (void)en; @@ -13,14 +25,25 @@ void QuestSystem::update(entityx::EntityManager &en, entityx::EventManager &ev, int QuestSystem::assign(std::string title, std::string desc, std::string req) { + current.emplace_back(title, desc); + + auto* list = ¤t.back().reqs; + std::string reqTitle; for (auto s : tokens(req, ',')) { - s.erase(std::remove_if(s.begin(), s.end(), - [](char c) { return isspace(c); }), s.end()); + trim(s); - std::cout << s << '\n'; + if (s == "Reward") { + list = ¤t.back().rewards; + } else { + if (!reqTitle.empty()) { + list->emplace_front(reqTitle, std::stoi(s)); + reqTitle.clear(); + } else { + reqTitle = s; + } + } } - current.emplace_back(title, desc); return 0; } @@ -39,7 +62,13 @@ int QuestSystem::finish(std::string title) if (quest == std::end(current)) return -1; - // TODO requirements + for (const auto& r : quest->reqs) { + if (!game::engine.getSystem<InventorySystem>()->take(r.first, r.second)) + return -1; + } + + for (const auto& r : quest->rewards) + game::engine.getSystem<InventorySystem>()->add(r.first, r.second); drop(title); |