Skip to content
Snippets Groups Projects
  • Tobias Hunger's avatar
    8d0c4772
    ToolChain: Refactor toolchain support · 8d0c4772
    Tobias Hunger authored
    Refactor ToolChains in Qt Creator:
    
     * Allow for several toolchains of the same type
     * Be smarter wrt. guessing what kind of output a toolchain
       produces. This allows us to eventually handle e.g. embedded
       linux setups way better than before.
     * Be smarter wrt. guessing what kind of environment a Qt version
       needs.
     * Improve auto-detection of toolchains a bit
     * Decide on which debugger to use based on the kind of output
       produced by the compiler.
     * Add options page to configure toolchains
     * Remove toolchain related options from the Qt version dialog
    
    Reviewed-by: dt
    8d0c4772
    History
    ToolChain: Refactor toolchain support
    Tobias Hunger authored
    Refactor ToolChains in Qt Creator:
    
     * Allow for several toolchains of the same type
     * Be smarter wrt. guessing what kind of output a toolchain
       produces. This allows us to eventually handle e.g. embedded
       linux setups way better than before.
     * Be smarter wrt. guessing what kind of environment a Qt version
       needs.
     * Improve auto-detection of toolchains a bit
     * Decide on which debugger to use based on the kind of output
       produced by the compiler.
     * Add options page to configure toolchains
     * Remove toolchain related options from the Qt version dialog
    
    Reviewed-by: dt
buildconfiguration.h 5.09 KiB
/**************************************************************************
**
** This file is part of Qt Creator
**
** Copyright (c) 2011 Nokia Corporation and/or its subsidiary(-ies).
**
** Contact: Nokia Corporation (qt-info@nokia.com)
**
** No Commercial Usage
**
** This file contains pre-release code and may not be distributed.
** You may use this file in accordance with the terms and conditions
** contained in the Technology Preview License Agreement accompanying
** this package.
**
** 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, 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.
**
** If you have questions regarding the use of this file, please contact
** Nokia at qt-info@nokia.com.
**
**************************************************************************/

#ifndef BUILDCONFIGURATION_H
#define BUILDCONFIGURATION_H

#include "projectexplorer_export.h"
#include "projectconfiguration.h"

#include <utils/stringutils.h>
#include <utils/environment.h>

#include <QtCore/QString>
#include <QtCore/QStringList>

namespace ProjectExplorer {

class BuildConfiguration;
class BuildStepList;
class Target;
class ToolChain;
class IOutputParser;

class BuildConfigMacroExpander : public Utils::AbstractQtcMacroExpander {
public:
    BuildConfigMacroExpander(BuildConfiguration *bc) : m_bc(bc) {}
    virtual bool resolveMacro(const QString &name, QString *ret);
private:
    BuildConfiguration *m_bc;
};

class PROJECTEXPLORER_EXPORT BuildConfiguration : public ProjectConfiguration
{
    Q_OBJECT

public:
    // ctors are protected
    virtual ~BuildConfiguration();

    virtual QString buildDirectory() const = 0;

    // TODO: Maybe the BuildConfiguration is not the best place for the environment
    virtual Utils::Environment baseEnvironment() const;
    QString baseEnvironmentText() const;
    Utils::Environment environment() const;
    void setUserEnvironmentChanges(const QList<Utils::EnvironmentItem> &diff);
    QList<Utils::EnvironmentItem> userEnvironmentChanges() const;
    bool useSystemEnvironment() const;
    void setUseSystemEnvironment(bool b);

    QStringList knownStepLists() const;
    BuildStepList *stepList(const QString &id) const;

    virtual QVariantMap toMap() const;

    // Creates a suitable outputparser for custom build steps
    // (based on the toolchain)
    // TODO this is not great API
    // it's mainly so that custom build systems are better integrated
    // with the generic project manager
    virtual IOutputParser *createOutputParser() const = 0;

    Target *target() const;

    virtual bool isEnabled() const;

    Utils::AbstractMacroExpander *macroExpander() { return &m_macroExpander; }

    virtual ProjectExplorer::ToolChain *toolChain() const;
    virtual void setToolChain(ProjectExplorer::ToolChain *tc);

signals:
    void environmentChanged();
    void buildDirectoryChanged();
    void enabledChanged();
    void toolChainChanged();

protected:
    BuildConfiguration(Target *target, const QString &id);
    BuildConfiguration(Target *target, BuildConfiguration *source);

    void cloneSteps(BuildConfiguration *source);

    virtual bool fromMap(const QVariantMap &map);

private:
    bool m_clearSystemEnvironment;
    QList<Utils::EnvironmentItem> m_userEnvironmentChanges;
    QList<BuildStepList *> m_stepLists;
    BuildConfigMacroExpander m_macroExpander;
    ToolChain *m_toolChain;
};

class PROJECTEXPLORER_EXPORT IBuildConfigurationFactory :
    public QObject
{
    Q_OBJECT

public:
    explicit IBuildConfigurationFactory(QObject *parent = 0);
    virtual ~IBuildConfigurationFactory();

    // used to show the list of possible additons to a target, returns a list of types
    virtual QStringList availableCreationIds(Target *parent) const = 0;
    // used to translate the types to names to display to the user
    virtual QString displayNameForId(const QString &id) const = 0;

    virtual bool canCreate(Target *parent, const QString &id) const = 0;
    virtual BuildConfiguration *create(Target *parent, const QString &id) = 0;
    // used to recreate the runConfigurations when restoring settings
    virtual bool canRestore(Target *parent, const QVariantMap &map) const = 0;
    virtual BuildConfiguration *restore(Target *parent, const QVariantMap &map) = 0;
    virtual bool canClone(Target *parent, BuildConfiguration *product) const = 0;
    virtual BuildConfiguration *clone(Target *parent, BuildConfiguration *product) = 0;

signals:
    void availableCreationIdsChanged();
};

} // namespace ProjectExplorer

Q_DECLARE_METATYPE(ProjectExplorer::BuildConfiguration *)

#endif // BUILDCONFIGURATION_H