#include "dolphinapplication.h"
#include "dolphinmainwindow.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)
}
}
-
int DolphinApplication::newInstance()
{
- int exitValue = KUniqueApplication::newInstance();
-
+ KCmdLineArgs::setCwd(QDir::currentPath().toUtf8());
KCmdLineArgs* args = KCmdLineArgs::parsedArgs();
- if (args->count() > 0) {
+ 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->arg(i));
+ openWindow(args->url(i));
}
}
- else {
- openWindow(QString());
- }
+ first = false;
args->clear();
+ return 0;
+}
- return exitValue;
+int DolphinApplication::openWindow(const KUrl& url)
+{
+ DolphinMainWindow* win = createMainWindow();
+ if ((win->activeViewContainer() != 0) && url.isValid()) {
+ win->activeViewContainer()->setUrl(url);
+ }
+ win->show();
+ return win->getId();
}
-int DolphinApplication::openWindow(const QString& url)
+int DolphinApplication::openSplitWindow(const KUrl& leftUrl, const KUrl& rightUrl)
{
DolphinMainWindow* win = createMainWindow();
- if ((win->activeView() != 0) && !url.isEmpty()) {
- win->activeView()->setUrl(KUrl(url));
+ 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"