forked from qt-creator/qt-creator
Nim: Merge Toolchain related file pairs
Change-Id: Ia8526bc55934e6f2b29aa291a6269050309e3b4f Reviewed-by: Jarek Kobus <jaroslaw.kobus@qt.io>
This commit is contained in:
@@ -24,7 +24,6 @@ add_qtc_plugin(Nim
|
|||||||
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
|
||||||
project/nimtoolchainfactory.cpp project/nimtoolchainfactory.h
|
|
||||||
settings/nimcodestylepreferencesfactory.cpp settings/nimcodestylepreferencesfactory.h
|
settings/nimcodestylepreferencesfactory.cpp settings/nimcodestylepreferencesfactory.h
|
||||||
settings/nimcodestylepreferenceswidget.cpp settings/nimcodestylepreferenceswidget.h
|
settings/nimcodestylepreferenceswidget.cpp settings/nimcodestylepreferenceswidget.h
|
||||||
settings/nimcodestylesettingspage.cpp settings/nimcodestylesettingspage.h
|
settings/nimcodestylesettingspage.cpp settings/nimcodestylesettingspage.h
|
||||||
|
@@ -46,7 +46,6 @@ QtcPlugin {
|
|||||||
"nimproject.h", "nimproject.cpp",
|
"nimproject.h", "nimproject.cpp",
|
||||||
"nimrunconfiguration.h", "nimrunconfiguration.cpp",
|
"nimrunconfiguration.h", "nimrunconfiguration.cpp",
|
||||||
"nimtoolchain.h", "nimtoolchain.cpp",
|
"nimtoolchain.h", "nimtoolchain.cpp",
|
||||||
"nimtoolchainfactory.h", "nimtoolchainfactory.cpp",
|
|
||||||
"nimblebuildstep.h", "nimblebuildstep.cpp",
|
"nimblebuildstep.h", "nimblebuildstep.cpp",
|
||||||
"nimbleproject.h", "nimbleproject.cpp",
|
"nimbleproject.h", "nimbleproject.cpp",
|
||||||
"nimblerunconfiguration.h", "nimblerunconfiguration.cpp",
|
"nimblerunconfiguration.h", "nimblerunconfiguration.cpp",
|
||||||
|
@@ -14,7 +14,7 @@
|
|||||||
#include "project/nimproject.h"
|
#include "project/nimproject.h"
|
||||||
#include "project/nimbleproject.h"
|
#include "project/nimbleproject.h"
|
||||||
#include "project/nimrunconfiguration.h"
|
#include "project/nimrunconfiguration.h"
|
||||||
#include "project/nimtoolchainfactory.h"
|
#include "project/nimtoolchain.h"
|
||||||
#include "project/nimblebuildstep.h"
|
#include "project/nimblebuildstep.h"
|
||||||
#include "project/nimbletaskstep.h"
|
#include "project/nimbletaskstep.h"
|
||||||
#include "settings/nimcodestylepreferencesfactory.h"
|
#include "settings/nimcodestylepreferencesfactory.h"
|
||||||
|
@@ -4,13 +4,22 @@
|
|||||||
#include "nimtoolchain.h"
|
#include "nimtoolchain.h"
|
||||||
|
|
||||||
#include "nimconstants.h"
|
#include "nimconstants.h"
|
||||||
#include "nimtoolchainfactory.h"
|
#include "nimtoolchain.h"
|
||||||
#include "nimtr.h"
|
#include "nimtr.h"
|
||||||
|
|
||||||
#include <projectexplorer/abi.h>
|
#include <projectexplorer/abi.h>
|
||||||
#include <utils/environment.h>
|
#include <projectexplorer/devicesupport/devicemanager.h>
|
||||||
#include <utils/process.h>
|
#include <projectexplorer/toolchainconfigwidget.h>
|
||||||
|
|
||||||
|
#include <utils/algorithm.h>
|
||||||
|
#include <utils/environment.h>
|
||||||
|
#include <utils/environment.h>
|
||||||
|
#include <utils/fileutils.h>
|
||||||
|
#include <utils/pathchooser.h>
|
||||||
|
#include <utils/process.h>
|
||||||
|
#include <utils/qtcassert.h>
|
||||||
|
|
||||||
|
#include <QFormLayout>
|
||||||
#include <QRegularExpression>
|
#include <QRegularExpression>
|
||||||
|
|
||||||
using namespace ProjectExplorer;
|
using namespace ProjectExplorer;
|
||||||
@@ -70,11 +79,6 @@ QList<Utils::OutputLineParser *> NimToolChain::createOutputParsers() const
|
|||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
std::unique_ptr<ProjectExplorer::ToolChainConfigWidget> NimToolChain::createConfigurationWidget()
|
|
||||||
{
|
|
||||||
return std::make_unique<NimToolChainConfigWidget>(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
QString NimToolChain::compilerVersion() const
|
QString NimToolChain::compilerVersion() const
|
||||||
{
|
{
|
||||||
return compilerCommand().isEmpty() || m_version == std::make_tuple(-1,-1,-1)
|
return compilerCommand().isEmpty() || m_version == std::make_tuple(-1,-1,-1)
|
||||||
@@ -114,4 +118,133 @@ bool NimToolChain::parseVersion(const FilePath &path, std::tuple<int, int, int>
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NimToolChainConfigWidget
|
||||||
|
|
||||||
|
class NimToolChainConfigWidget : public ToolChainConfigWidget
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
explicit NimToolChainConfigWidget(NimToolChain *tc)
|
||||||
|
: ToolChainConfigWidget(tc)
|
||||||
|
, m_compilerCommand(new PathChooser)
|
||||||
|
, m_compilerVersion(new QLineEdit)
|
||||||
|
{
|
||||||
|
// Create ui
|
||||||
|
const auto gnuVersionArgs = QStringList("--version");
|
||||||
|
m_compilerCommand->setExpectedKind(PathChooser::ExistingCommand);
|
||||||
|
m_compilerCommand->setCommandVersionArguments(gnuVersionArgs);
|
||||||
|
m_mainLayout->addRow(Tr::tr("&Compiler path:"), m_compilerCommand);
|
||||||
|
m_compilerVersion->setReadOnly(true);
|
||||||
|
m_mainLayout->addRow(Tr::tr("&Compiler version:"), m_compilerVersion);
|
||||||
|
|
||||||
|
// Fill
|
||||||
|
fillUI();
|
||||||
|
|
||||||
|
// Connect
|
||||||
|
connect(m_compilerCommand, &PathChooser::validChanged, this, [this] {
|
||||||
|
const FilePath path = m_compilerCommand->rawFilePath();
|
||||||
|
auto tc = static_cast<NimToolChain *>(toolChain());
|
||||||
|
QTC_ASSERT(tc, return);
|
||||||
|
tc->setCompilerCommand(path);
|
||||||
|
fillUI();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
void applyImpl() final;
|
||||||
|
void discardImpl() final;
|
||||||
|
bool isDirtyImpl() const final;
|
||||||
|
void makeReadOnlyImpl() final;
|
||||||
|
|
||||||
|
private:
|
||||||
|
void fillUI();
|
||||||
|
|
||||||
|
Utils::PathChooser *m_compilerCommand;
|
||||||
|
QLineEdit *m_compilerVersion;
|
||||||
|
};
|
||||||
|
|
||||||
|
void NimToolChainConfigWidget::applyImpl()
|
||||||
|
{
|
||||||
|
auto tc = static_cast<NimToolChain *>(toolChain());
|
||||||
|
Q_ASSERT(tc);
|
||||||
|
if (tc->isAutoDetected())
|
||||||
|
return;
|
||||||
|
tc->setCompilerCommand(m_compilerCommand->filePath());
|
||||||
|
}
|
||||||
|
|
||||||
|
void NimToolChainConfigWidget::discardImpl()
|
||||||
|
{
|
||||||
|
fillUI();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool NimToolChainConfigWidget::isDirtyImpl() const
|
||||||
|
{
|
||||||
|
auto tc = static_cast<NimToolChain *>(toolChain());
|
||||||
|
Q_ASSERT(tc);
|
||||||
|
return tc->compilerCommand() != m_compilerCommand->filePath();
|
||||||
|
}
|
||||||
|
|
||||||
|
void NimToolChainConfigWidget::makeReadOnlyImpl()
|
||||||
|
{
|
||||||
|
m_compilerCommand->setReadOnly(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
void NimToolChainConfigWidget::fillUI()
|
||||||
|
{
|
||||||
|
auto tc = static_cast<NimToolChain *>(toolChain());
|
||||||
|
Q_ASSERT(tc);
|
||||||
|
m_compilerCommand->setFilePath(tc->compilerCommand());
|
||||||
|
m_compilerVersion->setText(tc->compilerVersion());
|
||||||
|
}
|
||||||
|
|
||||||
|
std::unique_ptr<ToolChainConfigWidget> NimToolChain::createConfigurationWidget()
|
||||||
|
{
|
||||||
|
return std::make_unique<NimToolChainConfigWidget>(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
// NimToolChainFactory
|
||||||
|
|
||||||
|
NimToolChainFactory::NimToolChainFactory()
|
||||||
|
{
|
||||||
|
setDisplayName(Tr::tr("Nim"));
|
||||||
|
setSupportedToolChainType(Constants::C_NIMTOOLCHAIN_TYPEID);
|
||||||
|
setSupportedLanguages({Constants::C_NIMLANGUAGE_ID});
|
||||||
|
setToolchainConstructor([] { return new NimToolChain; });
|
||||||
|
setUserCreatable(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
Toolchains NimToolChainFactory::autoDetect(const ToolchainDetector &detector) const
|
||||||
|
{
|
||||||
|
Toolchains result;
|
||||||
|
|
||||||
|
const FilePath compilerPath = detector.device->searchExecutableInPath("nim");
|
||||||
|
if (compilerPath.isEmpty())
|
||||||
|
return result;
|
||||||
|
|
||||||
|
result = Utils::filtered(detector.alreadyKnown, [compilerPath](ToolChain *tc) {
|
||||||
|
return tc->typeId() == Constants::C_NIMTOOLCHAIN_TYPEID
|
||||||
|
&& tc->compilerCommand() == compilerPath;
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!result.empty())
|
||||||
|
return result;
|
||||||
|
|
||||||
|
auto tc = new NimToolChain;
|
||||||
|
tc->setDetection(ToolChain::AutoDetection);
|
||||||
|
tc->setCompilerCommand(compilerPath);
|
||||||
|
result.append(tc);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
Toolchains NimToolChainFactory::detectForImport(const ToolChainDescription &tcd) const
|
||||||
|
{
|
||||||
|
Toolchains result;
|
||||||
|
if (tcd.language == Constants::C_NIMLANGUAGE_ID) {
|
||||||
|
auto tc = new NimToolChain;
|
||||||
|
tc->setDetection(ToolChain::ManualDetection); // FIXME: sure?
|
||||||
|
tc->setCompilerCommand(tcd.compilerPath);
|
||||||
|
result.append(tc);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
} // Nim
|
} // Nim
|
||||||
|
@@ -34,4 +34,13 @@ private:
|
|||||||
std::tuple<int, int, int> m_version;
|
std::tuple<int, int, int> m_version;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class NimToolChainFactory : public ProjectExplorer::ToolChainFactory
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
NimToolChainFactory();
|
||||||
|
|
||||||
|
ProjectExplorer::Toolchains autoDetect(const ProjectExplorer::ToolchainDetector &detector) const final;
|
||||||
|
ProjectExplorer::Toolchains detectForImport(const ProjectExplorer::ToolChainDescription &tcd) const final;
|
||||||
|
};
|
||||||
|
|
||||||
} // Nim
|
} // Nim
|
||||||
|
@@ -1,129 +0,0 @@
|
|||||||
// Copyright (C) Filippo Cucchetto <filippocucchetto@gmail.com>
|
|
||||||
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
|
|
||||||
|
|
||||||
#include "nimtoolchainfactory.h"
|
|
||||||
|
|
||||||
#include "nimconstants.h"
|
|
||||||
#include "nimtoolchain.h"
|
|
||||||
#include "nimtr.h"
|
|
||||||
|
|
||||||
#include <projectexplorer/devicesupport/devicemanager.h>
|
|
||||||
|
|
||||||
#include <utils/algorithm.h>
|
|
||||||
#include <utils/environment.h>
|
|
||||||
#include <utils/fileutils.h>
|
|
||||||
#include <utils/pathchooser.h>
|
|
||||||
#include <utils/qtcassert.h>
|
|
||||||
|
|
||||||
#include <QFormLayout>
|
|
||||||
|
|
||||||
using namespace ProjectExplorer;
|
|
||||||
using namespace Utils;
|
|
||||||
|
|
||||||
namespace Nim {
|
|
||||||
|
|
||||||
NimToolChainFactory::NimToolChainFactory()
|
|
||||||
{
|
|
||||||
setDisplayName(Tr::tr("Nim"));
|
|
||||||
setSupportedToolChainType(Constants::C_NIMTOOLCHAIN_TYPEID);
|
|
||||||
setSupportedLanguages({Constants::C_NIMLANGUAGE_ID});
|
|
||||||
setToolchainConstructor([] { return new NimToolChain; });
|
|
||||||
setUserCreatable(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
Toolchains NimToolChainFactory::autoDetect(const ToolchainDetector &detector) const
|
|
||||||
{
|
|
||||||
Toolchains result;
|
|
||||||
|
|
||||||
const FilePath compilerPath = detector.device->searchExecutableInPath("nim");
|
|
||||||
if (compilerPath.isEmpty())
|
|
||||||
return result;
|
|
||||||
|
|
||||||
result = Utils::filtered(detector.alreadyKnown, [compilerPath](ToolChain *tc) {
|
|
||||||
return tc->typeId() == Constants::C_NIMTOOLCHAIN_TYPEID
|
|
||||||
&& tc->compilerCommand() == compilerPath;
|
|
||||||
});
|
|
||||||
|
|
||||||
if (!result.empty())
|
|
||||||
return result;
|
|
||||||
|
|
||||||
auto tc = new NimToolChain;
|
|
||||||
tc->setDetection(ToolChain::AutoDetection);
|
|
||||||
tc->setCompilerCommand(compilerPath);
|
|
||||||
result.append(tc);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
Toolchains NimToolChainFactory::detectForImport(const ToolChainDescription &tcd) const
|
|
||||||
{
|
|
||||||
Toolchains result;
|
|
||||||
if (tcd.language == Constants::C_NIMLANGUAGE_ID) {
|
|
||||||
auto tc = new NimToolChain;
|
|
||||||
tc->setDetection(ToolChain::ManualDetection); // FIXME: sure?
|
|
||||||
tc->setCompilerCommand(tcd.compilerPath);
|
|
||||||
result.append(tc);
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
NimToolChainConfigWidget::NimToolChainConfigWidget(NimToolChain *tc)
|
|
||||||
: ToolChainConfigWidget(tc)
|
|
||||||
, m_compilerCommand(new PathChooser)
|
|
||||||
, m_compilerVersion(new QLineEdit)
|
|
||||||
{
|
|
||||||
// Create ui
|
|
||||||
const auto gnuVersionArgs = QStringList("--version");
|
|
||||||
m_compilerCommand->setExpectedKind(PathChooser::ExistingCommand);
|
|
||||||
m_compilerCommand->setCommandVersionArguments(gnuVersionArgs);
|
|
||||||
m_mainLayout->addRow(Tr::tr("&Compiler path:"), m_compilerCommand);
|
|
||||||
m_compilerVersion->setReadOnly(true);
|
|
||||||
m_mainLayout->addRow(Tr::tr("&Compiler version:"), m_compilerVersion);
|
|
||||||
|
|
||||||
// Fill
|
|
||||||
fillUI();
|
|
||||||
|
|
||||||
// Connect
|
|
||||||
connect(m_compilerCommand, &PathChooser::validChanged, this, [this] {
|
|
||||||
const FilePath path = m_compilerCommand->rawFilePath();
|
|
||||||
auto tc = static_cast<NimToolChain *>(toolChain());
|
|
||||||
QTC_ASSERT(tc, return);
|
|
||||||
tc->setCompilerCommand(path);
|
|
||||||
fillUI();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
void NimToolChainConfigWidget::applyImpl()
|
|
||||||
{
|
|
||||||
auto tc = static_cast<NimToolChain *>(toolChain());
|
|
||||||
Q_ASSERT(tc);
|
|
||||||
if (tc->isAutoDetected())
|
|
||||||
return;
|
|
||||||
tc->setCompilerCommand(m_compilerCommand->filePath());
|
|
||||||
}
|
|
||||||
|
|
||||||
void NimToolChainConfigWidget::discardImpl()
|
|
||||||
{
|
|
||||||
fillUI();
|
|
||||||
}
|
|
||||||
|
|
||||||
bool NimToolChainConfigWidget::isDirtyImpl() const
|
|
||||||
{
|
|
||||||
auto tc = static_cast<NimToolChain *>(toolChain());
|
|
||||||
Q_ASSERT(tc);
|
|
||||||
return tc->compilerCommand() != m_compilerCommand->filePath();
|
|
||||||
}
|
|
||||||
|
|
||||||
void NimToolChainConfigWidget::makeReadOnlyImpl()
|
|
||||||
{
|
|
||||||
m_compilerCommand->setReadOnly(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
void NimToolChainConfigWidget::fillUI()
|
|
||||||
{
|
|
||||||
auto tc = static_cast<NimToolChain *>(toolChain());
|
|
||||||
Q_ASSERT(tc);
|
|
||||||
m_compilerCommand->setFilePath(tc->compilerCommand());
|
|
||||||
m_compilerVersion->setText(tc->compilerVersion());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,44 +0,0 @@
|
|||||||
// Copyright (C) Filippo Cucchetto <filippocucchetto@gmail.com>
|
|
||||||
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
|
|
||||||
|
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#include <projectexplorer/toolchain.h>
|
|
||||||
#include <projectexplorer/toolchainconfigwidget.h>
|
|
||||||
|
|
||||||
namespace Utils { class PathChooser; }
|
|
||||||
|
|
||||||
namespace Nim {
|
|
||||||
|
|
||||||
class NimToolChain;
|
|
||||||
|
|
||||||
class NimToolChainFactory : public ProjectExplorer::ToolChainFactory
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
NimToolChainFactory();
|
|
||||||
|
|
||||||
ProjectExplorer::Toolchains autoDetect(const ProjectExplorer::ToolchainDetector &detector) const final;
|
|
||||||
ProjectExplorer::Toolchains detectForImport(const ProjectExplorer::ToolChainDescription &tcd) const final;
|
|
||||||
};
|
|
||||||
|
|
||||||
class NimToolChainConfigWidget : public ProjectExplorer::ToolChainConfigWidget
|
|
||||||
{
|
|
||||||
Q_OBJECT
|
|
||||||
|
|
||||||
public:
|
|
||||||
explicit NimToolChainConfigWidget(NimToolChain *tc);
|
|
||||||
|
|
||||||
protected:
|
|
||||||
void applyImpl() final;
|
|
||||||
void discardImpl() final;
|
|
||||||
bool isDirtyImpl() const final;
|
|
||||||
void makeReadOnlyImpl() final;
|
|
||||||
|
|
||||||
private:
|
|
||||||
void fillUI();
|
|
||||||
|
|
||||||
Utils::PathChooser *m_compilerCommand;
|
|
||||||
QLineEdit *m_compilerVersion;
|
|
||||||
};
|
|
||||||
|
|
||||||
} // Nim
|
|
Reference in New Issue
Block a user