X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/a47dc8edae84ae571ff364351d493cec0be9d3f3..7eeb8dba6aeba09aa3dfa7fa5f0b00840d4d8317:/src/versioncontrol/fileviewsvnplugin.cpp diff --git a/src/versioncontrol/fileviewsvnplugin.cpp b/src/versioncontrol/fileviewsvnplugin.cpp index 91a37a878..f43f10e98 100644 --- a/src/versioncontrol/fileviewsvnplugin.cpp +++ b/src/versioncontrol/fileviewsvnplugin.cpp @@ -43,6 +43,7 @@ K_EXPORT_PLUGIN(FileViewSvnPluginFactory("fileviewsvnplugin")) FileViewSvnPlugin::FileViewSvnPlugin(QObject* parent, const QList& args) : KVersionControlPlugin(parent), + m_pendingOperation(false), m_versionInfoHash(), m_versionInfoKeys(), m_updateAction(0), @@ -102,6 +103,15 @@ bool FileViewSvnPlugin::beginRetrieval(const QString& directory) { Q_ASSERT(directory.endsWith('/')); + // clear all entries for this directory + QMutableHashIterator it(m_versionInfoHash); + while (it.hasNext()) { + it.next(); + if (it.key().startsWith(directory)) { + it.remove(); + } + } + QStringList arguments; arguments << "status" << "--show-updates" << directory; @@ -213,7 +223,7 @@ QList FileViewSvnPlugin::contextMenuActions(const KFileItemList& items QList FileViewSvnPlugin::contextMenuActions(const QString& directory) { - const bool enabled = m_contextItems.isEmpty(); + const bool enabled = !m_pendingOperation; if (enabled) { m_contextDir = directory; } @@ -311,6 +321,8 @@ void FileViewSvnPlugin::removeFiles() void FileViewSvnPlugin::slotOperationCompleted(int exitCode, QProcess::ExitStatus exitStatus) { + m_pendingOperation = false; + if ((exitStatus != QProcess::NormalExit) || (exitCode != 0)) { emit errorMessage(m_errorMsg); } else if (m_contextItems.isEmpty()) { @@ -323,10 +335,11 @@ void FileViewSvnPlugin::slotOperationCompleted(int exitCode, QProcess::ExitStatu void FileViewSvnPlugin::slotOperationError() { - emit errorMessage(m_errorMsg); - // don't do any operation on other items anymore m_contextItems.clear(); + m_pendingOperation = false; + + emit errorMessage(m_errorMsg); } void FileViewSvnPlugin::execSvnCommand(const QString& svnCommand, @@ -345,6 +358,8 @@ void FileViewSvnPlugin::execSvnCommand(const QString& svnCommand, void FileViewSvnPlugin::startSvnCommandProcess() { + m_pendingOperation = true; + QProcess* process = new QProcess(this); connect(process, SIGNAL(finished(int, QProcess::ExitStatus)), this, SLOT(slotOperationCompleted(int, QProcess::ExitStatus)));