]> cloud.milkyroute.net Git - dolphin.git/blobdiff - src/dolphinapplication.cpp
The apply button in the settings dialog now disables itself when settings are applied...
[dolphin.git] / src / dolphinapplication.cpp
index b426ec1b821b946e1a3011e58da8ddceaa888575..d9dc0728ef2feb893cd22b97b9e89dee4702cd5d 100644 (file)
 
 #include "dolphinapplication.h"
 #include "dolphinmainwindow.h"
-#include "metadataloader.h"
+#include "dolphinviewcontainer.h"
 
 #include <applicationadaptor.h>
+#include <kcmdlineargs.h>
 #include <kurl.h>
-#include <QDBusConnection>
+#include <QtDBus/QDBusConnection>
+#include <QtCore/QDir>
 
 DolphinApplication::DolphinApplication() :
     m_lastId(0)
@@ -56,33 +58,73 @@ 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::setCwd(QDir::currentPath().toUtf8());
+    KCmdLineArgs* args = KCmdLineArgs::parsedArgs();
+    static bool first = true;
+
+    switch (args->count()) {
+    case 0:
+        if( !first || !isSessionRestored()) {
+            openWindow(KUrl());
+        }
+        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));
+        }
+    }
+
+    first = false;
+    args->clear();
+    return 0;
 }
 
-void DolphinApplication::refreshMainWindows()
+int DolphinApplication::openWindow(const KUrl& url)
 {
-    for (int i = 0; i < m_mainWindows.count(); ++i) {
-        m_mainWindows[i]->refreshViews();
+    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)
+{
+    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();
+}
+
+
 #include "dolphinapplication.moc"