/************************************************************************** ** ** Copyright (C) 2014 Openismus GmbH. ** Authors: Peter Penz (ppenz@openismus.com) ** Patricia Santana Cruz (patriciasantanacruz@gmail.com) ** Contact: http://www.qt-project.org/legal ** ** 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 Digia. For licensing terms and ** conditions see http://qt.digia.com/licensing. For further information ** use the contact form at http://qt.digia.com/contact-us. ** ** GNU Lesser General Public License Usage ** Alternatively, 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, Digia gives you certain additional ** rights. These rights are described in the Digia Qt LGPL Exception ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. ** ****************************************************************************/ #include "autogenstep.h" #include "autotoolsproject.h" #include "autotoolsbuildconfiguration.h" #include "autotoolsprojectconstants.h" #include #include #include #include #include #include #include #include #include #include #include using namespace AutotoolsProjectManager; using namespace AutotoolsProjectManager::Internal; using namespace ProjectExplorer; const char AUTOGEN_ADDITIONAL_ARGUMENTS_KEY[] = "AutotoolsProjectManager.AutogenStep.AdditionalArguments"; const char AUTOGEN_STEP_ID[] = "AutotoolsProjectManager.AutogenStep"; ///////////////////////////// // AutogenStepFactory class ///////////////////////////// AutogenStepFactory::AutogenStepFactory(QObject *parent) : IBuildStepFactory(parent) { } QList AutogenStepFactory::availableCreationIds(BuildStepList *parent) const { if (!canHandle(parent)) return QList(); return QList() << Core::Id(AUTOGEN_STEP_ID); } QString AutogenStepFactory::displayNameForId(const Core::Id id) const { if (id == AUTOGEN_STEP_ID) return tr("Autogen", "Display name for AutotoolsProjectManager::AutogenStep id."); return QString(); } bool AutogenStepFactory::canCreate(BuildStepList *parent, const Core::Id id) const { return canHandle(parent) && Core::Id(AUTOGEN_STEP_ID) == id; } BuildStep *AutogenStepFactory::create(BuildStepList *parent, const Core::Id id) { if (!canCreate(parent, id)) return 0; return new AutogenStep(parent); } bool AutogenStepFactory::canClone(BuildStepList *parent, BuildStep *source) const { return canCreate(parent, source->id()); } BuildStep *AutogenStepFactory::clone(BuildStepList *parent, BuildStep *source) { if (!canClone(parent, source)) return 0; return new AutogenStep(parent, static_cast(source)); } bool AutogenStepFactory::canRestore(BuildStepList *parent, const QVariantMap &map) const { return canCreate(parent, idFromMap(map)); } BuildStep *AutogenStepFactory::restore(BuildStepList *parent, const QVariantMap &map) { if (!canRestore(parent, map)) return 0; AutogenStep *bs = new AutogenStep(parent); if (bs->fromMap(map)) return bs; delete bs; return 0; } bool AutogenStepFactory::canHandle(BuildStepList *parent) const { if (parent->target()->project()->id() == Constants::AUTOTOOLS_PROJECT_ID) return parent->id() == ProjectExplorer::Constants::BUILDSTEPS_BUILD; return false; } //////////////////////// // AutogenStep class //////////////////////// AutogenStep::AutogenStep(BuildStepList *bsl) : AbstractProcessStep(bsl, Core::Id(AUTOGEN_STEP_ID)), m_runAutogen(false) { ctor(); } AutogenStep::AutogenStep(BuildStepList *bsl, const Core::Id id) : AbstractProcessStep(bsl, id) { ctor(); } AutogenStep::AutogenStep(BuildStepList *bsl, AutogenStep *bs) : AbstractProcessStep(bsl, bs), m_additionalArguments(bs->additionalArguments()) { ctor(); } void AutogenStep::ctor() { setDefaultDisplayName(tr("Autogen")); } bool AutogenStep::init() { BuildConfiguration *bc = buildConfiguration(); ProcessParameters *pp = processParameters(); pp->setMacroExpander(bc->macroExpander()); pp->setEnvironment(bc->environment()); pp->setWorkingDirectory(bc->buildDirectory().toString()); pp->setCommand(QLatin1String("autogen.sh")); pp->setArguments(additionalArguments()); pp->resolveAll(); return AbstractProcessStep::init(); } void AutogenStep::run(QFutureInterface &interface) { BuildConfiguration *bc = buildConfiguration(); // Check whether we need to run autogen.sh const QString buildDir = bc->buildDirectory().toString(); const QFileInfo configureInfo(buildDir + QLatin1String("/configure")); const QFileInfo configureAcInfo(buildDir + QLatin1String("/configure.ac")); const QFileInfo makefileAmInfo(buildDir + QLatin1String("/Makefile.am")); if (!configureInfo.exists() || configureInfo.lastModified() < configureAcInfo.lastModified() || configureInfo.lastModified() < makefileAmInfo.lastModified()) { m_runAutogen = true; } if (!m_runAutogen) { emit addOutput(tr("Configuration unchanged, skipping autogen step."), BuildStep::MessageOutput); interface.reportResult(true); emit finished(); return; } m_runAutogen = false; AbstractProcessStep::run(interface); } BuildStepConfigWidget *AutogenStep::createConfigWidget() { return new AutogenStepConfigWidget(this); } bool AutogenStep::immutable() const { return false; } void AutogenStep::setAdditionalArguments(const QString &list) { if (list == m_additionalArguments) return; m_additionalArguments = list; m_runAutogen = true; emit additionalArgumentsChanged(list); } QString AutogenStep::additionalArguments() const { return m_additionalArguments; } QVariantMap AutogenStep::toMap() const { QVariantMap map(AbstractProcessStep::toMap()); map.insert(QLatin1String(AUTOGEN_ADDITIONAL_ARGUMENTS_KEY), m_additionalArguments); return map; } bool AutogenStep::fromMap(const QVariantMap &map) { m_additionalArguments = map.value(QLatin1String(AUTOGEN_ADDITIONAL_ARGUMENTS_KEY)).toString(); return BuildStep::fromMap(map); } ////////////////////////////////// // AutogenStepConfigWidget class ////////////////////////////////// AutogenStepConfigWidget::AutogenStepConfigWidget(AutogenStep *autogenStep) : m_autogenStep(autogenStep), m_summaryText(), m_additionalArguments(0) { QFormLayout *fl = new QFormLayout(this); fl->setMargin(0); fl->setFieldGrowthPolicy(QFormLayout::ExpandingFieldsGrow); setLayout(fl); m_additionalArguments = new QLineEdit(this); fl->addRow(tr("Arguments:"), m_additionalArguments); m_additionalArguments->setText(m_autogenStep->additionalArguments()); updateDetails(); connect(m_additionalArguments, SIGNAL(textChanged(QString)), autogenStep, SLOT(setAdditionalArguments(QString))); connect(autogenStep, SIGNAL(additionalArgumentsChanged(QString)), this, SLOT(updateDetails())); } QString AutogenStepConfigWidget::displayName() const { return tr("Autogen", "AutotoolsProjectManager::AutogenStepConfigWidget display name."); } QString AutogenStepConfigWidget::summaryText() const { return m_summaryText; } void AutogenStepConfigWidget::updateDetails() { BuildConfiguration *bc = m_autogenStep->buildConfiguration(); ProcessParameters param; param.setMacroExpander(bc->macroExpander()); param.setEnvironment(bc->environment()); param.setWorkingDirectory(bc->buildDirectory().toString()); param.setCommand(QLatin1String("autogen.sh")); param.setArguments(m_autogenStep->additionalArguments()); m_summaryText = param.summary(displayName()); emit updateSummary(); }