X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fsettings.h;h=08db0cd97f538bca4ac911ead653096623b25989;hp=9ad960dd8b206d43b251bfecc7eca92b50625be3;hb=10f9c27ee5d92ece2931947cd341c7f7b548f580;hpb=8699dd758516d0ded076811e8ea656adc95e69d0 diff --git a/src/common/settings.h b/src/common/settings.h index 9ad960dd..08db0cd9 100644 --- a/src/common/settings.h +++ b/src/common/settings.h @@ -18,41 +18,80 @@ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ -#ifndef _SETTINGS_H_ -#define _SETTINGS_H_ +#ifndef SETTINGS_H +#define SETTINGS_H +#include +#include #include #include -#include -class Settings : private QSettings { +class SettingsChangeNotifier : public QObject { + Q_OBJECT - public: - virtual ~Settings(); +signals: + void valueChanged(const QVariant &newValue); - //static void setGuiValue(QString, QVariant) {}; - //static QVariant guiValue(QString, QVariant = QVariant()) { return QVariant(); } - - enum Mode { Default, Custom }; +private: + friend class Settings; +}; - protected: - Settings(QString group, QString applicationName); +class Settings { +public: + enum Mode { Default, Custom }; - void setGroup(QString group); +public: + void notify(const QString &key, QObject *receiver, const char *slot); - virtual QStringList allLocalKeys(); - virtual QStringList localChildKeys(const QString &rootkey = QString()); - virtual QStringList localChildGroups(const QString &rootkey = QString()); +protected: + inline Settings(QString group_, QString appName_) : group(group_), appName(appName_) {} + inline virtual ~Settings() {} - virtual void setLocalValue(const QString &key, const QVariant &data); - virtual QVariant localValue(const QString &key, const QVariant &def = QVariant()); + inline void setGroup(const QString &group_) { group = group_; } - virtual void removeLocalKey(const QString &key); + virtual QStringList allLocalKeys(); + virtual QStringList localChildKeys(const QString &rootkey = QString()); + virtual QStringList localChildGroups(const QString &rootkey = QString()); - QString group; + 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); + QString group; + QString appName; +private: + inline QString org() { +#ifdef Q_WS_MAC + return QCoreApplication::organizationDomain(); +#else + return QCoreApplication::organizationName(); +#endif + } + + static QHash > settingsCache; + static QHash > settingsChangeNotifier; + + inline void setCacheValue(const QString &group, const QString &key, const QVariant &data) { + settingsCache[group][key] = data; + } + inline const QVariant &cacheValue(const QString &group, const QString &key) { + return settingsCache[group][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