diff --git a/src/persistence/paths.cpp b/src/persistence/paths.cpp index f3f398665..73a168750 100644 --- a/src/persistence/paths.cpp +++ b/src/persistence/paths.cpp @@ -29,6 +29,8 @@ #include #include +#include + namespace { const QLatin1String globalSettingsFile{"qtox.ini"}; const QLatin1String profileFolder{"profiles"}; @@ -74,56 +76,58 @@ const QLatin1String TCSToxFileFolder{"~/.config/tox/"}; * All qTox or Tox specific directories should be looked up through this module. */ -/** - * @brief Paths::makePaths Factory method for the Paths object - * @param mode - * @return Pointer to Paths object on success, nullptr else - */ -Paths* Paths::makePaths(Portable mode) -{ - bool portable = false; - const QString basePortable = qApp->applicationDirPath(); - const QString baseNonPortable = QStandardPaths::writableLocation(QStandardPaths::AppDataLocation); - const QString portableSettingsPath = basePortable % QDir::separator() % globalSettingsFile; +namespace { + using Portable = Paths::Portable; + bool portableFromMode(Portable mode) + { + bool portable = false; + const QString basePortable = qApp->applicationDirPath(); + const QString baseNonPortable = QStandardPaths::writableLocation(QStandardPaths::AppDataLocation); + const QString portableSettingsPath = basePortable % QDir::separator() % globalSettingsFile; - switch (mode) { - case Portable::Portable: - qDebug() << "Forcing portable"; - portable = true; - break; - case Portable::NonPortable: - qDebug() << "Forcing non-portable"; - portable = false; - break; - case Portable::Auto: - if (QFile(portableSettingsPath).exists()) { - QSettings ps(portableSettingsPath, QSettings::IniFormat); - ps.setIniCodec("UTF-8"); - ps.beginGroup("Advanced"); - portable = ps.value("makeToxPortable", false).toBool(); - ps.endGroup(); - } else { - portable = false; + switch (mode) { + case Portable::Portable: + qDebug() << "Forcing portable"; + return true; + case Portable::NonPortable: + qDebug() << "Forcing non-portable"; + return false; + case Portable::Auto: + if (QFile(portableSettingsPath).exists()) { + QSettings ps(portableSettingsPath, QSettings::IniFormat); + ps.setIniCodec("UTF-8"); + ps.beginGroup("Advanced"); + portable = ps.value("makeToxPortable", false).toBool(); + ps.endGroup(); + } else { + portable = false; + } + qDebug()<< "Auto portable mode:" << portable; + return portable; } - qDebug()<< "Auto portable mode:" << portable; - break; + assert(!"Unhandled enum class Paths::Portable value"); + return false; } - QString basePath = portable ? basePortable : baseNonPortable; - - if (basePath.isEmpty()) { - qCritical() << "Couldn't find writable path"; - return nullptr; + QString basePathFromPortable(bool portable) + { + const QString basePortable = qApp->applicationDirPath(); + const QString baseNonPortable = QStandardPaths::writableLocation(QStandardPaths::AppDataLocation); + QString basePath = portable ? basePortable : baseNonPortable; + if (basePath.isEmpty()) { + assert(!"Couldn't find writeable path"); + qCritical() << "Couldn't find writable path"; + } + return basePath; } +} // namespace - return new Paths(basePath, portable); +Paths::Paths(Portable mode) +{ + portable = portableFromMode(mode); + basePath = basePathFromPortable(portable); } -Paths::Paths(const QString& basePath, bool portable) - : basePath{basePath} - , portable{portable} -{} - /** * @brief Set paths to passed portable or system wide * @param newPortable diff --git a/src/persistence/paths.h b/src/persistence/paths.h index 47c7dcd05..c1b33f48e 100644 --- a/src/persistence/paths.h +++ b/src/persistence/paths.h @@ -34,7 +34,7 @@ public: NonPortable /** Force non-portable mode */ }; - static Paths* makePaths(Portable mode = Portable::Auto); + Paths(Portable mode = Portable::Auto); bool setPortable(bool portable); bool isPortable() const; @@ -54,11 +54,7 @@ public: QString getUserNodesFilePath() const; #endif - private: - Paths(const QString &basePath, bool portable); - -private: - QString basePath{}; + QString basePath; std::atomic_bool portable{false}; }; diff --git a/src/persistence/settings.cpp b/src/persistence/settings.cpp index 461cae1dc..f4c27f35f 100644 --- a/src/persistence/settings.cpp +++ b/src/persistence/settings.cpp @@ -67,7 +67,6 @@ Settings::Settings() , useCustomDhtList{false} , makeToxPortable{false} , currentProfileId(0) - , paths(*Paths::makePaths(Paths::Portable::Auto)) { settingsThread = new QThread(); settingsThread->setObjectName("qTox Settings"); @@ -873,7 +872,6 @@ void Settings::setMakeToxPortable(bool newValue) bool changed = false; { QMutexLocker locker{&bigLock}; - QFile(paths.getSettingsDirPath() + globalSettingsFile).remove() if (newValue != makeToxPortable) { QFile(paths.getSettingsDirPath() + globalSettingsFile).remove(); makeToxPortable = newValue; diff --git a/test/net/bsu_test.cpp b/test/net/bsu_test.cpp index 32f301423..c37c0bcf9 100644 --- a/test/net/bsu_test.cpp +++ b/test/net/bsu_test.cpp @@ -48,9 +48,9 @@ TestBootstrapNodesUpdater::TestBootstrapNodesUpdater() void TestBootstrapNodesUpdater::testOnline() { QNetworkProxy proxy{QNetworkProxy::ProxyType::NoProxy}; - auto paths = Paths::makePaths(Paths::Portable::NonPortable); + Paths paths{Paths::Portable::NonPortable}; - BootstrapNodeUpdater updater{proxy, *paths}; + BootstrapNodeUpdater updater{proxy, paths}; QSignalSpy spy(&updater, &BootstrapNodeUpdater::availableBootstrapNodes); updater.requestBootstrapNodes(); diff --git a/test/persistence/paths_test.cpp b/test/persistence/paths_test.cpp index edf0f93bc..0fcf6c399 100644 --- a/test/persistence/paths_test.cpp +++ b/test/persistence/paths_test.cpp @@ -56,11 +56,10 @@ const QString sep{QDir::separator()}; */ void TestPaths::constructAuto() { - Paths * paths = Paths::makePaths(Paths::Portable::Auto); + Paths paths{Paths::Portable::Auto}; // auto detection should succeed - QVERIFY(paths != nullptr); // the test environment should not provide a `qtox.ini` - QVERIFY(paths->isPortable() == false); + QVERIFY(paths.isPortable() == false); } /** @@ -68,10 +67,9 @@ void TestPaths::constructAuto() */ void TestPaths::constructPortable() { - Paths * paths = Paths::makePaths(Paths::Portable::Portable); + Paths paths{Paths::Portable::Portable}; // portable construction should succeed even though qtox.ini doesn't exist - QVERIFY(paths != nullptr); - QVERIFY(paths->isPortable() == true); + QVERIFY(paths.isPortable() == true); } /** @@ -79,11 +77,10 @@ void TestPaths::constructPortable() */ void TestPaths::constructNonPortable() { - Paths * paths = Paths::makePaths(Paths::Portable::NonPortable); + Paths paths{Paths::Portable::NonPortable}; // Non portable should succeed - QVERIFY(paths != nullptr); // the test environment should not provide a `qtox.ini` - QVERIFY(paths->isPortable() == false); + QVERIFY(paths.isPortable() == false); } /**