further speed upgrade for settings
authorMarcus Eggenberger <egs@quassel-irc.org>
Fri, 8 Aug 2008 09:29:52 +0000 (11:29 +0200)
committerMarcus Eggenberger <egs@quassel-irc.org>
Fri, 8 Aug 2008 09:29:52 +0000 (11:29 +0200)
src/common/settings.cpp
src/common/settings.h

index eb4fc72..e8ad9d0 100644 (file)
@@ -18,7 +18,6 @@
  *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
  ***************************************************************************/
 
-#include <QCoreApplication>
 #include <QSettings>
 #include <QStringList>
 #include <QDebug>
 
 #include "settings.h"
 
-static QHash<QString, QHash<QString, QVariant> > __settingsCache__;
-
-Settings::Settings(QString g, QString applicationName)
-
-#ifdef Q_WS_MAC
-  : QSettings(QCoreApplication::organizationDomain(), applicationName),
-#else
-  : QSettings(QCoreApplication::organizationName(), applicationName),
-#endif
-    group(g)
-{
-
-/* we need to call the constructor immediately in order to set the path...
-#ifndef Q_WS_QWS
-  QSettings(QCoreApplication::organizationName(), applicationName);
-#else
-  // FIXME sandboxDir() is not currently working correctly...
-  //if(Qtopia::sandboxDir().isEmpty()) QSettings();
-  //else QSettings(Qtopia::sandboxDir() + "/etc/QuasselIRC.conf", QSettings::NativeFormat);
-  // ...so we have to use a workaround:
-  QString appPath = QCoreApplication::applicationFilePath();
-  if(appPath.startsWith(Qtopia::packagePath())) {
-    QString sandboxPath = appPath.left(Qtopia::packagePath().length() + 32);
-    QSettings(sandboxPath + "/etc/QuasselIRC.conf", QSettings::IniFormat);
-    qDebug() << sandboxPath + "/etc/QuasselIRC.conf";
-  } else {
-    QSettings(QCoreApplication::organizationName(), applicationName);
-  }
-#endif
-*/
-}
+QHash<QString, QHash<QString, QVariant> > Settings::settingsCache;
+
+// Settings::Settings(QString group_, QString appName_)
+//   : group(group_),
+//     appName(appName_)
+// {
+
+// /* we need to call the constructor immediately in order to set the path...
+// #ifndef Q_WS_QWS
+//   QSettings(QCoreApplication::organizationName(), applicationName);
+// #else
+//   // FIXME sandboxDir() is not currently working correctly...
+//   //if(Qtopia::sandboxDir().isEmpty()) QSettings();
+//   //else QSettings(Qtopia::sandboxDir() + "/etc/QuasselIRC.conf", QSettings::NativeFormat);
+//   // ...so we have to use a workaround:
+//   QString appPath = QCoreApplication::applicationFilePath();
+//   if(appPath.startsWith(Qtopia::packagePath())) {
+//     QString sandboxPath = appPath.left(Qtopia::packagePath().length() + 32);
+//     QSettings(sandboxPath + "/etc/QuasselIRC.conf", QSettings::IniFormat);
+//     qDebug() << sandboxPath + "/etc/QuasselIRC.conf";
+//   } else {
+//     QSettings(QCoreApplication::organizationName(), applicationName);
+//   }
+// #endif
+// */
+// }
 
 QStringList Settings::allLocalKeys() {
-  beginGroup(group);
-  QStringList res = allKeys();
-  endGroup();
+  QSettings s(org(), appName);
+  s.beginGroup(group);
+  QStringList res = s.allKeys();
+  s.endGroup();
   return res;
 }
 
 QStringList Settings::localChildKeys(const QString &rootkey) {
   QString g;
-  if(rootkey.isEmpty()) g = group;
-  else g = QString("%1/%2").arg(group, rootkey);
-  beginGroup(g);
-  QStringList res = childKeys();
-  endGroup();
+  if(rootkey.isEmpty())
+    g = group;
+  else
+    g = QString("%1/%2").arg(group, rootkey);
+
+  QSettings s(org(), appName);
+  s.beginGroup(g);
+  QStringList res = s.childKeys();
+  s.endGroup();
   return res;
 }
 
 QStringList Settings::localChildGroups(const QString &rootkey) {
   QString g;
-  if(rootkey.isEmpty()) g = group;
-  else g = QString("%1/%2").arg(group, rootkey);
-  beginGroup(g);
-  QStringList res = childGroups();
-  endGroup();
+  if(rootkey.isEmpty())
+    g = group;
+  else
+    g = QString("%1/%2").arg(group, rootkey);
+
+  QSettings s(org(), appName);
+  s.beginGroup(g);
+  QStringList res = s.childGroups();
+  s.endGroup();
   return res;
 }
 
 void Settings::setLocalValue(const QString &key, const QVariant &data) {
-  beginGroup(group);
-  setValue(key, data);
+  QSettings s(org(), appName);
+  s.beginGroup(group);
+  s.setValue(key, data);
+  s.endGroup();
   setCacheValue(group, key, data);
-  endGroup();
 }
 
 const QVariant &Settings::localValue(const QString &key, const QVariant &def) {
   if(!isCached(group, key)) {
-    beginGroup(group);
-    setCacheValue(group, key, value(key, def));
-    endGroup();
+    QSettings s(org(), appName);
+    s.beginGroup(group);
+    setCacheValue(group, key, s.value(key, def));
+    s.endGroup();
   }
   return cacheValue(group, key);
 }
 
 void Settings::removeLocalKey(const QString &key) {
-  beginGroup(group);
-  remove(key);
-  endGroup();
+  QSettings s(org(), appName);
+  s.beginGroup(group);
+  s.remove(key);
+  s.endGroup();
+  if(isCached(group, key))
+    settingsCache[group].remove(key);
 }
 
 
