summaryrefslogtreecommitdiffstats
path: root/src/common
diff options
context:
space:
mode:
authorZaba999 <zaba.marcin@gmail.com>2012-09-26 22:57:43 +0200
committerZaba999 <zaba.marcin@gmail.com>2012-09-26 22:57:43 +0200
commitf6638a173e21fbee3cc961d3dea82cc89382b873 (patch)
tree115936bf2657563b347f3d0e20735d9f4b5da689 /src/common
parent6cce7ec6fd262178ce91d218f9287363842349cd (diff)
downloadcolobot-f6638a173e21fbee3cc961d3dea82cc89382b873.tar.gz
colobot-f6638a173e21fbee3cc961d3dea82cc89382b873.tar.bz2
colobot-f6638a173e21fbee3cc961d3dea82cc89382b873.zip
Work in progress on opening files, and listing dirs
Fixed includes profile changed from SimpleIni to boost::ptree -> not finished yet
Diffstat (limited to 'src/common')
-rw-r--r--src/common/global.h8
-rw-r--r--src/common/profile.cpp118
-rw-r--r--src/common/profile.h6
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