Internal cleanups to assure that the asynchronous request for the folder-information works reliable when switching between directories.

svn path=/trunk/KDE/kdebase/apps/; revision=1183537
This commit is contained in:
Peter Penz 2010-10-07 18:00:58 +00:00
parent 431da0482c
commit 6751f6a52a
2 changed files with 44 additions and 36 deletions

View file

@ -18,12 +18,13 @@
***************************************************************************/ ***************************************************************************/
#include "informationpanel.h" #include "informationpanel.h"
#include "informationpanelcontent.h"
#include <kio/job.h>
#include <kdirnotify.h> #include <kdirnotify.h>
#include <QApplication>
#include <QShowEvent> #include <QShowEvent>
#include <QVBoxLayout> #include <QVBoxLayout>
#include "informationpanelcontent.h"
#include <kio/job.h>
InformationPanel::InformationPanel(QWidget* parent) : InformationPanel::InformationPanel(QWidget* parent) :
Panel(parent), Panel(parent),
@ -89,34 +90,46 @@ void InformationPanel::requestDelayedItemInfo(const KFileItem& item)
return; return;
} }
cancelRequest(); if (QApplication::mouseButtons() & Qt::LeftButton) {
// Ignore the request of an item information when a rubberband
// selection is ongoing.
return;
}
m_fileItem = KFileItem();
if (item.isNull()) { if (item.isNull()) {
// The cursor is above the viewport. If files are selected, // The cursor is above the viewport. If files are selected,
// show information regarding the selection. // show information regarding the selection.
if (m_selection.size() > 0) { if (m_selection.size() > 0) {
cancelRequest();
m_infoTimer->start(); m_infoTimer->start();
} }
} else { } else if (item.url().isValid() && !isEqualToShownUrl(item.url())) {
const KUrl url = item.url(); // The cursor is above an item that is not shown currently
if (url.isValid() && !isEqualToShownUrl(url)) { cancelRequest();
m_urlCandidate = item.url();
m_fileItem = item; m_urlCandidate = item.url();
m_infoTimer->start(); m_fileItem = item;
} m_infoTimer->start();
} }
} }
bool InformationPanel::urlChanged() bool InformationPanel::urlChanged()
{ {
if (!url().isValid() || isEqualToShownUrl(url())) { if (!url().isValid()) {
return false; return false;
} }
m_shownUrl = url(); if (!isVisible()) {
if (isVisible()) { return true;
cancelRequest(); }
cancelRequest();
m_selection.clear();
if (!isEqualToShownUrl(url())) {
m_shownUrl = url();
m_fileItem = KFileItem();
// Update the content with a delay. This gives // Update the content with a delay. This gives
// the directory lister the chance to show the content // the directory lister the chance to show the content
// before expensive operations are done to show // before expensive operations are done to show
@ -137,6 +150,8 @@ void InformationPanel::showEvent(QShowEvent* event)
// Information Panel // Information Panel
init(); init();
} }
m_shownUrl = url();
showItemInfo(); showItemInfo();
} }
} }
@ -164,10 +179,11 @@ void InformationPanel::showItemInfo()
cancelRequest(); cancelRequest();
if (showMultipleSelectionInfo()) { if (m_fileItem.isNull() && (m_selection.count() > 1)) {
// The information for a selection of items should be shown
m_content->showItems(m_selection); m_content->showItems(m_selection);
m_shownUrl = KUrl();
} else { } else {
// The information for exactly one item should be shown
KFileItem item; KFileItem item;
if (!m_fileItem.isNull()) { if (!m_fileItem.isNull()) {
item = m_fileItem; item = m_fileItem;
@ -177,9 +193,9 @@ void InformationPanel::showItemInfo()
} }
if (item.isNull()) { if (item.isNull()) {
// no item is hovered and no selection has been done: provide // No item is hovered and no selection has been done: provide
// an item for the directory represented by m_shownUrl // an item for the currently shown directory.
m_folderStatJob = KIO::stat(m_shownUrl, KIO::HideProgressInfo); m_folderStatJob = KIO::stat(url(), KIO::HideProgressInfo);
connect(m_folderStatJob, SIGNAL(result(KJob*)), connect(m_folderStatJob, SIGNAL(result(KJob*)),
this, SLOT(slotFolderStatFinished(KJob*))); this, SLOT(slotFolderStatFinished(KJob*)));
} else { } else {
@ -198,6 +214,7 @@ void InformationPanel::slotFolderStatFinished(KJob* job)
void InformationPanel::slotInfoTimeout() void InformationPanel::slotInfoTimeout()
{ {
m_shownUrl = m_urlCandidate; m_shownUrl = m_urlCandidate;
m_urlCandidate.clear();
showItemInfo(); showItemInfo();
} }
@ -288,12 +305,13 @@ void InformationPanel::cancelRequest()
{ {
delete m_folderStatJob; delete m_folderStatJob;
m_folderStatJob = 0; m_folderStatJob = 0;
m_infoTimer->stop();
}
bool InformationPanel::showMultipleSelectionInfo() const m_infoTimer->stop();
{ m_urlChangedTimer->stop();
return m_fileItem.isNull() && (m_selection.count() > 1); m_resetUrlTimer->stop();
m_invalidUrlCandidate.clear();
m_urlCandidate.clear();
} }
bool InformationPanel::isEqualToShownUrl(const KUrl& url) const bool InformationPanel::isEqualToShownUrl(const KUrl& url) const

View file

@ -112,16 +112,6 @@ private:
*/ */
void showMetaInfo(); void showMetaInfo();
/**
* Returns true, if the meta information should be shown for
* the multiple selected items that are stored in
* m_selection. If true is returned, it is assured that
* m_selection.count() > 1. If false is returned, the meta
* information should be shown for the file
* InformationPanel::fileUrl();
*/
bool showMultipleSelectionInfo() const;
/** /**
* Returns true, if \a url is equal to the shown URL m_shownUrl. * Returns true, if \a url is equal to the shown URL m_shownUrl.
*/ */