X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/2b895e7e2bd096e55faa1032ebc6a355a72c2325..5acfb27760f3da1d4f794e820008f8a4c8ff7533:/src/main.cpp diff --git a/src/main.cpp b/src/main.cpp index e8d6c2d29..cbfc6b72f 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -21,6 +21,8 @@ #include "dolphinmainwindow.h" #include "dolphin_generalsettings.h" +#include "dbusinterface.h" +#include "global.h" #include #include @@ -34,6 +36,7 @@ extern "C" Q_DECL_EXPORT int kdemain(int argc, char **argv) { QApplication app(argc, argv); + app.setAttribute(Qt::AA_UseHighDpiPixmaps, true); Kdelibs4ConfigMigrator migrate(QStringLiteral("dolphin")); migrate.setConfigFiles(QStringList() << QStringLiteral("dolphinrc")); migrate.setUiFiles(QStringList() << QStringLiteral("dolphinpart.rc") << QStringLiteral("dolphinui.rc")); @@ -83,6 +86,7 @@ extern "C" Q_DECL_EXPORT int kdemain(int argc, char **argv) KAboutData::setApplicationData(aboutData); KDBusService dolphinDBusService; + DBusInterface interface; QCommandLineParser parser; parser.addVersionOption(); @@ -93,56 +97,38 @@ extern "C" Q_DECL_EXPORT int kdemain(int argc, char **argv) parser.addOption(QCommandLineOption(QStringList() << QLatin1String("select"), i18nc("@info:shell", "The files and directories passed as arguments " "will be selected."))); parser.addOption(QCommandLineOption(QStringList() << QLatin1String("split"), i18nc("@info:shell", "Dolphin will get started with a split view."))); + parser.addOption(QCommandLineOption(QStringList() << QLatin1String("daemon"), i18nc("@info:shell", "Start Dolphin Daemon (only required for DBus Interface)"))); parser.addPositionalArgument(QLatin1String("+[Url]"), i18nc("@info:shell", "Document to open")); parser.process(app); aboutData.processCommandLine(&parser); + if (parser.isSet("daemon")) { + return app.exec(); + } DolphinMainWindow* m_mainWindow = new DolphinMainWindow(); m_mainWindow->setAttribute(Qt::WA_DeleteOnClose); - QList urls; const QStringList args = parser.positionalArguments(); - foreach (const QString& str, args) { - const QUrl url = QUrl::fromUserInput(str, QString(), QUrl::AssumeLocalFile); - if (url.isValid()) { - urls.append(url); - } else { - qCWarning(DolphinDebug) << "Invalid URL: " << str; - } - } + QList urls = Dolphin::validateUris(args); - bool resetSplitSettings = false; - if (parser.isSet("split") && !GeneralSettings::splitView()) { - // Dolphin should be opened with a split view although this is not - // set in the GeneralSettings. Temporary adjust the setting until - // all passed URLs have been opened. - GeneralSettings::setSplitView(true); - resetSplitSettings = true; - - // We need 2 URLs to open Dolphin in split view mode - if (urls.isEmpty()) { // No URL given - Open home URL in all two views - urls.append(GeneralSettings::homeUrl()); - urls.append(GeneralSettings::homeUrl()); - } else if (urls.length() == 1) { // Only 1 URL given - Open given URL in all two views - urls.append(urls.at(0)); - } + if (urls.isEmpty()) { + // We need at least one URL to open Dolphin + const QUrl homeUrl(QUrl::fromLocalFile(GeneralSettings::homeUrl())); + urls.append(homeUrl); } - if (!urls.isEmpty()) { - if (parser.isSet("select")) { - m_mainWindow->openFiles(urls); - } else { - m_mainWindow->openDirectories(urls); - } - } else { - const QUrl homeUrl(QUrl::fromLocalFile(GeneralSettings::homeUrl())); - m_mainWindow->openNewActivatedTab(homeUrl); + const bool splitView = parser.isSet("split") || GeneralSettings::splitView(); + if (splitView && urls.size() < 2) { + // Split view does only make sense if we have at least 2 URLs + urls.append(urls.last()); } - if (resetSplitSettings) { - GeneralSettings::setSplitView(false); + if (parser.isSet("select")) { + m_mainWindow->openFiles(urls, splitView); + } else { + m_mainWindow->openDirectories(urls, splitView); } m_mainWindow->show();