X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/d7d4fb9d26773c2d729b49d71af10e1378381ff3..339f0fb322e55fd1029d8aff01dc7aed3c64166c:/src/dolphinapplication.cpp diff --git a/src/dolphinapplication.cpp b/src/dolphinapplication.cpp index b35e58314..8b6139d92 100644 --- a/src/dolphinapplication.cpp +++ b/src/dolphinapplication.cpp @@ -20,18 +20,26 @@ #include "dolphinapplication.h" #include "dolphinmainwindow.h" +#include "dolphinviewcontainer.h" -DolphinApplication::DolphinApplication() +#include +#include +#include +#include + +DolphinApplication::DolphinApplication() : + m_lastId(0) { + new ApplicationAdaptor(this); + QDBusConnection::sessionBus().registerObject("/dolphin/Application", this); } -/* - * cleanup what ever is left from the MainWindows - */ DolphinApplication::~DolphinApplication() { - while( m_mainWindows.count() != 0 ) + // cleanup what ever is left from the MainWindows + while (m_mainWindows.count() != 0) { delete m_mainWindows.takeFirst(); + } } DolphinApplication* DolphinApplication::app() @@ -41,24 +49,63 @@ DolphinApplication* DolphinApplication::app() DolphinMainWindow* DolphinApplication::createMainWindow() { - DolphinMainWindow* mainwindow = new DolphinMainWindow; - mainwindow->init(); - - m_mainWindows.append( mainwindow ); - return mainwindow; + DolphinMainWindow* mainWindow = new DolphinMainWindow(m_lastId); + ++m_lastId; + mainWindow->init(); + + m_mainWindows.append(mainWindow); + return mainWindow; } -void DolphinApplication::removeMainWindow( DolphinMainWindow *mainwindow ) +void DolphinApplication::removeMainWindow(DolphinMainWindow* mainWindow) { - m_mainWindows.removeAll( mainwindow ); + m_mainWindows.removeAll(mainWindow); } void DolphinApplication::refreshMainWindows() { - for( int i = 0; i < m_mainWindows.count(); ++i ) { + for (int i = 0; i < m_mainWindows.count(); ++i) { m_mainWindows[i]->refreshViews(); } } -#include "dolphinapplication.moc" +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"