]> cloud.milkyroute.net Git - dolphin.git/commitdiff
BUG:222186
authorHarsh Chouraria J <qwertymaniac@gmail.com>
Mon, 11 Jan 2010 12:08:38 +0000 (12:08 +0000)
committerHarsh Chouraria J <qwertymaniac@gmail.com>
Mon, 11 Jan 2010 12:08:38 +0000 (12:08 +0000)
With respect to the action done on hitting the "Return/Enter" key:
 * Fix the behavior for multiple-item opening, when they have directories among them.
 * Open multiple directories in background tabs.

svn path=/trunk/KDE/kdebase/apps/; revision=1073019

src/dolphincontroller.cpp

index 408abd501ad72a86bf1ff6af745d90fdb595ec9c..0bbf0557a178d04f3bb7065524400cb74f66ddbc 100644 (file)
@@ -175,9 +175,28 @@ void DolphinController::handleKeyPressEvent(QKeyEvent* event)
                             || (event->key() == Qt::Key_Enter))
                          && !selModel->selectedIndexes().isEmpty();
     if (trigger) {
+        QModelIndexList dirQueue;
         const QModelIndexList indexList = selModel->selectedIndexes();
         foreach (const QModelIndex& index, indexList) {
-            emit itemTriggered(itemForIndex(index));
+            // Trigger non-directories immediately.
+            if (!itemForIndex(index).isDir()) {
+                emit itemTriggered(itemForIndex(index));
+            } else {
+                // Keep storing the directory indexes for trigger later.
+                dirQueue << index;
+            }
+        }
+        // Trigger directories - Tabs if multiple, else normal.
+        if (!dirQueue.isEmpty()) {
+            if (dirQueue.length() == 1) {
+                // For single directory selection, open normally.
+                emit itemTriggered(itemForIndex(dirQueue[0]));
+            } else {
+                foreach(const QModelIndex& dir, dirQueue) {
+                    // Since its a valid directory - open a tab.
+                    emit tabRequested(itemForIndex(dir).url());
+                }
+            }
         }
     }
 }