/************************************************************************** ** ** This file is part of Qt Creator ** ** Copyright (c) 2010-2011 Openismus GmbH. ** Authors: Peter Penz (ppenz@openismus.com) ** Patricia Santana Cruz (patriciasantanacruz@gmail.com) ** ** Contact: Nokia Corporation (info@qt.nokia.com) ** ** ** GNU Lesser General Public License Usage ** ** 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, Nokia gives you certain additional ** rights. These rights are described in the Nokia Qt LGPL Exception ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. ** ** Other Usage ** ** Alternatively, this file may be used in accordance with the terms and ** conditions contained in a signed written agreement between you and Nokia. ** ** If you have questions regarding the use of this file, please contact ** Nokia at info@qt.nokia.com. ** **************************************************************************/ #include "autotoolsbuildconfiguration.h" #include "autotoolsbuildsettingswidget.h" #include "makestep.h" #include "autotoolsproject.h" #include "autotoolsprojectconstants.h" #include "autogenstep.h" #include "autoreconfstep.h" #include "configurestep.h" #include <projectexplorer/buildsteplist.h> #include <projectexplorer/kitinformation.h> #include <projectexplorer/projectexplorerconstants.h> #include <projectexplorer/target.h> #include <projectexplorer/toolchain.h> #include <qtsupport/customexecutablerunconfiguration.h> #include <utils/qtcassert.h> #include <QInputDialog> using namespace AutotoolsProjectManager; using namespace AutotoolsProjectManager::Constants; using namespace Internal; using namespace ProjectExplorer; using namespace ProjectExplorer::Constants; ////////////////////////////////////// // AutotoolsBuildConfiguration class ////////////////////////////////////// AutotoolsBuildConfiguration::AutotoolsBuildConfiguration(ProjectExplorer::Target *parent) : BuildConfiguration(parent, Core::Id(AUTOTOOLS_BC_ID)) { AutotoolsProject *project = qobject_cast<AutotoolsProject *>(parent->project()); if (project) m_buildDirectory = project->defaultBuildDirectory(); } BuildConfigWidget *AutotoolsBuildConfiguration::createConfigWidget() { return new AutotoolsBuildSettingsWidget; } AutotoolsBuildConfiguration::AutotoolsBuildConfiguration(ProjectExplorer::Target *parent, const Core::Id id) : BuildConfiguration(parent, id) { } AutotoolsBuildConfiguration::AutotoolsBuildConfiguration(ProjectExplorer::Target *parent, AutotoolsBuildConfiguration *source) : BuildConfiguration(parent, source), m_buildDirectory(source->m_buildDirectory) { cloneSteps(source); } QVariantMap AutotoolsBuildConfiguration::toMap() const { QVariantMap map = BuildConfiguration::toMap(); map.insert(QLatin1String(BUILD_DIRECTORY_KEY), m_buildDirectory); return map; } bool AutotoolsBuildConfiguration::fromMap(const QVariantMap &map) { if (!BuildConfiguration::fromMap(map)) return false; m_buildDirectory = map.value(QLatin1String(BUILD_DIRECTORY_KEY)).toString(); return true; } QString AutotoolsBuildConfiguration::buildDirectory() const { return m_buildDirectory; } void AutotoolsBuildConfiguration::setBuildDirectory(const QString &buildDirectory) { if (m_buildDirectory == buildDirectory) return; m_buildDirectory = buildDirectory; emit buildDirectoryChanged(); } IOutputParser *AutotoolsBuildConfiguration::createOutputParser() const { ToolChain *tc = ProjectExplorer::ToolChainKitInformation::toolChain(target()->kit()); if (tc) return tc->outputParser(); return 0; } ////////////////////////////////////// // AutotoolsBuildConfiguration class ////////////////////////////////////// AutotoolsBuildConfigurationFactory::AutotoolsBuildConfigurationFactory(QObject *parent) : IBuildConfigurationFactory(parent) { } QList<Core::Id> AutotoolsBuildConfigurationFactory::availableCreationIds(const Target *parent) const { if (!canHandle(parent)) return QList<Core::Id>(); return QList<Core::Id>() << Core::Id(AUTOTOOLS_BC_ID); } QString AutotoolsBuildConfigurationFactory::displayNameForId(const Core::Id id) const { if (id == AUTOTOOLS_BC_ID) return tr("Build"); return QString(); } bool AutotoolsBuildConfigurationFactory::canCreate(const Target *parent, const Core::Id id) const { if (!canHandle(parent)) return false; if (id == AUTOTOOLS_BC_ID) return true; return false; } AutotoolsBuildConfiguration *AutotoolsBuildConfigurationFactory::create(Target *parent, const Core::Id id, const QString &name) { if (!canCreate(parent, id)) return 0; bool ok = true; QString buildConfigurationName = name; if (buildConfigurationName.isEmpty()) buildConfigurationName = QInputDialog::getText(0, tr("New Configuration"), tr("New configuration name:"), QLineEdit::Normal, QString(), &ok); buildConfigurationName = buildConfigurationName.trimmed(); if (!ok || buildConfigurationName.isEmpty()) return 0; AutotoolsBuildConfiguration *bc = createDefaultConfiguration(parent); bc->setDisplayName(buildConfigurationName); return bc; } AutotoolsBuildConfiguration *AutotoolsBuildConfigurationFactory::createDefaultConfiguration(ProjectExplorer::Target *target) { AutotoolsBuildConfiguration *bc = new AutotoolsBuildConfiguration(target); BuildStepList *buildSteps = bc->stepList(Core::Id(BUILDSTEPS_BUILD)); // ### Build Steps Build ### // autogen.sh or autoreconf QFile autogenFile(target->project()->projectDirectory() + QLatin1String("/autogen.sh")); if (autogenFile.exists()) { AutogenStep *autogenStep = new AutogenStep(buildSteps); buildSteps->insertStep(0, autogenStep); } else { AutoreconfStep *autoreconfStep = new AutoreconfStep(buildSteps); autoreconfStep->setAdditionalArguments(QLatin1String("--force --install")); buildSteps->insertStep(0, autoreconfStep); } // ./configure. ConfigureStep *configureStep = new ConfigureStep(buildSteps); buildSteps->insertStep(1, configureStep); // make MakeStep *makeStep = new MakeStep(buildSteps); buildSteps->insertStep(2, makeStep); makeStep->setBuildTarget(QLatin1String("all"), /*on =*/ true); // ### Build Steps Clean ### BuildStepList *cleanSteps = bc->stepList(Core::Id(BUILDSTEPS_CLEAN)); MakeStep *cleanMakeStep = new MakeStep(cleanSteps); cleanMakeStep->setAdditionalArguments(QLatin1String("clean")); cleanMakeStep->setClean(true); cleanSteps->insertStep(0, cleanMakeStep); return bc; } bool AutotoolsBuildConfigurationFactory::canHandle(const Target *t) const { if (!t->project()->supportsKit(t->kit())) return false; return t->project()->id() == Constants::AUTOTOOLS_PROJECT_ID; } bool AutotoolsBuildConfigurationFactory::canClone(const Target *parent, BuildConfiguration *source) const { return canCreate(parent, source->id()); } AutotoolsBuildConfiguration *AutotoolsBuildConfigurationFactory::clone(Target *parent, BuildConfiguration *source) { if (!canClone(parent, source)) return 0; AutotoolsBuildConfiguration *origin = static_cast<AutotoolsBuildConfiguration *>(source); return new AutotoolsBuildConfiguration(parent, origin); } bool AutotoolsBuildConfigurationFactory::canRestore(const Target *parent, const QVariantMap &map) const { return canCreate(parent, idFromMap(map)); } AutotoolsBuildConfiguration *AutotoolsBuildConfigurationFactory::restore(Target *parent, const QVariantMap &map) { if (!canRestore(parent, map)) return 0; AutotoolsBuildConfiguration *bc = new AutotoolsBuildConfiguration(parent); if (bc->fromMap(map)) return bc; delete bc; return 0; } BuildConfiguration::BuildType AutotoolsBuildConfiguration::buildType() const { // TODO: Should I return something different from Unknown? return Unknown; }