X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/cefcbf0ef0e960db68021715d1c600b901be8501..07f083241be254d081b05170d16612c51cfc5ccc:/src/dolphinapplication.cpp diff --git a/src/dolphinapplication.cpp b/src/dolphinapplication.cpp index b426ec1b8..8b6139d92 100644 --- a/src/dolphinapplication.cpp +++ b/src/dolphinapplication.cpp @@ -20,11 +20,12 @@ #include "dolphinapplication.h" #include "dolphinmainwindow.h" -#include "metadataloader.h" +#include "dolphinviewcontainer.h" #include +#include #include -#include +#include DolphinApplication::DolphinApplication() : m_lastId(0) @@ -56,33 +57,55 @@ DolphinMainWindow* DolphinApplication::createMainWindow() return mainWindow; } -MetadataLoader* DolphinApplication::metadataLoader() +void DolphinApplication::removeMainWindow(DolphinMainWindow* mainWindow) { - static MetadataLoader loader; - return &loader; + m_mainWindows.removeAll(mainWindow); } -int DolphinApplication::openWindow(const QString& url) +void DolphinApplication::refreshMainWindows() { - DolphinMainWindow* win = createMainWindow(); - if ((win->activeView() != 0) && !url.isEmpty()) { - win->activeView()->setUrl(KUrl(url)); + for (int i = 0; i < m_mainWindows.count(); ++i) { + m_mainWindows[i]->refreshViews(); } - 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) +int DolphinApplication::newInstance() { - m_mainWindows.removeAll(mainWindow); + KCmdLineArgs* args = KCmdLineArgs::parsedArgs(); + 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)); + } + + 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 0; } -void DolphinApplication::refreshMainWindows() +int DolphinApplication::openWindow(const QString& urlString) { - for (int i = 0; i < m_mainWindows.count(); ++i) { - m_mainWindows[i]->refreshViews(); + DolphinMainWindow* win = createMainWindow(); + const KUrl url(urlString); + if (!url.isEmpty()) { + win->openDirectories(QList() << url); } + win->show(); + return win->getId(); } #include "dolphinapplication.moc"