-void Settings::setCacheValue(const QString &group, const QString &key, const QVariant &data) {
-  ::__settingsCache__[group][key] = data;
-}
+// void Settings::setCacheValue(const QString &group, const QString &key, const QVariant &data) {
+//   settingsCache[group][key] = data;
+// }
 
-const QVariant &Settings::cacheValue(const QString &group, const QString &key) {
-  return ::__settingsCache__[group][key];
-}
+// const QVariant &Settings::cacheValue(const QString &group, const QString &key) {
+//   return settingsCache[group][key];
+// }
 
-bool Settings::isCached(const QString &group, const QString &key) {
-  return ::__settingsCache__.contains(group) && ::__settingsCache__[group].contains(key);
-}
+// bool Settings::isCached(const QString &group, const QString &key) {
+//   return settingsCache.contains(group) && settingsCache[group].contains(key);
+// }
index 1816a61..1a51591 100644 (file)
  *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
  ***************************************************************************/
 
-#ifndef _SETTINGS_H_
-#define _SETTINGS_H_
+#ifndef SETTINGS_H
+#define SETTINGS_H
 
+#include <QCoreApplication>
+#include <QHash>
 #include <QString>
 #include <QVariant>
-#include <QSettings>
 
-class Settings : private QSettings {
+class Settings {
 public:
   enum Mode { Default, Custom };
   
 protected:
-  Settings(QString group, QString applicationName);
+  inline Settings(QString group_, QString appName_) : group(group_), appName(appName_) {}
+  inline virtual ~Settings() {}
   
   inline void setGroup(const QString &group_) { group = group_; }
   
@@ -44,11 +46,27 @@ protected:
   virtual void removeLocalKey(const QString &key);
   
   QString group;
+  QString appName;
 
 private:
-  void setCacheValue(const QString &group, const QString &key, const QVariant &data);
-  const QVariant &cacheValue(const QString &group, const QString &key);
-  bool isCached(const QString &group, const QString &key);
+  inline QString org() {
+#ifdef Q_WS_MAC
+    return QCoreApplication::organizationDomain();
+#else
+    return QCoreApplication::organizationName();
+#endif
+  }
+
+  static QHash<QString, QHash<QString, QVariant> > settingsCache;
+  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);
+  }
 };