summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/corelib/kernel/qcoreapplication.cpp13
-rw-r--r--src/gui/util/qdesktopservices.cpp27
2 files changed, 30 insertions, 10 deletions
diff --git a/src/corelib/kernel/qcoreapplication.cpp b/src/corelib/kernel/qcoreapplication.cpp
index 967ed447d5..3d09d858a3 100644
--- a/src/corelib/kernel/qcoreapplication.cpp
+++ b/src/corelib/kernel/qcoreapplication.cpp
@@ -1943,7 +1943,9 @@ QString QCoreApplication::organizationDomain()
using the empty constructor. This saves having to repeat this
information each time a QSettings object is created.
- \sa organizationName organizationDomain applicationVersion
+ If not set, the application name defaults to the executable name (since 5.0).
+
+ \sa organizationName organizationDomain applicationVersion applicationFilePath
*/
void QCoreApplication::setApplicationName(const QString &application)
{
@@ -1952,6 +1954,15 @@ void QCoreApplication::setApplicationName(const QString &application)
QString QCoreApplication::applicationName()
{
+ QString appname = coreappdata()->application;
+ if (appname.isEmpty() && QCoreApplication::self)
+ appname = QCoreApplication::self->d_func()->appName();
+ return appname;
+}
+
+// Exported for QDesktopServices (Qt4 behavior compatibility)
+Q_CORE_EXPORT QString qt_applicationName_noFallback()
+{
return coreappdata()->application;
}
diff --git a/src/gui/util/qdesktopservices.cpp b/src/gui/util/qdesktopservices.cpp
index 1a6661440c..26aecadcf4 100644
--- a/src/gui/util/qdesktopservices.cpp
+++ b/src/gui/util/qdesktopservices.cpp
@@ -287,17 +287,26 @@ void QDesktopServices::unsetUrlHandler(const QString &scheme)
QString QDesktopServices::storageLocationImpl(StandardLocation type)
{
-#if defined(Q_OS_UNIX) && !defined(Q_OS_MAC)
if (type == DataLocation) {
- QString xdgDataHome = QLatin1String(qgetenv("XDG_DATA_HOME"));
- if (xdgDataHome.isEmpty())
- xdgDataHome = QDir::homePath() + QLatin1String("/.local/share");
- xdgDataHome += QLatin1String("/data/")
- + QCoreApplication::organizationName() + QLatin1Char('/')
- + QCoreApplication::applicationName();
- return xdgDataHome;
- }
+ // Preserve Qt 4 compatibility:
+ // * QCoreApplication::applicationName() must default to empty
+ // * Unix data location is under the "data/" subdirectory
+ extern Q_CORE_EXPORT QString qt_applicationName_noFallback();
+ const QString compatAppName = qt_applicationName_noFallback();
+ const QString baseDir = QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation);
+#if defined(Q_OS_WIN) || defined(Q_OS_MAC)
+ QString result = baseDir;
+ if (!QCoreApplication::organizationName().isEmpty())
+ result += QLatin1Char('/') + QCoreApplication::organizationName();
+ if (!compatAppName.isEmpty())
+ result += QLatin1Char('/') + compatAppName;
+ return result;
+#elif defined(Q_OS_UNIX)
+ return baseDir + QLatin1String("/data/")
+ + QCoreApplication::organizationName() + QLatin1Char('/')
+ + compatAppName;
#endif
+ }
return QStandardPaths::writableLocation(static_cast<QStandardPaths::StandardLocation>(type));
}