// Copyright (C) 2018 Jochen Seemann // SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0 #include "conaninstallstep.h" #include "conanconstants.h" #include "conanplugin.h" #include "conansettings.h" #include "conantr.h" #include #include #include #include #include #include #include #include #include #include #include using namespace ProjectExplorer; using namespace Utils; namespace Conan::Internal { // ConanInstallStep class ConanInstallStep final : public AbstractProcessStep { public: ConanInstallStep(BuildStepList *bsl, Id id); private: bool init() final; void setupOutputFormatter(OutputFormatter *formatter) final; }; ConanInstallStep::ConanInstallStep(BuildStepList *bsl, Id id) : AbstractProcessStep(bsl, id) { setUseEnglishOutput(); setDisplayName(Tr::tr("Conan install")); auto conanFile = addAspect(); conanFile->setSettingsKey("ConanPackageManager.InstallStep.ConanFile"); conanFile->setFilePath(ConanPlugin::conanFilePath(project(), project()->projectDirectory() / "conanfile.txt")); conanFile->setLabelText(Tr::tr("Conan file:")); conanFile->setToolTip(Tr::tr("Enter location of conanfile.txt or conanfile.py.")); conanFile->setDisplayStyle(StringAspect::PathChooserDisplay); conanFile->setExpectedKind(PathChooser::File); auto additionalArguments = addAspect(); additionalArguments->setSettingsKey("ConanPackageManager.InstallStep.AdditionalArguments"); additionalArguments->setLabelText(Tr::tr("Additional arguments:")); additionalArguments->setDisplayStyle(StringAspect::LineEditDisplay); auto buildMissing = addAspect(); buildMissing->setSettingsKey("ConanPackageManager.InstallStep.BuildMissing"); buildMissing->setLabel("Build missing:", BoolAspect::LabelPlacement::InExtraLabel); buildMissing->setDefaultValue(true); buildMissing->setValue(true); setCommandLineProvider([=] { BuildConfiguration::BuildType bt = buildConfiguration()->buildType(); const QString buildType = bt == BuildConfiguration::Release ? QString("Release") : QString("Debug"); CommandLine cmd(ConanPlugin::conanSettings()->conanFilePath.filePath()); cmd.addArgs({"install", "-s", "build_type=" + buildType}); if (buildMissing->value()) cmd.addArg("--build=missing"); cmd.addArg(conanFile->value()); cmd.addArgs(additionalArguments->value(), CommandLine::Raw); return cmd; }); setSummaryUpdater([this]() -> QString { QList tcList = ToolChainKitAspect::toolChains(target()->kit()); if (tcList.isEmpty()) return "" + ToolChainKitAspect::msgNoToolChainInTarget() + ""; ProcessParameters param; setupProcessParameters(¶m); return param.summary(displayName()); }); } bool ConanInstallStep::init() { if (!AbstractProcessStep::init()) return false; const QList tcList = ToolChainKitAspect::toolChains(target()->kit()); if (tcList.isEmpty()) { emit addTask(Task::compilerMissingTask()); emitFaultyConfigurationMessage(); return false; } return true; } void ConanInstallStep::setupOutputFormatter(OutputFormatter *formatter) { formatter->addLineParser(new GnuMakeParser()); formatter->addLineParsers(kit()->createOutputParsers()); formatter->addSearchDir(processParameters()->effectiveWorkingDirectory()); AbstractProcessStep::setupOutputFormatter(formatter); } // ConanInstallStepFactory ConanInstallStepFactory::ConanInstallStepFactory() { registerStep(Constants::INSTALL_STEP); setDisplayName(Tr::tr("Run conan install")); } } // Conan::Internal