summaryrefslogtreecommitdiff
path: root/src/plugins/projectexplorer/abstractprocessstep.cpp
diff options
context:
space:
mode:
authorTobias Hunger <tobias.hunger@digia.com>2013-05-03 16:08:00 +0200
committerTobias Hunger <tobias.hunger@digia.com>2013-05-06 10:04:38 +0200
commit8bbad43019af98e342d6a5b311016fa20198e4cf (patch)
tree0727f9ffd34dd0d6dfd221558e2aa69b295f4742 /src/plugins/projectexplorer/abstractprocessstep.cpp
parent14763118a58bf526f873b6750c3785f8752e4d7e (diff)
downloadqt-creator-8bbad43019af98e342d6a5b311016fa20198e4cf.tar.gz
OutputParser: Allow to flush pending tasks.
Add a way to flush out tasks from the outputparsers. This is necessary to make parsers that keep state more robust. Flush parsers (once) before adding any new task. This keeps the sequence intact. Flush all parsers once the parsing is done to make sure there is no task queued somewhere. Task-number: QTCREATORBUG-9195 Change-Id: Icd37df1f470cb73123ad286d6900ad1047a1d512 Reviewed-by: Tobias Hunger <tobias.hunger@digia.com>
Diffstat (limited to 'src/plugins/projectexplorer/abstractprocessstep.cpp')
-rw-r--r--src/plugins/projectexplorer/abstractprocessstep.cpp14
1 files changed, 12 insertions, 2 deletions
diff --git a/src/plugins/projectexplorer/abstractprocessstep.cpp b/src/plugins/projectexplorer/abstractprocessstep.cpp
index a025d03a0c..2c31d5c61e 100644
--- a/src/plugins/projectexplorer/abstractprocessstep.cpp
+++ b/src/plugins/projectexplorer/abstractprocessstep.cpp
@@ -88,7 +88,7 @@ using namespace ProjectExplorer;
AbstractProcessStep::AbstractProcessStep(BuildStepList *bsl, const Core::Id id) :
BuildStep(bsl, id), m_timer(0), m_futureInterface(0),
m_ignoreReturnValue(false), m_process(0),
- m_outputParserChain(0)
+ m_outputParserChain(0), m_skipFlush(false)
{
}
@@ -96,7 +96,7 @@ AbstractProcessStep::AbstractProcessStep(BuildStepList *bsl,
AbstractProcessStep *bs) :
BuildStep(bsl, bs), m_timer(0), m_futureInterface(0),
m_ignoreReturnValue(bs->m_ignoreReturnValue),
- m_process(0), m_outputParserChain(0)
+ m_process(0), m_outputParserChain(0), m_skipFlush(false)
{
}
@@ -261,6 +261,9 @@ void AbstractProcessStep::processStarted()
void AbstractProcessStep::processFinished(int exitCode, QProcess::ExitStatus status)
{
+ if (m_outputParserChain)
+ m_outputParserChain->flush();
+
QString command = QDir::toNativeSeparators(m_param.effectiveCommand());
if (status == QProcess::NormalExit && exitCode == 0) {
emit addOutput(tr("The process \"%1\" exited normally.").arg(command),
@@ -367,6 +370,13 @@ void AbstractProcessStep::taskAdded(const ProjectExplorer::Task &task)
if (m_ignoreReturnValue)
return;
+ // flush out any pending tasks before proceeding:
+ if (!m_skipFlush && m_outputParserChain) {
+ m_skipFlush = true;
+ m_outputParserChain->flush();
+ m_skipFlush = false;
+ }
+
Task editable(task);
QString filePath = task.file.toString();
if (!filePath.isEmpty() && !QDir::isAbsolutePath(filePath)) {