X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/abf17941f7a052d25788d2f2f3c84e5aae935e29..2dcc433ab2c353a40e3c65f3df46e8a1eac697cc:/src/dolphinapplication.cpp diff --git a/src/dolphinapplication.cpp b/src/dolphinapplication.cpp index cad005630..468c7a0f7 100644 --- a/src/dolphinapplication.cpp +++ b/src/dolphinapplication.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2006 by Peter Penz * + * Copyright (C) 2006 by Peter Penz * * Copyright (C) 2006 by Holger 'zecke' Freyther * * * * This program is free software; you can redistribute it and/or modify * @@ -20,10 +20,12 @@ #include "dolphinapplication.h" #include "dolphinmainwindow.h" +#include "dolphinviewcontainer.h" #include -#include -#include +#include +#include +#include DolphinApplication::DolphinApplication() : m_lastId(0) @@ -35,7 +37,7 @@ DolphinApplication::DolphinApplication() : DolphinApplication::~DolphinApplication() { // cleanup what ever is left from the MainWindows - while (m_mainWindows.count() != 0) { + while (!m_mainWindows.isEmpty()) { delete m_mainWindows.takeFirst(); } } @@ -55,16 +57,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(); - return win->getId(); -} - void DolphinApplication::removeMainWindow(DolphinMainWindow* mainWindow) { m_mainWindows.removeAll(mainWindow); @@ -77,4 +69,43 @@ void DolphinApplication::refreshMainWindows() } } +int DolphinApplication::newInstance() +{ + 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; +} + +int DolphinApplication::openWindow(const QString& urlString) +{ + DolphinMainWindow* win = createMainWindow(); + const KUrl url(urlString); + if (!url.isEmpty()) { + win->openDirectories(QList() << url); + } + win->show(); + return win->getId(); +} + #include "dolphinapplication.moc"