diff options
Diffstat (limited to 'src/inventory.cpp')
-rw-r--r-- | src/inventory.cpp | 53 |
1 files changed, 30 insertions, 23 deletions
diff --git a/src/inventory.cpp b/src/inventory.cpp index 1fdaf63..36cc041 100644 --- a/src/inventory.cpp +++ b/src/inventory.cpp @@ -320,30 +320,34 @@ bool InventorySystem::receive(const KeyDownEvent &kde) return true; } -void InventorySystem::add(const std::string& name, int count) +void InventorySystem::add(const std::string& name, int count, int slot) { - auto i = std::find_if(items.begin(), items.end(), - [&name](const InventoryEntry& ie) { - // either matching item that isn't filled, or empty slow - return (ie.item != nullptr && ie.item->name == name && ie.count < ie.item->stackSize) || ie.count == 0; - }); + auto& ie = items[slot]; - if (i != items.end()) { - auto& ie = *i; + if (isGoodEntry(ie)) { + if (ie.item->name != name) + return; // TODO behavior? + ie.count += count; + } else { + ie.item = &itemList[name]; + ie.count = count; + } - // update the slot - if (!isGoodEntry(ie)) { - ie.item = &itemList[name]; - ie.count = count; - } else { - ie.count += count; - } + if (ie.count > ie.item->stackSize) { + int diff = ie.count - ie.item->stackSize; + ie.count = ie.item->stackSize; + add(name, diff); + } +} - // handle overflow - if (ie.count > ie.item->stackSize) { - int diff = ie.count - ie.item->stackSize; - ie.count = ie.item->stackSize; - add(name, diff); +void InventorySystem::add(const std::string& name, int count) +{ + for (unsigned int i = 0; i < items.size(); i++) { + if ((items[i].item != nullptr && items[i].item->name == name + && items[i].count < items[i].item->stackSize) + || items[i].count == 0) { + add(name, count, static_cast<int>(i)); + break; } } } @@ -395,9 +399,11 @@ bool InventorySystem::save(void) // signature? s << "831998\n"; + int idx = 0; for (const auto& i : items) { if (i.item != nullptr && i.count > 0) - s << std::string(i.item->name) << '\n' << i.count << '\n'; + s << std::string(i.item->name) << '\n' << i.count << '\n' << idx << '\n'; + idx++; } // end of list? @@ -417,11 +423,12 @@ void InventorySystem::load(void) if (std::stoi(lines[0]) != 831998) UserError("Save file signature is invalid... (delete it)"); - for (unsigned int i = 1; i < lines.size(); i += 2) { + for (unsigned int i = 1; i < lines.size(); i += 3) { if (lines[i].size() > 0) { int count = std::stoi(lines[i + 1]); + int slot = std::stoi(lines[i + 2]); if (count > 0) - add(lines[i], count); + add(lines[i], count, slot); } } } |