X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/cdcb4b0166aefdd382d20e7ff3b5cb217ba54ba8..8eb9b508ca87fb1d634d8b8ba62c054ed04466d2:/src/dolphinapplication.cpp diff --git a/src/dolphinapplication.cpp b/src/dolphinapplication.cpp index 8c1464d53..13a2b60d8 100644 --- a/src/dolphinapplication.cpp +++ b/src/dolphinapplication.cpp @@ -20,11 +20,12 @@ #include "dolphinapplication.h" #include "dolphinmainwindow.h" +#include "dolphinviewcontainer.h" #include -#include -#include -#include +#include +#include +#include DolphinApplication::DolphinApplication() : m_lastId(0) @@ -68,30 +69,40 @@ void DolphinApplication::refreshMainWindows() } } - int DolphinApplication::newInstance() { - int exitValue = KUniqueApplication::newInstance(); - KCmdLineArgs* args = KCmdLineArgs::parsedArgs(); - if (args->count() > 0) { - for (int i = 0; i < args->count(); ++i) { - openWindow(args->arg(i)); + static bool first = true; + + const int argsCount = args->count(); + if ((argsCount > 0) || !first || !isSessionRestored()) { + QList urls; + for (int i = 0; i < argsCount; ++i) { + urls.append(args->url(i)); } - } else { - openWindow(QString()); + + DolphinMainWindow* win = createMainWindow(); + if (urls.count() > 0) { + if (args->isSet("select")) { + win->openFiles(urls); + } else { + win->openDirectories(urls); + } + } + win->show(); } + first = false; args->clear(); - - return exitValue; + return 0; } -int DolphinApplication::openWindow(const QString& url) +int DolphinApplication::openWindow(const QString& urlString) { DolphinMainWindow* win = createMainWindow(); - if ((win->activeView() != 0) && !url.isEmpty()) { - win->activeView()->setUrl(KUrl(url)); + const KUrl url(urlString); + if (!url.isEmpty()) { + win->openDirectories(QList() << url); } win->show(); return win->getId();