Nim: Resolve duplicate code

Both NimParser implementations were exactly the same code but only one
got tested.

Change-Id: Icdd8badfe60c8d2d8d3184b8307bd3ab67aee95e
Reviewed-by: Filippo Cucchetto <filippocucchetto@gmail.com>
Reviewed-by: hjk <hjk@qt.io>
This commit is contained in:
Bernhard Beschow
2021-02-02 16:47:42 +01:00
parent 4d1b7d4c3d
commit 4f96e397d2
7 changed files with 182 additions and 146 deletions

View File

@@ -19,6 +19,7 @@ add_qtc_plugin(Nim
project/nimbuildconfiguration.cpp project/nimbuildconfiguration.h project/nimbuildconfiguration.cpp project/nimbuildconfiguration.h
project/nimcompilerbuildstep.cpp project/nimcompilerbuildstep.h project/nimcompilerbuildstep.cpp project/nimcompilerbuildstep.h
project/nimcompilercleanstep.cpp project/nimcompilercleanstep.h project/nimcompilercleanstep.cpp project/nimcompilercleanstep.h
project/nimoutputtaskparser.cpp project/nimoutputtaskparser.h
project/nimproject.cpp project/nimproject.h project/nimproject.cpp project/nimproject.h
project/nimrunconfiguration.cpp project/nimrunconfiguration.h project/nimrunconfiguration.cpp project/nimrunconfiguration.h
project/nimtoolchain.cpp project/nimtoolchain.h project/nimtoolchain.cpp project/nimtoolchain.h

View File

@@ -20,6 +20,7 @@ HEADERS += \
project/nimbleproject.h \ project/nimbleproject.h \
project/nimblerunconfiguration.h \ project/nimblerunconfiguration.h \
project/nimbletaskstep.h \ project/nimbletaskstep.h \
project/nimoutputtaskparser.h \
tools/nimlexer.h \ tools/nimlexer.h \
tools/sourcecodestream.h \ tools/sourcecodestream.h \
project/nimbuildsystem.h \ project/nimbuildsystem.h \
@@ -56,6 +57,7 @@ SOURCES += \
project/nimbletaskstep.cpp \ project/nimbletaskstep.cpp \
project/nimbleproject.cpp \ project/nimbleproject.cpp \
project/nimblerunconfiguration.cpp \ project/nimblerunconfiguration.cpp \
project/nimoutputtaskparser.cpp \
tools/nimlexer.cpp \ tools/nimlexer.cpp \
project/nimbuildsystem.cpp \ project/nimbuildsystem.cpp \
project/nimblebuildsystem.cpp \ project/nimblebuildsystem.cpp \

View File

@@ -41,6 +41,7 @@ QtcPlugin {
"nimbuildconfiguration.h", "nimbuildconfiguration.cpp", "nimbuildconfiguration.h", "nimbuildconfiguration.cpp",
"nimcompilerbuildstep.h", "nimcompilerbuildstep.cpp", "nimcompilerbuildstep.h", "nimcompilerbuildstep.cpp",
"nimcompilercleanstep.h", "nimcompilercleanstep.cpp", "nimcompilercleanstep.h", "nimcompilercleanstep.cpp",
"nimoutputtaskparser.h", "nimoutputtaskparser.cpp",
"nimproject.h", "nimproject.cpp", "nimproject.h", "nimproject.cpp",
"nimrunconfiguration.h", "nimrunconfiguration.cpp", "nimrunconfiguration.h", "nimrunconfiguration.cpp",
"nimtoolchain.h", "nimtoolchain.cpp", "nimtoolchain.h", "nimtoolchain.cpp",

View File

@@ -28,6 +28,7 @@
#include "nimconstants.h" #include "nimconstants.h"
#include "nimbleproject.h" #include "nimbleproject.h"
#include "nimbuildsystem.h" #include "nimbuildsystem.h"
#include "nimoutputtaskparser.h"
#include "nimtoolchain.h" #include "nimtoolchain.h"
#include <projectexplorer/buildconfiguration.h> #include <projectexplorer/buildconfiguration.h>
@@ -44,43 +45,6 @@ using namespace Utils;
namespace Nim { namespace Nim {
class NimParser : public OutputTaskParser
{
Result handleLine(const QString &lne, Utils::OutputFormat) override
{
const QString line = lne.trimmed();
static const QRegularExpression regex("(.+.nim)\\((\\d+), (\\d+)\\) (.+)");
static const QRegularExpression warning("(Warning):(.*)");
static const QRegularExpression error("(Error):(.*)");
const QRegularExpressionMatch match = regex.match(line);
if (!match.hasMatch())
return Status::NotHandled;
const QString filename = match.captured(1);
bool lineOk = false;
const int lineNumber = match.captured(2).toInt(&lineOk);
const QString message = match.captured(4);
if (!lineOk)
return Status::NotHandled;
Task::TaskType type = Task::Unknown;
if (warning.match(message).hasMatch())
type = Task::Warning;
else if (error.match(message).hasMatch())
type = Task::Error;
else
return Status::NotHandled;
const CompileTask t(type, message, absoluteFilePath(FilePath::fromUserInput(filename)),
lineNumber);
LinkSpecs linkSpecs;
addLinkSpecForAbsoluteFilePath(linkSpecs, t.file, t.line, match, 1);
scheduleTask(t, 1);
return {Status::Done, linkSpecs};
}
};
class NimbleBuildStep : public AbstractProcessStep class NimbleBuildStep : public AbstractProcessStep
{ {
Q_DECLARE_TR_FUNCTIONS(Nim::NimbleBuilStep) Q_DECLARE_TR_FUNCTIONS(Nim::NimbleBuilStep)

View File

@@ -28,6 +28,7 @@
#include "nimbuildconfiguration.h" #include "nimbuildconfiguration.h"
#include "nimbuildsystem.h" #include "nimbuildsystem.h"
#include "nimconstants.h" #include "nimconstants.h"
#include "nimoutputtaskparser.h"
#include "nimtoolchain.h" #include "nimtoolchain.h"
#include <projectexplorer/processparameters.h> #include <projectexplorer/processparameters.h>
@@ -51,45 +52,6 @@ using namespace Utils;
namespace Nim { namespace Nim {
// NimParser
class NimParser : public ProjectExplorer::OutputTaskParser
{
Result handleLine(const QString &lne, Utils::OutputFormat) override
{
const QString line = lne.trimmed();
static const QRegularExpression regex("(.+.nim)\\((\\d+), (\\d+)\\) (.+)");
static const QRegularExpression warning("(Warning):(.*)");
static const QRegularExpression error("(Error):(.*)");
const QRegularExpressionMatch match = regex.match(line);
if (!match.hasMatch())
return Status::NotHandled;
const QString filename = match.captured(1);
bool lineOk = false;
const int lineNumber = match.captured(2).toInt(&lineOk);
const QString message = match.captured(4);
if (!lineOk)
return Status::NotHandled;
Task::TaskType type = Task::Unknown;
if (warning.match(message).hasMatch())
type = Task::Warning;
else if (error.match(message).hasMatch())
type = Task::Error;
else
return Status::NotHandled;
const CompileTask t(type, message, absoluteFilePath(FilePath::fromUserInput(filename)),
lineNumber);
LinkSpecs linkSpecs;
addLinkSpecForAbsoluteFilePath(linkSpecs, t.file, t.line, match, 1);
scheduleTask(t, 1);
return {Status::Done, linkSpecs};
}
};
NimCompilerBuildStep::NimCompilerBuildStep(BuildStepList *parentList, Utils::Id id) NimCompilerBuildStep::NimCompilerBuildStep(BuildStepList *parentList, Utils::Id id)
: AbstractProcessStep(parentList, id) : AbstractProcessStep(parentList, id)
{ {
@@ -280,73 +242,3 @@ NimCompilerBuildStepFactory::NimCompilerBuildStepFactory()
} }
} // namespace Nim } // namespace Nim
#ifdef WITH_TESTS
#include "nimplugin.h"
#include <projectexplorer/outputparser_test.h>
#include <QTest>
namespace Nim {
void NimPlugin::testNimParser_data()
{
QTest::addColumn<QString>("input");
QTest::addColumn<OutputParserTester::Channel>("inputChannel");
QTest::addColumn<QString>("childStdOutLines");
QTest::addColumn<QString>("childStdErrLines");
QTest::addColumn<Tasks >("tasks");
QTest::addColumn<QString>("outputLines");
// negative tests
QTest::newRow("pass-through stdout")
<< "Sometext" << OutputParserTester::STDOUT
<< "Sometext\n" << QString()
<< Tasks()
<< QString();
QTest::newRow("pass-through stderr")
<< "Sometext" << OutputParserTester::STDERR
<< QString() << "Sometext\n"
<< Tasks()
<< QString();
// positive tests
QTest::newRow("Parse error string")
<< QString::fromLatin1("main.nim(23, 1) Error: undeclared identifier: 'x'")
<< OutputParserTester::STDERR
<< QString() << QString()
<< Tasks({CompileTask(Task::Error,
"Error: undeclared identifier: 'x'",
FilePath::fromUserInput("main.nim"), 23)})
<< QString();
QTest::newRow("Parse warning string")
<< QString::fromLatin1("lib/pure/parseopt.nim(56, 34) Warning: quoteIfContainsWhite is deprecated [Deprecated]")
<< OutputParserTester::STDERR
<< QString() << QString()
<< Tasks({CompileTask(Task::Warning,
"Warning: quoteIfContainsWhite is deprecated [Deprecated]",
FilePath::fromUserInput("lib/pure/parseopt.nim"), 56)})
<< QString();
}
void NimPlugin::testNimParser()
{
OutputParserTester testbench;
testbench.addLineParser(new NimParser);
QFETCH(QString, input);
QFETCH(OutputParserTester::Channel, inputChannel);
QFETCH(Tasks, tasks);
QFETCH(QString, childStdOutLines);
QFETCH(QString, childStdErrLines);
QFETCH(QString, outputLines);
testbench.testParsing(input, inputChannel,
tasks, childStdOutLines, childStdErrLines,
outputLines);
}
}
#endif

View File

@@ -0,0 +1,139 @@
/****************************************************************************
**
** Copyright (C) Filippo Cucchetto <filippocucchetto@gmail.com>
** Contact: http://www.qt.io/licensing
**
** 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 The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 3 as published by the Free Software
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
**
****************************************************************************/
#include "nimoutputtaskparser.h"
#include <QRegularExpression>
using namespace ProjectExplorer;
using namespace Utils;
namespace Nim {
NimParser::Result NimParser::handleLine(const QString &lne, Utils::OutputFormat)
{
const QString line = lne.trimmed();
static const QRegularExpression regex("(.+.nim)\\((\\d+), (\\d+)\\) (.+)");
static const QRegularExpression warning("(Warning):(.*)");
static const QRegularExpression error("(Error):(.*)");
const QRegularExpressionMatch match = regex.match(line);
if (!match.hasMatch())
return Status::NotHandled;
const QString filename = match.captured(1);
bool lineOk = false;
const int lineNumber = match.captured(2).toInt(&lineOk);
const QString message = match.captured(4);
if (!lineOk)
return Status::NotHandled;
Task::TaskType type = Task::Unknown;
if (warning.match(message).hasMatch())
type = Task::Warning;
else if (error.match(message).hasMatch())
type = Task::Error;
else
return Status::NotHandled;
const CompileTask t(type, message, absoluteFilePath(FilePath::fromUserInput(filename)),
lineNumber);
LinkSpecs linkSpecs;
addLinkSpecForAbsoluteFilePath(linkSpecs, t.file, t.line, match, 1);
scheduleTask(t, 1);
return {Status::Done, linkSpecs};
}
} // namespace Nim
#ifdef WITH_TESTS
#include "nimplugin.h"
#include <projectexplorer/outputparser_test.h>
#include <QTest>
namespace Nim {
void NimPlugin::testNimParser_data()
{
QTest::addColumn<QString>("input");
QTest::addColumn<OutputParserTester::Channel>("inputChannel");
QTest::addColumn<QString>("childStdOutLines");
QTest::addColumn<QString>("childStdErrLines");
QTest::addColumn<Tasks >("tasks");
QTest::addColumn<QString>("outputLines");
// negative tests
QTest::newRow("pass-through stdout")
<< "Sometext" << OutputParserTester::STDOUT
<< "Sometext\n" << QString()
<< Tasks()
<< QString();
QTest::newRow("pass-through stderr")
<< "Sometext" << OutputParserTester::STDERR
<< QString() << "Sometext\n"
<< Tasks()
<< QString();
// positive tests
QTest::newRow("Parse error string")
<< QString::fromLatin1("main.nim(23, 1) Error: undeclared identifier: 'x'")
<< OutputParserTester::STDERR
<< QString() << QString()
<< Tasks({CompileTask(Task::Error,
"Error: undeclared identifier: 'x'",
FilePath::fromUserInput("main.nim"), 23)})
<< QString();
QTest::newRow("Parse warning string")
<< QString::fromLatin1("lib/pure/parseopt.nim(56, 34) Warning: quoteIfContainsWhite is deprecated [Deprecated]")
<< OutputParserTester::STDERR
<< QString() << QString()
<< Tasks({CompileTask(Task::Warning,
"Warning: quoteIfContainsWhite is deprecated [Deprecated]",
FilePath::fromUserInput("lib/pure/parseopt.nim"), 56)})
<< QString();
}
void NimPlugin::testNimParser()
{
OutputParserTester testbench;
testbench.addLineParser(new NimParser);
QFETCH(QString, input);
QFETCH(OutputParserTester::Channel, inputChannel);
QFETCH(Tasks, tasks);
QFETCH(QString, childStdOutLines);
QFETCH(QString, childStdErrLines);
QFETCH(QString, outputLines);
testbench.testParsing(input, inputChannel,
tasks, childStdOutLines, childStdErrLines,
outputLines);
}
}
#endif

View File

@@ -0,0 +1,37 @@
/****************************************************************************
**
** Copyright (C) Filippo Cucchetto <filippocucchetto@gmail.com>
** Contact: http://www.qt.io/licensing
**
** 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 The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 3 as published by the Free Software
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
**
****************************************************************************/
#pragma once
#include <projectexplorer/ioutputparser.h>
namespace Nim {
class NimParser : public ProjectExplorer::OutputTaskParser
{
Result handleLine(const QString &line, Utils::OutputFormat) override;
};
} // Nim