2012-06-26 20:23:05 +00:00
|
|
|
// * This file is part of the COLOBOT source code
|
|
|
|
// * Copyright (C) 2001-2008, Daniel ROUX & EPSITEC SA, www.epsitec.ch
|
|
|
|
// *
|
|
|
|
// * This program is free software: you can redistribute it and/or modify
|
|
|
|
// * it under the terms of the GNU General Public License as published by
|
|
|
|
// * the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// * (at your option) any later version.
|
|
|
|
// *
|
|
|
|
// * This program is distributed in the hope that it will be useful,
|
|
|
|
// * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// * GNU General Public License for more details.
|
|
|
|
// *
|
|
|
|
// * You should have received a copy of the GNU General Public License
|
|
|
|
// * along with this program. If not, see http://www.gnu.org/licenses/.
|
|
|
|
|
2012-09-09 15:51:10 +00:00
|
|
|
/**
|
|
|
|
* \file common/profile.h
|
|
|
|
* \brief Class for loading profile (currently for loading ini config file)
|
|
|
|
*/
|
2012-06-26 20:23:05 +00:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2012-09-09 15:51:10 +00:00
|
|
|
#include "common/singleton.h"
|
2012-06-26 20:23:05 +00:00
|
|
|
|
2012-10-17 19:55:45 +00:00
|
|
|
#include <boost/property_tree/ptree.hpp>
|
2013-03-17 18:01:32 +00:00
|
|
|
#include <boost/filesystem.hpp>
|
|
|
|
#include <boost/algorithm/string/replace.hpp>
|
2012-10-17 19:55:45 +00:00
|
|
|
|
2012-09-09 15:51:10 +00:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
2012-08-09 21:04:29 +00:00
|
|
|
|
2013-03-17 18:01:32 +00:00
|
|
|
namespace fs = boost::filesystem;
|
|
|
|
|
2012-08-12 13:00:37 +00:00
|
|
|
|
|
|
|
/**
|
2012-10-17 19:55:45 +00:00
|
|
|
* \class CProfile
|
2012-08-12 13:00:37 +00:00
|
|
|
*
|
2012-10-17 19:55:45 +00:00
|
|
|
* \brief Class for loading profile (currently for loading ini config file)
|
2012-08-12 13:00:37 +00:00
|
|
|
*
|
|
|
|
*/
|
2012-08-09 21:04:29 +00:00
|
|
|
class CProfile : public CSingleton<CProfile>
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
CProfile();
|
|
|
|
~CProfile();
|
|
|
|
|
2012-08-12 13:00:37 +00:00
|
|
|
/** Loads colobot.ini from current directory
|
2012-10-17 19:55:45 +00:00
|
|
|
* \return return true on success
|
2012-08-12 13:00:37 +00:00
|
|
|
*/
|
2012-08-09 21:04:29 +00:00
|
|
|
bool InitCurrentDirectory();
|
2012-08-12 13:00:37 +00:00
|
|
|
|
2013-05-04 09:56:03 +00:00
|
|
|
/** Saves colobot.ini to current directory
|
|
|
|
* \return return true on success
|
|
|
|
*/
|
|
|
|
bool SaveCurrentDirectory();
|
|
|
|
|
2012-08-12 13:00:37 +00:00
|
|
|
/** Sets string value in section under specified key
|
2012-10-17 19:55:45 +00:00
|
|
|
* \param section
|
|
|
|
* \param key
|
|
|
|
* \param value
|
|
|
|
* \return return true on success
|
2012-08-12 13:00:37 +00:00
|
|
|
*/
|
2012-08-09 21:04:29 +00:00
|
|
|
bool SetLocalProfileString(std::string section, std::string key, std::string value);
|
2012-08-12 13:00:37 +00:00
|
|
|
|
|
|
|
/** Gets string value in section under specified key
|
2012-10-17 19:55:45 +00:00
|
|
|
* \param section
|
|
|
|
* \param key
|
|
|
|
* \param buffer
|
|
|
|
* \return return true on success
|
2012-08-12 13:00:37 +00:00
|
|
|
*/
|
2012-08-09 21:04:29 +00:00
|
|
|
bool GetLocalProfileString(std::string section, std::string key, std::string& buffer);
|
|
|
|
|
2012-08-12 13:00:37 +00:00
|
|
|
/** Sets int value in section under specified key
|
2012-10-17 19:55:45 +00:00
|
|
|
* \param section
|
|
|
|
* \param key
|
|
|
|
* \param value
|
|
|
|
* \return return true on success
|
2012-08-12 13:00:37 +00:00
|
|
|
*/
|
2012-08-09 21:04:29 +00:00
|
|
|
bool SetLocalProfileInt(std::string section, std::string key, int value);
|
2012-08-12 13:00:37 +00:00
|
|
|
|
|
|
|
/** Gets int value in section under specified key
|
2012-10-17 19:55:45 +00:00
|
|
|
* \param section
|
|
|
|
* \param key
|
|
|
|
* \param value
|
|
|
|
* \return return true on success
|
2012-08-12 13:00:37 +00:00
|
|
|
*/
|
2012-08-09 21:04:29 +00:00
|
|
|
bool GetLocalProfileInt(std::string section, std::string key, int &value);
|
|
|
|
|
2012-08-12 13:00:37 +00:00
|
|
|
/** Sets float value in section under specified key
|
2012-10-17 19:55:45 +00:00
|
|
|
* \param section
|
|
|
|
* \param key
|
|
|
|
* \param value
|
|
|
|
* \return return true on success
|
2012-08-12 13:00:37 +00:00
|
|
|
*/
|
2012-08-09 21:04:29 +00:00
|
|
|
bool SetLocalProfileFloat(std::string section, std::string key, float value);
|
2012-08-12 13:00:37 +00:00
|
|
|
|
|
|
|
/** Gets float value in section under specified key
|
2012-10-17 19:55:45 +00:00
|
|
|
* \param section
|
|
|
|
* \param key
|
|
|
|
* \param value
|
|
|
|
* \return return true on success
|
2012-08-12 13:00:37 +00:00
|
|
|
*/
|
2012-08-09 21:04:29 +00:00
|
|
|
bool GetLocalProfileFloat(std::string section, std::string key, float &value);
|
|
|
|
|
2012-08-12 13:00:37 +00:00
|
|
|
/** Gets all values in section under specified key
|
2012-10-17 19:55:45 +00:00
|
|
|
* \param section
|
|
|
|
* \param key
|
|
|
|
* \return vector of values
|
2012-08-12 13:00:37 +00:00
|
|
|
*/
|
|
|
|
std::vector< std::string > GetLocalProfileSection(std::string section, std::string key);
|
2013-03-17 18:01:32 +00:00
|
|
|
|
|
|
|
/** Sets current user directory
|
|
|
|
* \param dir
|
|
|
|
*/
|
|
|
|
void SetUserDir(std::string dir);
|
|
|
|
|
|
|
|
/** Returns path based on current user. Replaces %user% in path with current user dir or
|
|
|
|
* uses default_dir param if no user dir is specified
|
|
|
|
* \param dir
|
|
|
|
* \param default_dir
|
|
|
|
* \return path
|
|
|
|
*/
|
|
|
|
std::string GetUserBasedPath(std::string dir, std::string default_dir);
|
|
|
|
|
|
|
|
/** opy a file into the temporary folder.
|
|
|
|
* \param filename
|
|
|
|
* \return true on success
|
|
|
|
*/
|
|
|
|
bool CopyFileToTemp(std::string filename);
|
2012-08-09 21:04:29 +00:00
|
|
|
|
|
|
|
private:
|
2012-09-26 20:57:43 +00:00
|
|
|
boost::property_tree::ptree m_propertyTree;
|
2012-09-26 22:30:47 +00:00
|
|
|
bool m_profileNeedSave;
|
2013-03-17 18:01:32 +00:00
|
|
|
std::string m_userDirectory;
|
2012-08-09 21:04:29 +00:00
|
|
|
};
|
2012-08-12 13:00:37 +00:00
|
|
|
|
|
|
|
//! Global function to get profile instance
|
2012-10-02 19:44:14 +00:00
|
|
|
inline CProfile & GetProfile() {
|
|
|
|
return *CProfile::GetInstancePointer();
|
2012-08-12 13:00:37 +00:00
|
|
|
}
|