X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/fd74aa8e2057158d2eadb835eb61564854c81020..fa36c3fd1f53a223f43bb57d7c28e431a889a7c2:/src/views/versioncontrol/updateitemstatesthread.cpp diff --git a/src/views/versioncontrol/updateitemstatesthread.cpp b/src/views/versioncontrol/updateitemstatesthread.cpp index b04d66f17..51a277831 100644 --- a/src/views/versioncontrol/updateitemstatesthread.cpp +++ b/src/views/versioncontrol/updateitemstatesthread.cpp @@ -19,15 +19,17 @@ #include "updateitemstatesthread.h" +#include +#include + #include -UpdateItemStatesThread::UpdateItemStatesThread() : +UpdateItemStatesThread::UpdateItemStatesThread(KVersionControlPlugin* plugin, + const QMap >& itemStates) : QThread(), m_globalPluginMutex(0), - m_plugin(0), - m_itemMutex(), - m_retrievedItems(false), - m_itemStates() + m_plugin(plugin), + m_itemStates(itemStates) { // Several threads may share one instance of a plugin. A global // mutex is required to serialize the retrieval of version control @@ -40,62 +42,38 @@ UpdateItemStatesThread::~UpdateItemStatesThread() { } -void UpdateItemStatesThread::setData(KVersionControlPlugin* plugin, - const QList& itemStates) -{ - QMutexLocker itemLocker(&m_itemMutex); - m_itemStates = itemStates; - - QMutexLocker pluginLocker(m_globalPluginMutex); - m_plugin = plugin; -} - void UpdateItemStatesThread::run() { Q_ASSERT(!m_itemStates.isEmpty()); - Q_ASSERT(m_plugin != 0); - - // The items from m_itemStates may be located in different directory levels. The version - // plugin requires the root directory for KVersionControlPlugin::beginRetrieval(). Instead - // of doing an expensive search, we utilize the knowledge of the implementation of - // VersionControlObserver::addDirectory() to be sure that the last item contains the root. - QMutexLocker itemLocker(&m_itemMutex); - const QString directory = m_itemStates.last().item.url().directory(KUrl::AppendTrailingSlash); - itemLocker.unlock(); + Q_ASSERT(m_plugin); QMutexLocker pluginLocker(m_globalPluginMutex); - m_retrievedItems = false; - if (m_plugin->beginRetrieval(directory)) { - itemLocker.relock(); - const int count = m_itemStates.count(); - for (int i = 0; i < count; ++i) { - m_itemStates[i].version = m_plugin->versionState(m_itemStates[i].item); + QMap >::iterator it = m_itemStates.begin(); + for (; it != m_itemStates.end(); ++it) { + if (m_plugin->beginRetrieval(it.key())) { + QVector& items = it.value(); + const int count = items.count(); + + KVersionControlPlugin2* pluginV2 = qobject_cast(m_plugin); + if (pluginV2) { + for (int i = 0; i < count; ++i) { + items[i].version = pluginV2->itemVersion(items[i].item); + } + } else { + for (int i = 0; i < count; ++i) { + const KVersionControlPlugin::VersionState state = m_plugin->versionState(items[i].item); + items[i].version = static_cast(state); + } + } } + m_plugin->endRetrieval(); - m_retrievedItems = true; } } -bool UpdateItemStatesThread::lockPlugin() +QMap > UpdateItemStatesThread::itemStates() const { - return m_globalPluginMutex->tryLock(300); -} - -void UpdateItemStatesThread::unlockPlugin() -{ - m_globalPluginMutex->unlock(); -} - -QList UpdateItemStatesThread::itemStates() const -{ - QMutexLocker locker(&m_itemMutex); return m_itemStates; } -bool UpdateItemStatesThread::retrievedItems() const -{ - QMutexLocker locker(&m_itemMutex); - return m_retrievedItems; -} - #include "updateitemstatesthread.moc"