From 6d6d59fc4361b49b7124025b96efc6c6079d0ddd Mon Sep 17 00:00:00 2001
From: Friedemann Kleint <Friedemann.Kleint@nokia.com>
Date: Mon, 29 Mar 2010 15:48:04 +0200
Subject: [PATCH] FolderNavigationWidget: Fix file watcher leaks.

by modifying it to change the root path of
the model instead of changing the top index
of the view. Depends on fix for QTBUG-8632.
---
 .../foldernavigationwidget.cpp                | 43 ++++++++-----------
 .../projectexplorer/foldernavigationwidget.h  |  1 -
 2 files changed, 19 insertions(+), 25 deletions(-)

diff --git a/src/plugins/projectexplorer/foldernavigationwidget.cpp b/src/plugins/projectexplorer/foldernavigationwidget.cpp
index cedab6f4790..70d73a40c38 100644
--- a/src/plugins/projectexplorer/foldernavigationwidget.cpp
+++ b/src/plugins/projectexplorer/foldernavigationwidget.cpp
@@ -99,6 +99,7 @@ bool DotRemovalFilter::filterAcceptsRow(int source_row, const QModelIndex &paren
     return fileName != m_dot;
 }
 
+// FolderNavigationModel: Shows path as tooltip.
 class FolderNavigationModel : public QFileSystemModel
 {
 public:
@@ -141,7 +142,6 @@ FolderNavigationWidget::FolderNavigationWidget(QWidget *parent)
     filters |= QDir::NoSymLinks;
 #endif
     m_fileSystemModel->setFilter(filters);
-    m_fileSystemModel->setRootPath(QDir::rootPath());
     m_filterModel->setSourceModel(m_fileSystemModel);
     m_listView->setModel(m_filterModel);
     m_listView->setFrameStyle(QFrame::NoFrame);
@@ -218,30 +218,20 @@ void FolderNavigationWidget::setCurrentFile(const QString &filePath)
 
 bool FolderNavigationWidget::setCurrentDirectory(const QString &directory)
 {
-    return !directory.isEmpty() && setCurrentDirectory(m_fileSystemModel->index(directory));
-}
-
-bool FolderNavigationWidget::setCurrentDirectory(const QModelIndex &dirIndex)
-{
-    const bool valid = dirIndex.isValid();
-    if (valid) {
-        // position view root on directory index.
-        m_listView->setRootIndex(m_filterModel->mapFromSource(dirIndex));
-        const QDir currentDir(m_fileSystemModel->filePath(dirIndex));
-        setCurrentTitle(currentDir.dirName(), currentDir.absolutePath());
-    } else {
-        m_listView->setRootIndex(QModelIndex());
-        setCurrentTitle(QString(), QString());
-    }
-    return valid;
+    const QString newDirectory = directory.isEmpty() ? QDir::rootPath() : directory;
+    if (debug)
+        qDebug() << "setcurdir" << directory << newDirectory;
+    // Set the root path on the model instead of changing the top index
+    // of the view to cause the model to clean out its file watchers.
+    const QModelIndex index = m_fileSystemModel->setRootPath(newDirectory);
+    QTC_ASSERT(index.isValid(), return false)
+    m_listView->setRootIndex(m_filterModel->mapFromSource(index));
+    return !directory.isEmpty();
 }
 
 QString FolderNavigationWidget::currentDirectory() const
 {
-    const QModelIndex rootIndex = m_listView->rootIndex();
-    if (rootIndex.isValid())
-        return m_fileSystemModel->filePath(m_filterModel->mapToSource(rootIndex));
-    return QString();
+    return m_fileSystemModel->rootPath();
 }
 
 void FolderNavigationWidget::slotOpenItem(const QModelIndex &viewIndex)
@@ -255,12 +245,17 @@ void FolderNavigationWidget::openItem(const QModelIndex &srcIndex)
     const QString fileName = m_fileSystemModel->fileName(srcIndex);
     if (fileName == QLatin1String("."))
         return;
-    if (fileName == QLatin1String("..")) { // cd up.
-        setCurrentDirectory(srcIndex.parent().parent());
+    if (fileName == QLatin1String("..")) {
+        // cd up: Special behaviour: The fileInfo of ".." is that of the parent directory.
+        const QString parentPath = m_fileSystemModel->fileInfo(srcIndex).absoluteFilePath();
+        if (parentPath != QDir::rootPath())
+            setCurrentDirectory(parentPath);
         return;
     }
     if (m_fileSystemModel->isDir(srcIndex)) { // Change to directory
-        setCurrentDirectory(srcIndex);
+        const QFileInfo fi = m_fileSystemModel->fileInfo(srcIndex);
+        if (fi.isReadable() && fi.isExecutable())
+            setCurrentDirectory(m_fileSystemModel->filePath(srcIndex));
         return;
     }
     // Open file.
diff --git a/src/plugins/projectexplorer/foldernavigationwidget.h b/src/plugins/projectexplorer/foldernavigationwidget.h
index 9f3bdeb888b..2f15ad8e07a 100644
--- a/src/plugins/projectexplorer/foldernavigationwidget.h
+++ b/src/plugins/projectexplorer/foldernavigationwidget.h
@@ -83,7 +83,6 @@ protected:
 private:
     void setCurrentTitle(const QString &dirName, const QString &fullPath);
     bool setCurrentDirectory(const QString &directory);
-    bool setCurrentDirectory(const QModelIndex &dirIndex);
     void openItem(const QModelIndex &srcIndex);
     QModelIndex currentItem() const;
     QString currentDirectory() const;
-- 
GitLab