diff --git a/Source/Core/Common/IniFile.cpp b/Source/Core/Common/IniFile.cpp index 604c4b0fc9..85fd180cd5 100644 --- a/Source/Core/Common/IniFile.cpp +++ b/Source/Core/Common/IniFile.cpp @@ -45,23 +45,18 @@ IniFile::Section::Section(std::string name_) : name{std::move(name_)} { } -void IniFile::Section::Set(const std::string& key, const std::string& newValue) +void IniFile::Section::Set(const std::string& key, std::string new_value) { auto it = values.find(key); if (it != values.end()) - it->second = newValue; + it->second = std::move(new_value); else { - values[key] = newValue; + values[key] = std::move(new_value); keys_order.push_back(key); } } -void IniFile::Section::Set(const std::string& key, const std::vector& newValues) -{ - Set(key, JoinStrings(newValues, ",")); -} - bool IniFile::Section::Get(const std::string& key, std::string* value, const std::string& defaultValue) const { @@ -80,36 +75,6 @@ bool IniFile::Section::Get(const std::string& key, std::string* value, return false; } -bool IniFile::Section::Get(const std::string& key, std::vector* out) const -{ - std::string temp; - bool retval = Get(key, &temp); - if (!retval || temp.empty()) - { - return false; - } - - // ignore starting comma, if any - size_t subStart = temp.find_first_not_of(","); - - // split by comma - while (subStart != std::string::npos) - { - // Find next comma - size_t subEnd = temp.find(',', subStart); - if (subStart != subEnd) - { - // take from first char until next comma - out->push_back(StripSpaces(temp.substr(subStart, subEnd - subStart))); - } - - // Find the next non-comma char - subStart = temp.find_first_not_of(",", subEnd); - } - - return true; -} - bool IniFile::Section::Exists(const std::string& key) const { return values.find(key) != values.end(); @@ -126,12 +91,7 @@ bool IniFile::Section::Delete(const std::string& key) return true; } -void IniFile::Section::SetLines(const std::vector& lines) -{ - m_lines = lines; -} - -void IniFile::Section::SetLines(std::vector&& lines) +void IniFile::Section::SetLines(std::vector lines) { m_lines = std::move(lines); } diff --git a/Source/Core/Common/IniFile.h b/Source/Core/Common/IniFile.h index f11a4b9d32..b085ad1741 100644 --- a/Source/Core/Common/IniFile.h +++ b/Source/Core/Common/IniFile.h @@ -35,26 +35,26 @@ public: bool Exists(const std::string& key) const; bool Delete(const std::string& key); - void Set(const std::string& key, const std::string& newValue); + void Set(const std::string& key, std::string new_value); + template - void Set(const std::string& key, const T& new_value) + void Set(const std::string& key, T&& new_value) { - Set(key, ValueToString(new_value)); + Set(key, ValueToString(std::forward(new_value))); } template - void Set(const std::string& key, const T& new_value, const std::common_type_t& default_value) + void Set(const std::string& key, T&& new_value, const std::common_type_t& default_value) { if (new_value != default_value) - Set(key, new_value); + Set(key, std::forward(new_value)); else Delete(key); } - void Set(const std::string& key, const std::vector& newValues); - bool Get(const std::string& key, std::string* value, - const std::string& defaultValue = NULL_STRING) const; + const std::string& default_value = NULL_STRING) const; + template bool Get(const std::string& key, T* value, const std::common_type_t& default_value = {}) const @@ -66,10 +66,8 @@ public: *value = default_value; return false; } - bool Get(const std::string& key, std::vector* values) const; - void SetLines(const std::vector& lines); - void SetLines(std::vector&& lines); + void SetLines(std::vector lines); bool GetLines(std::vector* lines, const bool remove_comments = true) const; bool operator<(const Section& other) const { return name < other.name; }