Qt: Fix windows version of Preference Dialog
authorRoland Knall <roland.knall@br-automation.com>
Fri, 5 Jan 2018 14:21:17 +0000 (15:21 +0100)
committerMichael Mann <mmann78@netscape.net>
Fri, 5 Jan 2018 15:14:42 +0000 (15:14 +0000)
Initializing a static member on Windows C++ has to be done differently.

This fixes the segfault introduced with Ia611ec192dcc1ad638a997182cec1ab5bdb7859c

Change-Id: Ib7a9840feda74830f835345c666f57e23e9e4e0b
Reviewed-on: https://code.wireshark.org/review/25163
Reviewed-by: Roland Knall <rknall@gmail.com>
Petri-Dish: Roland Knall <rknall@gmail.com>
Tested-by: Petri Dish Buildbot
Reviewed-by: Michael Mann <mmann78@netscape.net>
ui/qt/manager/preference_manager.cpp
ui/qt/manager/preference_manager.h

index f979eb6c96ff80946e540fe2cfb5246ccd19624b..26e64e040ca2627c1772cd9bf82ba441dbb4084f 100644 (file)
 
 PreferenceFactory::~PreferenceFactory() {}
 
-QMap<int, PreferenceFactory *> PreferenceManager::factories;
+QMap<int, PreferenceFactory *> & PreferenceManager::factories()
+{
+    static QMap<int, PreferenceFactory *> inst = QMap<int, PreferenceFactory *>();
+    return inst;
+}
 
 PreferenceManager::PreferenceManager(QObject * parent)
     : QObject(parent)
@@ -25,7 +29,7 @@ PreferenceManager::PreferenceManager(QObject * parent)
 PreferenceManager::~PreferenceManager()
 {
     /* As this is a singleton, this is the point, where we can clear the registry */
-    PreferenceManager::factories.clear();
+    PreferenceManager::factories().clear();
 }
 
 PreferenceManager * PreferenceManager::instance()
@@ -41,10 +45,10 @@ void PreferenceManager::registerType(int pref, PreferenceFactory * factory)
 {
     Q_ASSERT(pref >= 0);
 
-    if ( PreferenceManager::factories.contains(pref) || ! factory )
+    if ( PreferenceManager::factories().contains(pref) || ! factory )
         return;
 
-    PreferenceManager::factories[pref] = factory;
+    PreferenceManager::factories()[pref] = factory;
 }
 
 WiresharkPreference * PreferenceManager::getPreference(PrefsItem * pref)
@@ -53,11 +57,11 @@ WiresharkPreference * PreferenceManager::getPreference(PrefsItem * pref)
         return Q_NULLPTR;
 
     int key = pref->getPrefType();
-    if ( ! PreferenceManager::factories.contains(key) )
+    if ( ! PreferenceManager::factories().contains(key) )
         return Q_NULLPTR;
 
     /* All actions are parented with this manager, to clear the objects together with the manager */
-    WiresharkPreference * wspref = qobject_cast<WiresharkPreference *>(PreferenceManager::factories[key]->create(this));
+    WiresharkPreference * wspref = qobject_cast<WiresharkPreference *>(PreferenceManager::factories()[key]->create(this));
     if ( wspref )
         wspref->setPrefsItem(pref);
 
index 6ae224ee66a1dcfcca676f0e456d26731a5c410a..99dc16d0beef4568332fece811cfd72bb24aef6a 100644 (file)
@@ -39,7 +39,7 @@ protected:
     explicit PreferenceManager(QObject * parent = Q_NULLPTR);
 
 private:
-    static QMap<int, PreferenceFactory*> factories;
+    static QMap<int, PreferenceFactory*> & factories();
 };
 
 class PreferenceFactory : public QObject