diff options
Diffstat (limited to 'src/common')
-rw-r--r-- | src/common/global.h | 8 | ||||
-rw-r--r-- | src/common/profile.cpp | 118 | ||||
-rw-r--r-- | src/common/profile.h | 6 |
3 files changed, 102 insertions, 30 deletions
diff --git a/src/common/global.h b/src/common/global.h index 2f2104a..9704a2b 100644 --- a/src/common/global.h +++ b/src/common/global.h @@ -29,10 +29,10 @@ */ enum Language { - LANG_ENGLISH = 0, - LANG_FRENCH = 1, - LANG_GERMAN = 2, - LANG_POLISH = 3 + LANGUAGE_ENGLISH = 0, + LANGUAGE_FRENCH = 1, + LANGUAGE_GERMAN = 2, + LANGUAGE_POLISH = 3 }; /** diff --git a/src/common/profile.cpp b/src/common/profile.cpp index 1025567..0881c92 100644 --- a/src/common/profile.cpp +++ b/src/common/profile.cpp @@ -18,76 +18,132 @@ #include "common/profile.h" +#include "common/logger.h" #include <utility> #include <cstring> +#include <boost/property_tree/ini_parser.hpp> template<> CProfile* CSingleton<CProfile>::mInstance = nullptr; +namespace bp = boost::property_tree; CProfile::CProfile() { - m_ini = new CSimpleIniA(); - m_ini->SetUnicode(); - m_ini->SetMultiKey(); + // m_ini = new CSimpleIniA(); + // m_ini->SetUnicode(); + // m_ini->SetMultiKey(); } CProfile::~CProfile() { - m_ini->Reset(); - delete m_ini; + // m_ini->Reset(); + // delete m_ini; } bool CProfile::InitCurrentDirectory() { - bool result = m_ini->LoadFile("colobot.ini") == SI_OK; - return result; + try + { + bp::ini_parser::read_ini("colobot.ini", m_propertyTree); + } + catch (std::exception & e) + { + GetLogger()->Info("Error on parsing profile: %s\n", e.what()); + } + // return result; + return true; } bool CProfile::SetLocalProfileString(std::string section, std::string key, std::string value) { - return (m_ini->SetValue(section.c_str(), key.c_str(), value.c_str()) == SI_OK); + try + { + m_propertyTree.put(section + "." + key, value); + } + catch (std::exception & e) + { + GetLogger()->Info("Error on parsing profile: %s\n", e.what()); + } + // return (m_ini->SetValue(section.c_str(), key.c_str(), value.c_str()) == SI_OK); + return true; } bool CProfile::GetLocalProfileString(std::string section, std::string key, std::string &buffer) { - const char* value = m_ini->GetValue(section.c_str(), key.c_str(), nullptr); - if (value != nullptr && strlen(value) > 0) { - buffer = std::string(value); - return true; + try + { + buffer = m_propertyTree.get<std::string>(section + "." + key); } - - return false; + catch (std::exception & e) + { + GetLogger()->Info("Error on parsing profile: %s\n", e.what()); + } + return true; } bool CProfile::SetLocalProfileInt(std::string section, std::string key, int value) { - return (m_ini->SetLongValue(section.c_str(), key.c_str(), value) == SI_OK); + try + { + m_propertyTree.put(section + "." + key, value); + } + catch (std::exception & e) + { + GetLogger()->Info("Error on parsing profile: %s\n", e.what()); + } + // return (m_ini->SetLongValue(section.c_str(), key.c_str(), value) == SI_OK); + return true; } bool CProfile::GetLocalProfileInt(std::string section, std::string key, int &value) { - value = m_ini->GetLongValue(section.c_str(), key.c_str(), 0L); + try + { + value = m_propertyTree.get<int>(section + "." + key); + } + catch (std::exception & e) + { + GetLogger()->Info("Error on parsing profile: %s\n", e.what()); + } + // value = m_ini->GetLongValue(section.c_str(), key.c_str(), 0L); return true; } bool CProfile::SetLocalProfileFloat(std::string section, std::string key, float value) { - return (m_ini->SetDoubleValue(section.c_str(), key.c_str(), value) == SI_OK); + try + { + m_propertyTree.put(section + "." + key, value); + } + catch (std::exception & e) + { + GetLogger()->Info("Error on parsing profile: %s\n", e.what()); + } + // return (m_ini->SetDoubleValue(section.c_str(), key.c_str(), value) == SI_OK); + return true; } bool CProfile::GetLocalProfileFloat(std::string section, std::string key, float &value) { - value = m_ini->GetDoubleValue(section.c_str(), key.c_str(), 0.0d); + try + { + value = m_propertyTree.get<float>(section + "." + key); + } + catch (std::exception & e) + { + GetLogger()->Info("Error on parsing profile: %s\n", e.what()); + } + // value = m_ini->GetDoubleValue(section.c_str(), key.c_str(), 0.0d); return true; } @@ -96,13 +152,27 @@ std::vector< std::string > CProfile::GetLocalProfileSection(std::string section, { std::vector< std::string > ret_list; - CSimpleIniA::TNamesDepend values; - m_ini->GetAllValues(section.c_str(), key.c_str(), values); - values.sort(CSimpleIniA::Entry::LoadOrder()); - - for (auto item : values) { - ret_list.push_back(item.pItem); + try + { + for(bp::ptree::value_type const & v : m_propertyTree.get_child(section)) + { + if (v.first == key) + { + ret_list.push_back(v.second.get_value<std::string>()); + } + } } + catch (std::exception & e) + { + GetLogger()->Info("Error on parsing profile: %s\n", e.what()); + } + // CSimpleIniA::TNamesDepend values; + // m_ini->GetAllValues(section.c_str(), key.c_str(), values); + // values.sort(CSimpleIniA::Entry::LoadOrder()); + + // for (auto item : values) { + // ret_list.push_back(item.pItem); + // } return ret_list; } diff --git a/src/common/profile.h b/src/common/profile.h index 7a23d94..de30a63 100644 --- a/src/common/profile.h +++ b/src/common/profile.h @@ -21,7 +21,7 @@ #pragma once -#include "lib/simpleini/SimpleIni.h" +#include <boost/property_tree/ptree.hpp> #include "common/singleton.h" @@ -102,7 +102,9 @@ class CProfile : public CSingleton<CProfile> std::vector< std::string > GetLocalProfileSection(std::string section, std::string key); private: - CSimpleIniA *m_ini; + // bpt::ptree m_pt; + boost::property_tree::ptree m_propertyTree; + // CSimpleIniA *m_ini; }; //! Global function to get profile instance |