]> cloud.milkyroute.net Git - dolphin.git/blobdiff - src/dolphinapplication.cpp
SVN_SILENT: Minor simplificiation of the code. No change of behavior has been done.
[dolphin.git] / src / dolphinapplication.cpp
index cad0056304588a5bf9db5f4ae2906e6e990acc49..c418f4540d086a4ae45536625c18301215bb0925 100644 (file)
 
 #include "dolphinapplication.h"
 #include "dolphinmainwindow.h"
+#include "dolphinviewcontainer.h"
 
 #include <applicationadaptor.h>
+#include <kcmdlineargs.h>
 #include <kurl.h>
-#include <QDBusConnection>
+#include <QtDBus/QDBusConnection>
 
 DolphinApplication::DolphinApplication() :
     m_lastId(0)
@@ -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,39 @@ void DolphinApplication::refreshMainWindows()
     }
 }
 
+int DolphinApplication::newInstance()
+{
+    KCmdLineArgs* args = KCmdLineArgs::parsedArgs();
+
+    QList<KUrl> urls;
+    const int argsCount = args->count();
+    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();
+
+    args->clear();
+    return 0;
+}
+
+int DolphinApplication::openWindow(const QString& urlString)
+{
+    DolphinMainWindow* win = createMainWindow();
+    const KUrl url(urlString);
+    if (!url.isEmpty()) {
+        win->openDirectories(QList<KUrl>() << url);
+    }
+    win->show();
+    return win->getId();
+}
+
 #include "dolphinapplication.moc"