X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/c624666b53b678de541ca2946565eaecefb52a4c..c0922a81d88affaded8b8ff22b8671eedecf900c:/src/dolphinapplication.cpp diff --git a/src/dolphinapplication.cpp b/src/dolphinapplication.cpp index 4bec27492..988019de1 100644 --- a/src/dolphinapplication.cpp +++ b/src/dolphinapplication.cpp @@ -26,10 +26,9 @@ #include #include #include -#include DolphinApplication::DolphinApplication() : - m_lastId(0) + m_lastId(0), m_closedBySessionManager(false) { new ApplicationAdaptor(this); QDBusConnection::sessionBus().registerObject("/dolphin/Application", this); @@ -70,26 +69,48 @@ void DolphinApplication::refreshMainWindows() } } - int DolphinApplication::newInstance() { - KCmdLineArgs::setCwd(QDir::currentPath().toUtf8()); KCmdLineArgs* args = KCmdLineArgs::parsedArgs(); static bool first = true; - if (args->count() > 0) { + + 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->url(i)); } - } else if( !first || !isSessionRestored()) { - openWindow(KUrl()); } - first = false; + first = false; args->clear(); - return 0; } +bool DolphinApplication::closedBySessionManager() const +{ + return m_closedBySessionManager; +} + +void DolphinApplication::commitData(QSessionManager& sessionManager) { + m_closedBySessionManager = true; + KUniqueApplication::commitData(sessionManager); + m_closedBySessionManager = false; +} + int DolphinApplication::openWindow(const KUrl& url) { DolphinMainWindow* win = createMainWindow(); @@ -100,4 +121,19 @@ int DolphinApplication::openWindow(const KUrl& url) return win->getId(); } +int DolphinApplication::openSplitWindow(const KUrl& leftUrl, const KUrl& rightUrl) +{ + DolphinMainWindow* win = createMainWindow(); + 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"