From b3ab00e8badfd0911e0d7af7a632b5ae0bf4fbaf Mon Sep 17 00:00:00 2001 From: Peter Penz Date: Mon, 18 Jan 2010 14:08:21 +0000 Subject: fixed issue that SVN actions got disabled after selecting items svn path=/trunk/KDE/kdebase/apps/; revision=1076617 --- src/versioncontrol/fileviewsvnplugin.cpp | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) (limited to 'src/versioncontrol/fileviewsvnplugin.cpp') diff --git a/src/versioncontrol/fileviewsvnplugin.cpp b/src/versioncontrol/fileviewsvnplugin.cpp index 60ab81415..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), @@ -222,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; } @@ -320,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()) { @@ -332,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, @@ -354,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))); -- cgit v1.3