diff options
| author | Emmanuel Pescosta <[email protected]> | 2014-05-25 14:43:18 +0200 |
|---|---|---|
| committer | Emmanuel Pescosta <[email protected]> | 2014-05-25 14:43:18 +0200 |
| commit | fa36c3fd1f53a223f43bb57d7c28e431a889a7c2 (patch) | |
| tree | ddf2c2747d952babbdbcebb12c5d661953aef744 /src/statusbar/statusbarspaceinfo.cpp | |
| parent | a46121dc510f987f2d164b43eaf5f84ea8c83cb8 (diff) | |
| parent | 4fe788f1157426e819f1ba31d1ee6388759cfd18 (diff) | |
Merge branch 'master' into frameworks
Conflicts:
dolphin/src/statusbar/statusbarspaceinfo.cpp
Diffstat (limited to 'src/statusbar/statusbarspaceinfo.cpp')
| -rw-r--r-- | src/statusbar/statusbarspaceinfo.cpp | 57 |
1 files changed, 19 insertions, 38 deletions
diff --git a/src/statusbar/statusbarspaceinfo.cpp b/src/statusbar/statusbarspaceinfo.cpp index 82fa47143..3692947b1 100644 --- a/src/statusbar/statusbarspaceinfo.cpp +++ b/src/statusbar/statusbarspaceinfo.cpp @@ -20,22 +20,17 @@ #include "statusbarspaceinfo.h" -#include <KDiskFreeSpaceInfo> +#include "spaceinfoobserver.h" + #include <KLocale> #include <KIO/Job> -#include <QTimer> #include <QKeyEvent> StatusBarSpaceInfo::StatusBarSpaceInfo(QWidget* parent) : KCapacityBar(KCapacityBar::DrawTextInline, parent), - m_kBSize(0), - m_timer(0) + m_observer(0) { - // Use a timer to update the space information. Polling is useful - // here, as files can be deleted/added outside the scope of Dolphin. - m_timer = new QTimer(this); - connect(m_timer, &QTimer::timeout, this, &StatusBarSpaceInfo::calculateSpaceInfo); } StatusBarSpaceInfo::~StatusBarSpaceInfo() @@ -46,8 +41,8 @@ void StatusBarSpaceInfo::setUrl(const KUrl& url) { if (m_url != url) { m_url = url; - if (isVisible()) { - calculateSpaceInfo(); + if (m_observer) { + m_observer->setUrl(url); } } } @@ -60,47 +55,33 @@ KUrl StatusBarSpaceInfo::url() const void StatusBarSpaceInfo::showEvent(QShowEvent* event) { KCapacityBar::showEvent(event); - if (!event->spontaneous()) { - calculateSpaceInfo(); - m_timer->start(10000); - } + m_observer.reset(new SpaceInfoObserver(m_url, this)); + slotValuesChanged(); + connect(m_observer.data(), SIGNAL(valuesChanged()), this, SLOT(slotValuesChanged())); } void StatusBarSpaceInfo::hideEvent(QHideEvent* event) { - m_timer->stop(); + m_observer.reset(); KCapacityBar::hideEvent(event); } -void StatusBarSpaceInfo::calculateSpaceInfo() +void StatusBarSpaceInfo::slotValuesChanged() { - // KDiskFreeSpace is for local paths only - if (!m_url.isLocalFile()) { - setText(i18nc("@info:status", "Unknown size")); - setValue(0); - update(); - return; - } - - KDiskFreeSpaceInfo job = KDiskFreeSpaceInfo::freeSpaceInfo(m_url.toLocalFile()); - if (!job.isValid()) { + Q_ASSERT(m_observer); + const quint64 size = m_observer->size(); + if (size == 0) { setText(i18nc("@info:status", "Unknown size")); setValue(0); update(); - return; - } - - KIO::filesize_t kBSize = job.size() / 1024; - KIO::filesize_t kBUsed = job.used() / 1024; - - const bool valuesChanged = (kBUsed != static_cast<quint64>(value())) || (kBSize != m_kBSize); - if (valuesChanged) { - setText(i18nc("@info:status Free disk space", "%1 free", - KIO::convertSize(job.available()))); + } else { + const quint64 available = m_observer->available(); + const quint64 used = size - available; + const int percentUsed = qRound(100.0 * qreal(used) / qreal(size)); + setText(i18nc("@info:status Free disk space", "%1 free", KIO::convertSize(available))); setUpdatesEnabled(false); - m_kBSize = kBSize; - setValue(kBSize > 0 ? (kBUsed * 100) / kBSize : 0); + setValue(percentUsed); setUpdatesEnabled(true); update(); } |
