┌   ┐
54
└   ┘

summaryrefslogtreecommitdiff
path: root/src/dolphinapplication.cpp
diff options
context:
space:
mode:
authorPeter Penz <[email protected]>2009-12-17 21:07:18 +0000
committerPeter Penz <[email protected]>2009-12-17 21:07:18 +0000
commite15a9f3a8da1907b26195a1833588fc86a9d50ca (patch)
treee140f643669f97e4e51ddbbe4c547e2b2a429e8e /src/dolphinapplication.cpp
parentd613313b064ce75b2537f3d0cf08b563ed915574 (diff)
* respect the --select startup option
* minor cleanups related to selecting items in general svn path=/trunk/KDE/kdebase/apps/; revision=1063329
Diffstat (limited to 'src/dolphinapplication.cpp')
-rw-r--r--src/dolphinapplication.cpp53
1 files changed, 16 insertions, 37 deletions
diff --git a/src/dolphinapplication.cpp b/src/dolphinapplication.cpp
index f61bf795a..c418f4540 100644
--- a/src/dolphinapplication.cpp
+++ b/src/dolphinapplication.cpp
@@ -72,57 +72,36 @@ void DolphinApplication::refreshMainWindows()
int DolphinApplication::newInstance()
{
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;
+ QList<KUrl> urls;
+ const int argsCount = args->count();
+ for (int i = 0; i < argsCount; ++i) {
+ urls.append(args->url(i));
+ }
- default:
- for (int i = 0; i < args->count(); ++i) {
- openWindow(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 KUrl& url)
+int DolphinApplication::openWindow(const QString& urlString)
{
DolphinMainWindow* win = createMainWindow();
- if ((win->activeViewContainer() != 0) && url.isValid()) {
- win->activeViewContainer()->setUrl(url);
+ const KUrl url(urlString);
+ if (!url.isEmpty()) {
+ win->openDirectories(QList<KUrl>() << 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"