diff options
| author | Peter Penz <[email protected]> | 2009-12-17 21:07:18 +0000 |
|---|---|---|
| committer | Peter Penz <[email protected]> | 2009-12-17 21:07:18 +0000 |
| commit | e15a9f3a8da1907b26195a1833588fc86a9d50ca (patch) | |
| tree | e140f643669f97e4e51ddbbe4c547e2b2a429e8e /src/dolphinapplication.cpp | |
| parent | d613313b064ce75b2537f3d0cf08b563ed915574 (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.cpp | 53 |
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" |
