X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/4af3a2dcb43d053865af282c2492cc60c4b438d2..2446dd16e89e51e840489cf8cc1628116d323f36:/src/dolphinapplication.cpp diff --git a/src/dolphinapplication.cpp b/src/dolphinapplication.cpp index 59e870adb..ea18db132 100644 --- a/src/dolphinapplication.cpp +++ b/src/dolphinapplication.cpp @@ -20,10 +20,13 @@ #include "dolphinapplication.h" #include "dolphinmainwindow.h" +#include "dolphinviewcontainer.h" #include +#include #include -#include +#include +#include DolphinApplication::DolphinApplication() : m_lastId(0) @@ -55,17 +58,6 @@ DolphinMainWindow* DolphinApplication::createMainWindow() return mainWindow; } -int DolphinApplication::openWindow(const QString& url) -{ - DolphinMainWindow* win = createMainWindow(); - if ((win->activeView() != 0) && !url.isEmpty()) { - win->activeView()->setUrl(KUrl(url)); - } - win->show(); - //TODO find how to raise a window (as if we've launched a new dolphin process) - return win->getId(); -} - void DolphinApplication::removeMainWindow(DolphinMainWindow* mainWindow) { m_mainWindows.removeAll(mainWindow); @@ -78,4 +70,34 @@ void DolphinApplication::refreshMainWindows() } } + +int DolphinApplication::newInstance() +{ + int exitValue = KUniqueApplication::newInstance(); + + KCmdLineArgs::setCwd(QDir::currentPath().toUtf8()); + KCmdLineArgs* args = KCmdLineArgs::parsedArgs(); + if (args->count() > 0) { + for (int i = 0; i < args->count(); ++i) { + openWindow(args->url(i)); + } + } else { + openWindow(KUrl()); + } + + args->clear(); + + return exitValue; +} + +int DolphinApplication::openWindow(const KUrl& url) +{ + DolphinMainWindow* win = createMainWindow(); + if ((win->activeViewContainer() != 0) && url.isValid()) { + win->activeViewContainer()->setUrl(url); + } + win->show(); + return win->getId(); +} + #include "dolphinapplication.moc"