2013-05-08 01:33:42 +00:00
|
|
|
#ifndef USERSETTINGS_HPP
|
|
|
|
#define USERSETTINGS_HPP
|
|
|
|
|
|
|
|
#include <QTextStream>
|
|
|
|
#include <QStringList>
|
|
|
|
#include <QString>
|
|
|
|
#include <QMap>
|
|
|
|
|
|
|
|
#include <boost/filesystem/path.hpp>
|
|
|
|
|
|
|
|
#include "support.hpp"
|
|
|
|
|
2013-06-15 11:40:18 +00:00
|
|
|
#ifndef Q_MOC_RUN
|
|
|
|
#include <components/files/configurationmanager.hpp>
|
|
|
|
#endif
|
|
|
|
|
2013-05-08 01:33:42 +00:00
|
|
|
namespace Files { typedef std::vector<boost::filesystem::path> PathContainer;
|
|
|
|
struct ConfigurationManager;}
|
|
|
|
|
|
|
|
class QFile;
|
|
|
|
|
2013-05-11 10:55:46 +00:00
|
|
|
namespace CSMSettings {
|
2013-05-08 01:33:42 +00:00
|
|
|
|
2013-05-12 20:15:57 +00:00
|
|
|
struct UserSettings: public QObject
|
2013-05-08 01:33:42 +00:00
|
|
|
{
|
2013-05-12 20:15:57 +00:00
|
|
|
|
|
|
|
Q_OBJECT
|
|
|
|
|
2013-06-15 11:40:18 +00:00
|
|
|
SectionMap mSectionSettings;
|
2013-06-20 23:06:25 +00:00
|
|
|
static UserSettings *mUserSettingsInstance;
|
2013-06-15 11:40:18 +00:00
|
|
|
QStringList mPaths;
|
|
|
|
Files::ConfigurationManager mCfgMgr;
|
|
|
|
QString mReadOnlyMessage;
|
|
|
|
QString mReadWriteMessage;
|
|
|
|
|
2013-05-08 01:33:42 +00:00
|
|
|
public:
|
2013-05-12 01:55:36 +00:00
|
|
|
|
2013-06-20 23:06:25 +00:00
|
|
|
/// Singleton implementation
|
|
|
|
static UserSettings& instance();
|
|
|
|
|
2013-06-12 10:36:35 +00:00
|
|
|
UserSettings();
|
|
|
|
~UserSettings();
|
2013-05-12 01:55:36 +00:00
|
|
|
|
2013-06-20 23:06:25 +00:00
|
|
|
UserSettings (UserSettings const &); //not implemented
|
|
|
|
void operator= (UserSettings const &); //not implemented
|
2013-05-08 01:33:42 +00:00
|
|
|
|
2013-06-20 23:06:25 +00:00
|
|
|
/// Writes settings to the last loaded settings file
|
|
|
|
bool writeSettings(QMap<QString, SettingList *> §ions);
|
2013-05-08 01:33:42 +00:00
|
|
|
|
2013-06-20 23:06:25 +00:00
|
|
|
/// Called from editor to trigger signal to update the specified setting.
|
|
|
|
/// If no setting name is specified, all settings found in the specified section are updated.
|
2013-06-15 11:40:18 +00:00
|
|
|
void updateSettings (const QString §ionName, const QString &settingName = "");
|
2013-06-20 23:06:25 +00:00
|
|
|
|
|
|
|
/// Retrieves the settings file at all three levels (global, local and user).
|
|
|
|
|
2013-06-20 23:08:53 +00:00
|
|
|
/// \todo Multi-valued settings are not fully implemented. Setting values
|
|
|
|
/// \todo loaded in later files will always overwrite previously loaded values.
|
2013-06-15 11:40:18 +00:00
|
|
|
void loadSettings (const QString &fileName);
|
2013-05-08 01:33:42 +00:00
|
|
|
|
2013-06-20 23:06:25 +00:00
|
|
|
/// Returns the entire map of settings across all sections
|
|
|
|
const SectionMap &getSettings () const;
|
2013-05-12 01:55:36 +00:00
|
|
|
|
2013-06-20 23:06:25 +00:00
|
|
|
/// Retrieves the value as a QString of the specified setting in the specified section
|
|
|
|
QString getSetting(const QString §ion, const QString &setting) const;
|
2013-05-08 01:33:42 +00:00
|
|
|
|
|
|
|
private:
|
2013-05-12 01:55:36 +00:00
|
|
|
|
2013-06-12 10:36:35 +00:00
|
|
|
|
2013-06-20 23:06:25 +00:00
|
|
|
/// Opens a QTextStream from the provided path as read-only or read-write.
|
|
|
|
QTextStream *openFileStream (const QString &filePath, bool isReadOnly = false) const;
|
2013-05-12 01:55:36 +00:00
|
|
|
|
2013-06-20 23:06:25 +00:00
|
|
|
/// Parses a setting file specified in filePath from the provided text stream.
|
2013-06-15 11:40:18 +00:00
|
|
|
void loadFromFile (const QString &filePath = "");
|
|
|
|
|
2013-05-12 20:15:57 +00:00
|
|
|
signals:
|
2013-06-20 23:06:25 +00:00
|
|
|
|
2013-05-12 20:15:57 +00:00
|
|
|
void signalUpdateEditorSetting (const QString &settingName, const QString &settingValue);
|
|
|
|
|
2013-05-08 01:33:42 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
#endif // USERSETTINGS_HPP
|