projects
/
quassel.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Well, if we check for a settings version, maybe we should set it too...
[quassel.git]
/
src
/
common
/
settings.h
diff --git
a/src/common/settings.h
b/src/common/settings.h
index
1a51591
..
26c8ead
100644
(file)
--- a/
src/common/settings.h
+++ b/
src/common/settings.h
@@
-1,5
+1,5
@@
/***************************************************************************
/***************************************************************************
- * Copyright (C) 2005-0
8
by the Quassel Project *
+ * Copyright (C) 2005-0
9
by the Quassel Project *
* devel@quassel-irc.org *
* *
* This program is free software; you can redistribute it and/or modify *
* devel@quassel-irc.org *
* *
* This program is free software; you can redistribute it and/or modify *
@@
-23,41
+23,64
@@
#include <QCoreApplication>
#include <QHash>
#include <QCoreApplication>
#include <QHash>
+#include <QSettings>
#include <QString>
#include <QVariant>
#include <QString>
#include <QVariant>
+#include "quassel.h"
+
+class SettingsChangeNotifier : public QObject {
+ Q_OBJECT
+
+signals:
+ void valueChanged(const QVariant &newValue);
+
+private:
+ friend class Settings;
+};
+
class Settings {
public:
enum Mode { Default, Custom };
class Settings {
public:
enum Mode { Default, Custom };
-
+
+public:
+ virtual void notify(const QString &key, QObject *receiver, const char *slot);
+ virtual uint version();
+
protected:
inline Settings(QString group_, QString appName_) : group(group_), appName(appName_) {}
inline virtual ~Settings() {}
protected:
inline Settings(QString group_, QString appName_) : group(group_), appName(appName_) {}
inline virtual ~Settings() {}
-
+
inline void setGroup(const QString &group_) { group = group_; }
inline void setGroup(const QString &group_) { group = group_; }
-
+
virtual QStringList allLocalKeys();
virtual QStringList localChildKeys(const QString &rootkey = QString());
virtual QStringList localChildGroups(const QString &rootkey = QString());
virtual QStringList allLocalKeys();
virtual QStringList localChildKeys(const QString &rootkey = QString());
virtual QStringList localChildGroups(const QString &rootkey = QString());
-
+
virtual void setLocalValue(const QString &key, const QVariant &data);
virtual const QVariant &localValue(const QString &key, const QVariant &def = QVariant());
virtual void setLocalValue(const QString &key, const QVariant &data);
virtual const QVariant &localValue(const QString &key, const QVariant &def = QVariant());
-
+
virtual void removeLocalKey(const QString &key);
virtual void removeLocalKey(const QString &key);
-
+
QString group;
QString appName;
private:
QString group;
QString appName;
private:
- inline QS
tring org
() {
-#ifdef Q_WS_
MAC
- return Q
CoreApplication::organizationDomain()
;
+ inline QS
ettings::Format format
() {
+#ifdef Q_WS_
WIN
+ return Q
Settings::IniFormat
;
#else
#else
- return Q
CoreApplication::organizationName()
;
+ return Q
Settings::NativeFormat
;
#endif
}
#endif
}
+ inline QString fileName() {
+ return Quassel::configDirPath() + appName
+ + ((format() == QSettings::NativeFormat) ? QLatin1String(".conf") : QLatin1String(".ini"));
+ }
static QHash<QString, QHash<QString, QVariant> > settingsCache;
static QHash<QString, QHash<QString, QVariant> > settingsCache;
+ static QHash<QString, QHash<QString, SettingsChangeNotifier *> > settingsChangeNotifier;
+
inline void setCacheValue(const QString &group, const QString &key, const QVariant &data) {
settingsCache[group][key] = data;
}
inline void setCacheValue(const QString &group, const QString &key, const QVariant &data) {
settingsCache[group][key] = data;
}
@@
-67,8
+90,16
@@
private:
inline bool isCached(const QString &group, const QString &key) {
return settingsCache.contains(group) && settingsCache[group].contains(key);
}
inline bool isCached(const QString &group, const QString &key) {
return settingsCache.contains(group) && settingsCache[group].contains(key);
}
-};
+ inline SettingsChangeNotifier *notifier(const QString &group, const QString &key) {
+ if(!hasNotifier(group, key))
+ settingsChangeNotifier[group][key] = new SettingsChangeNotifier();
+ return settingsChangeNotifier[group][key];
+ }
+ inline bool hasNotifier(const QString &group, const QString &key) {
+ return settingsChangeNotifier.contains(group) && settingsChangeNotifier[group].contains(key);
+ }
+};
#endif
#endif