/**************************************************************************** ** ** Copyright (C) 2016 Openismus GmbH. ** Author: Peter Penz (ppenz@openismus.com) ** Author: Patricia Santana Cruz (patriciasantanacruz@gmail.com) ** Contact: https://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 "autotoolsbuildconfiguration.h" #include "autotoolsprojectconstants.h" #include #include #include #include #include using namespace AutotoolsProjectManager::Constants; using namespace ProjectExplorer; using namespace ProjectExplorer::Constants; using namespace Utils; namespace AutotoolsProjectManager { namespace Internal { // AutotoolsBuildConfiguration AutotoolsBuildConfiguration::AutotoolsBuildConfiguration(Target *parent, Core::Id id) : BuildConfiguration(parent, id) { // / is used so the un-changed check in setBuildDirectory() works correctly. // The leading / is to avoid the relative the path expansion in BuildConfiguration::buildDirectory. setBuildDirectory(Utils::FilePath::fromString("/")); setBuildDirectoryHistoryCompleter("AutoTools.BuildDir.History"); setConfigWidgetDisplayName(tr("Autotools Manager")); setInitializer([this](const BuildInfo &) { // ### Build Steps Build ### // autogen.sh or autoreconf QFile autogenFile(target()->project()->projectDirectory().toString() + "/autogen.sh"); if (autogenFile.exists()) buildSteps()->appendStep(Constants::AUTOGEN_STEP_ID); else buildSteps()->appendStep(Constants::AUTORECONF_STEP_ID); // ./configure. buildSteps()->appendStep(Constants::CONFIGURE_STEP_ID); // make buildSteps()->appendStep(Constants::MAKE_STEP_ID); // ### Build Steps Clean ### cleanSteps()->appendStep(Constants::MAKE_STEP_ID); }); } // AutotoolsBuildConfiguration class AutotoolsBuildConfigurationFactory::AutotoolsBuildConfigurationFactory() { registerBuildConfiguration ("AutotoolsProjectManager.AutotoolsBuildConfiguration"); setSupportedProjectType(Constants::AUTOTOOLS_PROJECT_ID); setSupportedProjectMimeTypeName(Constants::MAKEFILE_MIMETYPE); } QList AutotoolsBuildConfigurationFactory::availableBuilds (const Kit *k, const FilePath &projectPath, bool forSetup) const { BuildInfo info(this); info.typeName = tr("Build"); info.buildDirectory = forSetup ? FilePath::fromString(projectPath.toFileInfo().absolutePath()) : projectPath; info.kitId = k->id(); if (forSetup) { //: The name of the build configuration created by default for a autotools project. info.displayName = tr("Default"); } return {info}; } } // Internal } // AutotoolsProjectManager