From 172ee368c91db403ca319a87e7b82e9c0da873ff Mon Sep 17 00:00:00 2001 From: Chirag Anand Date: Sun, 25 Sep 2011 01:06:33 +0530 Subject: [PATCH] Fixed selection of directories with a trailing slash used with --select parameter. As QHash would not match a KUrl key with it's value if the key had a trailing slash, so it would return -1, hence the file won't get selected. Changed the UpdateViewState slot to remove the trailing slash before calling the index function for the selected URL. Also modified DolphinView to use KUrl list instead of KFileItemList to maintain simplicity. --- src/views/dolphinview.cpp | 24 +++++++++++++----------- src/views/dolphinview.h | 2 +- 2 files changed, 14 insertions(+), 12 deletions(-) diff --git a/src/views/dolphinview.cpp b/src/views/dolphinview.cpp index 71c67b1cf..fe45541e3 100644 --- a/src/views/dolphinview.cpp +++ b/src/views/dolphinview.cpp @@ -93,7 +93,7 @@ DolphinView::DolphinView(const KUrl& url, QWidget* parent) : m_currentItemUrl(), m_restoredContentsPosition(), m_createdItemUrl(), - m_selectedItems(), + m_selectedUrls(), m_versionControlObserver(0) { m_topLayout = new QVBoxLayout(this); @@ -307,10 +307,7 @@ int DolphinView::selectedItemsCount() const void DolphinView::markUrlsAsSelected(const QList& urls) { - foreach (const KUrl& url, urls) { - KFileItem item(KFileItem::Unknown, KFileItem::Unknown, url); - m_selectedItems.append(item); - } + m_selectedUrls = urls; } void DolphinView::setItemSelectionEnabled(const QRegExp& pattern, bool enabled) @@ -409,7 +406,10 @@ void DolphinView::reload() QByteArray viewState; QDataStream saveStream(&viewState, QIODevice::WriteOnly); saveState(saveStream); - m_selectedItems= selectedItems(); + + const KFileItemList itemList = selectedItems(); + m_selectedUrls.clear(); + m_selectedUrls = itemList.urlList(); setUrl(url()); loadDirectory(url(), true); @@ -666,7 +666,9 @@ void DolphinView::setHiddenFilesShown(bool show) return; } - m_selectedItems = selectedItems(); + const KFileItemList itemList = selectedItems(); + m_selectedUrls.clear(); + m_selectedUrls = itemList.urlList(); ViewProperties props(url()); props.setHiddenFilesShown(show); @@ -1020,20 +1022,20 @@ void DolphinView::updateViewState() m_container->verticalScrollBar()->setValue(y); } - if (!m_selectedItems.isEmpty()) { + if (!m_selectedUrls.isEmpty()) { KItemListSelectionManager* selectionManager = m_container->controller()->selectionManager(); QSet selectedItems = selectionManager->selectedItems(); const KFileItemModel* model = fileItemModel(); - foreach (const KFileItem& selectedItem, m_selectedItems) { - const int index = model->index(selectedItem); + foreach (const KUrl& url, m_selectedUrls) { + const int index = model->index(url); if (index >= 0) { selectedItems.insert(index); } } selectionManager->setSelectedItems(selectedItems); - m_selectedItems.clear(); + m_selectedUrls.clear(); } } diff --git a/src/views/dolphinview.h b/src/views/dolphinview.h index 74cec7dcc..da74011a7 100644 --- a/src/views/dolphinview.h +++ b/src/views/dolphinview.h @@ -766,7 +766,7 @@ private: KUrl m_currentItemUrl; QPoint m_restoredContentsPosition; KUrl m_createdItemUrl; // URL for a new item that got created by the "Create New..." menu - KFileItemList m_selectedItems; // this is used for making the View to remember selections after F5 + QList m_selectedUrls; // this is used for making the View to remember selections after F5 VersionControlObserver* m_versionControlObserver; -- 2.47.3