X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/960f13f7cbc2c04ba8a317bc646bf48d330c5813..b7404044470bb3ef241dced31839a1d18e70e3b0:/src/dolphinapplication.cpp diff --git a/src/dolphinapplication.cpp b/src/dolphinapplication.cpp index f61bf795a..8e83a8592 100644 --- a/src/dolphinapplication.cpp +++ b/src/dolphinapplication.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2006 by Peter Penz * + * Copyright (C) 2006-2011 by Peter Penz * * Copyright (C) 2006 by Holger 'zecke' Freyther * * * * This program is free software; you can redistribute it and/or modify * @@ -20,109 +20,83 @@ #include "dolphinapplication.h" #include "dolphinmainwindow.h" -#include "dolphinviewcontainer.h" +#include "dolphin_generalsettings.h" -#include -#include -#include -#include +#include +#include +#include +#include DolphinApplication::DolphinApplication() : - m_lastId(0) + m_mainWindow(0) { - new ApplicationAdaptor(this); - QDBusConnection::sessionBus().registerObject("/dolphin/Application", this); -} - -DolphinApplication::~DolphinApplication() -{ - // cleanup what ever is left from the MainWindows - while (m_mainWindows.count() != 0) { - delete m_mainWindows.takeFirst(); - } -} - -DolphinApplication* DolphinApplication::app() -{ - return qobject_cast(qApp); -} + KGlobal::locale()->insertCatalog("libkonq"); // Needed for applications using libkonq -DolphinMainWindow* DolphinApplication::createMainWindow() -{ - DolphinMainWindow* mainWindow = new DolphinMainWindow(m_lastId); - ++m_lastId; - mainWindow->init(); + m_mainWindow = new DolphinMainWindow(); + m_mainWindow->setAttribute(Qt::WA_DeleteOnClose); + m_mainWindow->show(); - m_mainWindows.append(mainWindow); - return mainWindow; -} + KCmdLineArgs* args = KCmdLineArgs::parsedArgs(); -void DolphinApplication::removeMainWindow(DolphinMainWindow* mainWindow) -{ - m_mainWindows.removeAll(mainWindow); -} + const int argsCount = args->count(); -void DolphinApplication::refreshMainWindows() -{ - for (int i = 0; i < m_mainWindows.count(); ++i) { - m_mainWindows[i]->refreshViews(); + QList urls; + for (int i = 0; i < argsCount; ++i) { + const KUrl url = args->url(i); + if (url.isValid()) { + urls.append(url); + } } -} -int DolphinApplication::newInstance() -{ - KCmdLineArgs* args = KCmdLineArgs::parsedArgs(); - static bool first = true; - - switch (args->count()) { - case 0: - if( !first || !isSessionRestored()) { - openWindow(KUrl()); + bool resetSplitSettings = false; + if (args->isSet("split") && !GeneralSettings::splitView()) { + // Dolphin should be opened with a split view although this is not + // set in the GeneralSettings. Temporary adjust the setting until + // all passed URLs have been opened. + GeneralSettings::setSplitView(true); + resetSplitSettings = true; + + // We need 2 URLs to open Dolphin in split view mode + if (urls.isEmpty()) { // No URL given - Open home URL in all two views + urls.append(GeneralSettings::homeUrl()); + urls.append(GeneralSettings::homeUrl()); + } else if (urls.length() == 1) { // Only 1 URL given - Open given URL in all two views + urls.append(urls.at(0)); } - 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)); + if (!urls.isEmpty()) { + if (args->isSet("select")) { + m_mainWindow->openFiles(urls); + } else { + m_mainWindow->openDirectories(urls); } } - first = false; + if (resetSplitSettings) { + GeneralSettings::setSplitView(false); + } + args->clear(); - return 0; } -int DolphinApplication::openWindow(const KUrl& url) +DolphinApplication::~DolphinApplication() { - 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) +DolphinApplication* DolphinApplication::app() { - 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(); + return qobject_cast(qApp); } +void DolphinApplication::restoreSession() +{ + const QString className = KXmlGuiWindow::classNameOfToplevel(1); + if (className == QLatin1String("DolphinMainWindow")) { + m_mainWindow->restore(1); + } else { + kWarning() << "Unknown class " << className << " in session saved data!"; + } +} #include "dolphinapplication.moc"