**
** This file is part of Qt Creator
**
-** Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
+** Copyright (c) 2011 Nokia Corporation and/or its subsidiary(-ies).
**
-** Contact: Nokia Corporation (qt-info@nokia.com)
+** Contact: Nokia Corporation (info@qt.nokia.com)
**
-** Commercial Usage
-**
-** Licensees holding valid Qt Commercial licenses may use this file in
-** accordance with the Qt Commercial License Agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and Nokia.
**
** 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.
+** 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 are unsure which license is appropriate for your use, please
-** contact the sales department at http://qt.nokia.com/contact.
+** If you have questions regarding the use of this file, please contact
+** Nokia at info@qt.nokia.com.
**
**************************************************************************/
#include "projectconfiguration.h"
#include "projectexplorer_export.h"
-#include "taskwindow.h"
#include <QtCore/QFutureInterface>
#include <QtGui/QWidget>
namespace ProjectExplorer {
-
-enum StepType { Build = 0,
- Clean = 1,
- LastStepType = 2};
-
+class Task;
class BuildConfiguration;
-
-/*
-// BuildSteps are the primary way plugin developers can customize
-// how their projects (or projects from other plugins) are build.
-//
-// Building a project, is done by taking the list of buildsteps
-// from the project and calling first init() than run() on them.
-//
-// That means to change the way your project is build, reimplemnt
-// this class and add your Step to the buildStep list of the project.
-//
-// Note: The projects own the buildstep, do not delete them yourself.
-//
-// init() is called in the GUI thread and can be used to query the
-// project for any information you need.
-//
-// run() is run via QtConccurrent in a own thread, if you need an
-// eventloop you need to create it yourself!
-//
-// You can use setValue() to store settings which a specific
-// to your buildstep. (You can set settings to apply only
-// to one buildconfiguration.
-// And later retrieve the same information with value()
-
-*/
+class BuildStepList;
+class DeployConfiguration;
+class Target;
class BuildStepConfigWidget;
+// Documentation inside.
class PROJECTEXPLORER_EXPORT BuildStep : public ProjectConfiguration
{
Q_OBJECT
protected:
- BuildStep(BuildConfiguration *bc, const QString &id);
- BuildStep(BuildConfiguration *bc, BuildStep *bs);
+ BuildStep(BuildStepList *bsl, const QString &id);
+ BuildStep(BuildStepList *bsl, BuildStep *bs);
public:
virtual ~BuildStep();
- // This function is run in the gui thread,
- // use it to retrieve any information that you need in run()
virtual bool init() = 0;
- // Reimplement this. This function is called when the target is build.
- // This function is NOT run in the gui thread. It runs in its own thread
- // If you need an event loop, you need to create one.
- // The absolute minimal implementation is:
- // fi.reportResult(true);
virtual void run(QFutureInterface<bool> &fi) = 0;
- // the Widget shown in the target settings dialog for this buildStep
- // ownership is transferred to the caller
virtual BuildStepConfigWidget *createConfigWidget() = 0;
- // if this function returns true, the user can't delete this BuildStep for this target
- // and the user is prevented from changing the order immutable steps are run
- // the default implementation returns false
virtual bool immutable() const;
+ virtual bool runInGuiThread() const;
+ virtual void cancel();
BuildConfiguration *buildConfiguration() const;
+ DeployConfiguration *deployConfiguration() const;
+ Target *target() const;
+ enum OutputFormat { NormalOutput, ErrorOutput, MessageOutput, ErrorMessageOutput };
+ enum OutputNewlineSetting { DoAppendNewline, DontAppendNewline };
+
+ Project *project() const;
signals:
- // Add a task.
void addTask(const ProjectExplorer::Task &task);
- // The string is added to the generated output, usually in the output
- // window.
- // It should be in html format, that is properly escaped
- void addOutput(const QString &string);
-private:
- BuildConfiguration *m_buildConfiguration;
+ void addOutput(const QString &string, ProjectExplorer::BuildStep::OutputFormat format,
+ ProjectExplorer::BuildStep::OutputNewlineSetting newlineSetting = DoAppendNewline) const;
+
+ void finished();
};
class PROJECTEXPLORER_EXPORT IBuildStepFactory :
virtual ~IBuildStepFactory();
// used to show the list of possible additons to a target, returns a list of types
- virtual QStringList availableCreationIds(BuildConfiguration *parent, StepType type) const = 0;
+ virtual QStringList availableCreationIds(BuildStepList *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(BuildConfiguration *parent, StepType type, const QString &id) const = 0;
- virtual BuildStep *create(BuildConfiguration *parent, StepType type, const QString &id) = 0;
+ virtual bool canCreate(BuildStepList *parent, const QString &id) const = 0;
+ virtual BuildStep *create(BuildStepList *parent, const QString &id) = 0;
// used to recreate the runConfigurations when restoring settings
- virtual bool canRestore(BuildConfiguration *parent, StepType type, const QVariantMap &map) const = 0;
- virtual BuildStep *restore(BuildConfiguration *parent, StepType type, const QVariantMap &map) = 0;
- virtual bool canClone(BuildConfiguration *parent, StepType type, BuildStep *product) const = 0;
- virtual BuildStep *clone(BuildConfiguration *parent, StepType type, BuildStep *product) = 0;
+ virtual bool canRestore(BuildStepList *parent, const QVariantMap &map) const = 0;
+ virtual BuildStep *restore(BuildStepList *parent, const QVariantMap &map) = 0;
+ virtual bool canClone(BuildStepList *parent, BuildStep *product) const = 0;
+ virtual BuildStep *clone(BuildStepList *parent, BuildStep *product) = 0;
};
class PROJECTEXPLORER_EXPORT BuildConfigWidget
// This is called to set up the config widget before showing it
virtual void init(BuildConfiguration *bc) = 0;
+
+signals:
+ void displayNameChanged(const QString &);
};
class PROJECTEXPLORER_EXPORT BuildStepConfigWidget
BuildStepConfigWidget()
: QWidget()
{}
- virtual void init() = 0;
virtual QString summaryText() const = 0;
+ virtual QString additionalSummaryText() const { return QString(); }
virtual QString displayName() const = 0;
+
signals:
void updateSummary();
+ void updateAdditionalSummary();
};
} // namespace ProjectExplorer
+Q_DECLARE_METATYPE(ProjectExplorer::BuildStep::OutputFormat)
+Q_DECLARE_METATYPE(ProjectExplorer::BuildStep::OutputNewlineSetting)
+
#endif // BUILDSTEP_H