aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/qmakeprojectmanager/qmakeparser.cpp
diff options
context:
space:
mode:
authorEike Ziller <[email protected]>2013-10-30 13:34:46 +0100
committerEike Ziller <[email protected]>2013-10-30 13:34:46 +0100
commit0ddb6cac29628425b7c2490a20df944f062ce50c (patch)
tree8527a12fbc6eb6d3fc7a8e4a30044f549bc2fd92 /src/plugins/qmakeprojectmanager/qmakeparser.cpp
parentbcd704d7bf5a1daa3d0ad9574386c11981c409a2 (diff)
parent88c647ce6868cd7ab03ec96062d2a77813b6e906 (diff)
Merge remote-tracking branch 'origin/3.0'
Conflicts: src/plugins/qmakeprojectmanager/qmakeproject.cpp Change-Id: Id6ac9051d2564788bb180e5a99243d588312ae99
Diffstat (limited to 'src/plugins/qmakeprojectmanager/qmakeparser.cpp')
-rw-r--r--src/plugins/qmakeprojectmanager/qmakeparser.cpp180
1 files changed, 180 insertions, 0 deletions
diff --git a/src/plugins/qmakeprojectmanager/qmakeparser.cpp b/src/plugins/qmakeprojectmanager/qmakeparser.cpp
new file mode 100644
index 00000000000..a64c4c9f613
--- /dev/null
+++ b/src/plugins/qmakeprojectmanager/qmakeparser.cpp
@@ -0,0 +1,180 @@
+/****************************************************************************
+**
+** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies).
+** Contact: http://www.qt-project.org/legal
+**
+** This file is part of Qt Creator.
+**
+** Commercial License Usage
+** Licensees holding valid commercial Qt licenses may use this file in
+** accordance with the commercial license agreement provided with the
+** Software or, alternatively, in accordance with the terms contained in
+** a written agreement between you and Digia. For licensing terms and
+** conditions see http://qt.digia.com/licensing. For further information
+** use the contact form at http://qt.digia.com/contact-us.
+**
+** GNU Lesser General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 2.1 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPL included in the
+** packaging of this file. Please review the following information to
+** ensure the GNU Lesser General Public License version 2.1 requirements
+** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+**
+** In addition, as a special exception, Digia gives you certain additional
+** rights. These rights are described in the Digia Qt LGPL Exception
+** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
+**
+****************************************************************************/
+
+#include "qmakeparser.h"
+
+#include <projectexplorer/task.h>
+#include <projectexplorer/projectexplorerconstants.h>
+
+using namespace QmakeProjectManager;
+using ProjectExplorer::Task;
+
+QMakeParser::QMakeParser() : m_error(QLatin1String("^(.+):(\\d+):\\s(.+)$"))
+{
+ setObjectName(QLatin1String("QMakeParser"));
+ m_error.setMinimal(true);
+}
+
+void QMakeParser::stdError(const QString &line)
+{
+ QString lne = rightTrimmed(line);
+ if (lne.startsWith(QLatin1String("Project ERROR:"))) {
+ const QString description = lne.mid(15);
+ emit addTask(Task(Task::Error,
+ description,
+ Utils::FileName() /* filename */,
+ -1 /* linenumber */,
+ Core::Id(ProjectExplorer::Constants::TASK_CATEGORY_BUILDSYSTEM)));
+ return;
+ }
+ if (lne.startsWith(QLatin1String("Project WARNING:"))) {
+ const QString description = lne.mid(17);
+ emit addTask(Task(Task::Warning,
+ description,
+ Utils::FileName() /* filename */,
+ -1 /* linenumber */,
+ Core::Id(ProjectExplorer::Constants::TASK_CATEGORY_BUILDSYSTEM)));
+ return;
+ }
+ if (m_error.indexIn(lne) > -1) {
+ QString fileName = m_error.cap(1);
+ Task::TaskType type = Task::Error;
+ if (fileName.startsWith(QLatin1String("WARNING: "))) {
+ type = Task::Warning;
+ fileName = fileName.mid(9);
+ } else if (fileName.startsWith(QLatin1String("ERROR: "))) {
+ fileName = fileName.mid(7);
+ }
+ emit addTask(Task(type,
+ m_error.cap(3) /* description */,
+ Utils::FileName::fromUserInput(fileName),
+ m_error.cap(2).toInt() /* line */,
+ Core::Id(ProjectExplorer::Constants::TASK_CATEGORY_BUILDSYSTEM)));
+ return;
+ }
+ IOutputParser::stdError(line);
+}
+
+
+// Unit tests:
+
+#ifdef WITH_TESTS
+# include <QTest>
+
+# include "qmakeprojectmanagerplugin.h"
+
+# include "projectexplorer/outputparser_test.h"
+
+using namespace QmakeProjectManager::Internal;
+using namespace ProjectExplorer;
+
+void QmakeProjectManagerPlugin::testQmakeOutputParsers_data()
+{
+ const Core::Id categoryBuildSystem = Core::Id(ProjectExplorer::Constants::TASK_CATEGORY_BUILDSYSTEM);
+ QTest::addColumn<QString>("input");
+ QTest::addColumn<OutputParserTester::Channel>("inputChannel");
+ QTest::addColumn<QString>("childStdOutLines");
+ QTest::addColumn<QString>("childStdErrLines");
+ QTest::addColumn<QList<ProjectExplorer::Task> >("tasks");
+ QTest::addColumn<QString>("outputLines");
+
+
+ QTest::newRow("pass-through stdout")
+ << QString::fromLatin1("Sometext") << OutputParserTester::STDOUT
+ << QString::fromLatin1("Sometext\n") << QString()
+ << QList<ProjectExplorer::Task>()
+ << QString();
+ QTest::newRow("pass-through stderr")
+ << QString::fromLatin1("Sometext") << OutputParserTester::STDERR
+ << QString() << QString::fromLatin1("Sometext\n")
+ << QList<ProjectExplorer::Task>()
+ << QString();
+
+ QTest::newRow("qMake error")
+ << QString::fromLatin1("Project ERROR: undefined file")
+ << OutputParserTester::STDERR
+ << QString() << QString()
+ << (QList<ProjectExplorer::Task>()
+ << Task(Task::Error,
+ QLatin1String("undefined file"),
+ Utils::FileName(), -1,
+ categoryBuildSystem))
+ << QString();
+
+ QTest::newRow("qMake Parse Error")
+ << QString::fromLatin1("e:\\project.pro:14: Parse Error ('sth odd')")
+ << OutputParserTester::STDERR
+ << QString() << QString()
+ << (QList<ProjectExplorer::Task>()
+ << Task(Task::Error,
+ QLatin1String("Parse Error ('sth odd')"),
+ Utils::FileName::fromUserInput(QLatin1String("e:\\project.pro")),
+ 14,
+ categoryBuildSystem))
+ << QString();
+
+ QTest::newRow("qMake warning")
+ << QString::fromLatin1("Project WARNING: bearer module might require ReadUserData capability")
+ << OutputParserTester::STDERR
+ << QString() << QString()
+ << (QList<ProjectExplorer::Task>()
+ << Task(Task::Warning,
+ QLatin1String("bearer module might require ReadUserData capability"),
+ Utils::FileName(), -1,
+ categoryBuildSystem))
+ << QString();
+
+ QTest::newRow("qMake warning with location")
+ << QString::fromLatin1("WARNING: e:\\QtSDK\\Simulator\\Qt\\msvc2008\\lib\\qtmaind.prl:1: Unescaped backslashes are deprecated.")
+ << OutputParserTester::STDERR
+ << QString() << QString()
+ << (QList<ProjectExplorer::Task>()
+ << Task(Task::Warning,
+ QLatin1String("Unescaped backslashes are deprecated."),
+ Utils::FileName::fromUserInput(QLatin1String("e:\\QtSDK\\Simulator\\Qt\\msvc2008\\lib\\qtmaind.prl")), 1,
+ categoryBuildSystem))
+ << QString();
+}
+
+void QmakeProjectManagerPlugin::testQmakeOutputParsers()
+{
+ OutputParserTester testbench;
+ testbench.appendOutputParser(new QMakeParser);
+ QFETCH(QString, input);
+ QFETCH(OutputParserTester::Channel, inputChannel);
+ QFETCH(QList<Task>, tasks);
+ QFETCH(QString, childStdOutLines);
+ QFETCH(QString, childStdErrLines);
+ QFETCH(QString, outputLines);
+
+ testbench.testParsing(input, inputChannel,
+ tasks, childStdOutLines, childStdErrLines,
+ outputLines);
+}
+#endif