1
0
mirror of https://github.com/qTox/qTox.git synced 2024-03-22 14:00:36 +08:00

fix: Replace hardcored roaming path on QStandartPath

Fix #4436

In most system user can change AppData location, so hardcored path can
lead to the wrong directory.
This commit is contained in:
Diadlo 2017-06-04 13:15:45 +03:00
parent 099dd30f80
commit f616ff36b6
No known key found for this signature in database
GPG Key ID: 5AF9F2E29107C727
2 changed files with 53 additions and 14 deletions

View File

@ -715,21 +715,35 @@ QString Settings::getSettingsDirPath() const
if (makeToxPortable) if (makeToxPortable)
return qApp->applicationDirPath() + QDir::separator(); return qApp->applicationDirPath() + QDir::separator();
QString path;
#if (QT_VERSION < QT_VERSION_CHECK(5, 4, 0))
// workaround for https://bugreports.qt-project.org/browse/QTBUG-38845 // workaround for https://bugreports.qt-project.org/browse/QTBUG-38845
#ifdef Q_OS_WIN # ifdef Q_OS_WIN
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation)
+ QDir::separator() + "AppData" + QDir::separator() + "Roaming" + QDir::separator() + "AppData" + QDir::separator() + "Roaming"
+ QDir::separator() + "tox") + QDir::separator() + "tox")
+ QDir::separator(); + QDir::separator();
#elif defined(Q_OS_OSX) # elif defined(Q_OS_OSX)
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation)
+ QDir::separator() + "Library" + QDir::separator() + QDir::separator() + "Library" + QDir::separator()
+ "Application Support" + QDir::separator() + "Tox") + "Application Support" + QDir::separator() + "Tox")
+ QDir::separator(); + QDir::separator();
#else # else
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::ConfigLocation) return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::ConfigLocation)
+ QDir::separator() + "tox") + QDir::separator() + "tox")
+ QDir::separator(); + QDir::separator();
# endif
#else
# ifdef Q_OS_WIN
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::AppDataLocation)
+ QDir::separator() + "tox") + QDir::separator();
# elif defined(Q_OS_OSX)
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::AppDataLocation)
+ QDir::separator() + "Tox") + QDir::separator();
# else
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::ConfigLocation)
+ QDir::separator() + "tox") + QDir::separator();
# endif
#endif #endif
} }
@ -743,25 +757,31 @@ QString Settings::getAppDataDirPath() const
if (makeToxPortable) if (makeToxPortable)
return qApp->applicationDirPath() + QDir::separator(); return qApp->applicationDirPath() + QDir::separator();
#if (QT_VERSION < QT_VERSION_CHECK(5, 4, 0))
// workaround for https://bugreports.qt-project.org/browse/QTBUG-38845 // workaround for https://bugreports.qt-project.org/browse/QTBUG-38845
#ifdef Q_OS_WIN # ifdef Q_OS_WIN
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation)
+ QDir::separator() + "AppData" + QDir::separator() + "Roaming" + QDir::separator() + "AppData" + QDir::separator() + "Roaming"
+ QDir::separator() + "tox") + QDir::separator() + "tox")
+ QDir::separator(); + QDir::separator();
#elif defined(Q_OS_OSX) # elif defined(Q_OS_OSX)
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation)
+ QDir::separator() + "Library" + QDir::separator() + QDir::separator() + "Library" + QDir::separator()
+ "Application Support" + QDir::separator() + "Tox") + "Application Support" + QDir::separator() + "Tox")
+ QDir::separator(); + QDir::separator();
#else # else
/*
* TODO: Change QStandardPaths::DataLocation to AppDataLocation when upgrate Qt to 5.4+
* For now we need support Qt 5.3, so we use deprecated DataLocation
* BTW, it's not a big deal since for linux AppDataLocation and DataLocation are equal
*/
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::DataLocation)) return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::DataLocation))
+ QDir::separator(); + QDir::separator();
# endif
#else
# if defined(Q_OS_OSX)
# elif defined(Q_OS_OSX)
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::AppDataLocation)
+ QDir::separator() + "Tox") + QDir::separator();
# else
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::AppDataLocation)
+ QDir::separator() + "tox") + QDir::separator();
# endif
#endif #endif
} }
@ -775,20 +795,33 @@ QString Settings::getAppCacheDirPath() const
if (makeToxPortable) if (makeToxPortable)
return qApp->applicationDirPath() + QDir::separator(); return qApp->applicationDirPath() + QDir::separator();
#if (QT_VERSION < QT_VERSION_CHECK(5, 4, 0))
// workaround for https://bugreports.qt-project.org/browse/QTBUG-38845 // workaround for https://bugreports.qt-project.org/browse/QTBUG-38845
#ifdef Q_OS_WIN # ifdef Q_OS_WIN
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation)
+ QDir::separator() + "AppData" + QDir::separator() + "Roaming" + QDir::separator() + "AppData" + QDir::separator() + "Roaming"
+ QDir::separator() + "tox") + QDir::separator() + "tox")
+ QDir::separator(); + QDir::separator();
#elif defined(Q_OS_OSX) # elif defined(Q_OS_OSX)
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation)
+ QDir::separator() + "Library" + QDir::separator() + QDir::separator() + "Library" + QDir::separator()
+ "Application Support" + QDir::separator() + "Tox") + "Application Support" + QDir::separator() + "Tox")
+ QDir::separator(); + QDir::separator();
#else # else
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::CacheLocation)) return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::CacheLocation))
+ QDir::separator(); + QDir::separator();
# endif
#else
# ifdef Q_OS_WIN
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::AppDataLocation)
+ QDir::separator() + "tox") + QDir::separator();
# elif defined(Q_OS_OSX)
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::AppDataLocation)
+ QDir::separator() + "Tox") + QDir::separator();
# else
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::CacheLocation))
+ QDir::separator();
# endif
#endif #endif
} }

View File

@ -108,9 +108,15 @@ QString Settings::getSettingsDirPath() const
} }
if (isOld) { if (isOld) {
#if (QT_VERSION < QT_VERSION_CHECK(5, 4, 0))
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation) return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation)
+ QDir::separator() + "AppData" + QDir::separator() + "Roaming" + QDir::separator() + "AppData" + QDir::separator() + "Roaming"
+ QDir::separator() + "tox" + QDir::separator()); + QDir::separator() + "tox" + QDir::separator());
#else
return QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::AppDataLocation)
+ QDir::separator() + "tox" + QDir::separator());
#endif
} else { } else {
QString pathStr = QString::fromStdWString(path); QString pathStr = QString::fromStdWString(path);
pathStr.replace("\\", "/"); pathStr.replace("\\", "/");