X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/aca3c707df3fe46bc1b50b4b1a8cc8703e3bfc16..d98f9c673b2f7eb31012ccef98dc8167630ccf1b:/src/dolphinapplication.cpp diff --git a/src/dolphinapplication.cpp b/src/dolphinapplication.cpp index a3dc80fef..f61bf795a 100644 --- a/src/dolphinapplication.cpp +++ b/src/dolphinapplication.cpp @@ -20,11 +20,11 @@ #include "dolphinapplication.h" #include "dolphinmainwindow.h" +#include "dolphinviewcontainer.h" #include #include #include -#include #include DolphinApplication::DolphinApplication() : @@ -69,38 +69,60 @@ void DolphinApplication::refreshMainWindows() } } - int DolphinApplication::newInstance() { - int exitValue = KUniqueApplication::newInstance(); - KCmdLineArgs* args = KCmdLineArgs::parsedArgs(); - if (args->count() > 0) { + static bool first = true; + + switch (args->count()) { + case 0: + if( !first || !isSessionRestored()) { + openWindow(KUrl()); + } + break; + + case 1: + openWindow(args->url(0)); + break; + + case 2: + openSplitWindow(args->url(0),args->url(1)); + break; + + default: for (int i = 0; i < args->count(); ++i) { - openWindow(args->arg(i)); + openWindow(args->url(i)); } - } else { - openWindow(QString()); } + first = false; args->clear(); - - return exitValue; + return 0; } -int DolphinApplication::openWindow(const QString& url) +int DolphinApplication::openWindow(const KUrl& url) { - QString dir = url; - if (dir == ".") { - dir = QDir::currentPath(); + DolphinMainWindow* win = createMainWindow(); + if ((win->activeViewContainer() != 0) && url.isValid()) { + win->activeViewContainer()->setUrl(url); } + win->show(); + return win->getId(); +} +int DolphinApplication::openSplitWindow(const KUrl& leftUrl, const KUrl& rightUrl) +{ DolphinMainWindow* win = createMainWindow(); - if ((win->activeView() != 0) && !dir.isEmpty()) { - win->activeView()->setUrl(KUrl(dir)); + if ((win->activeViewContainer() != 0) && leftUrl.isValid()) { + win->activeViewContainer()->setUrl(leftUrl); + } + win->toggleSplitView(); + if ((win->activeViewContainer() != 0) && rightUrl.isValid()){ + win->activeViewContainer()->setUrl(rightUrl); } win->show(); return win->getId(); } + #include "dolphinapplication.moc"