1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
|
/*
SPDX-FileCopyrightText: 2012 Miha Čančula <miha@noughmad.eu>
SPDX-License-Identifier: LGPL-2.0-or-later
*/
#ifndef KDEVPLATFORM_PLUGIN_TEMPLATECLASSASSISTANT_H
#define KDEVPLATFORM_PLUGIN_TEMPLATECLASSASSISTANT_H
#include <KAssistantDialog>
#include <QUrl>
namespace KDevelop
{
/**
* @brief An assistant for creating new source code files using KTextTemplate templates.
*
* This assistant guides the user through generating source code from templates.
* Currently, class and unit test templates are supported.
*
* Depending on the selected template type (@c Class or @c Test, see SourceFileTemplate::type()),
* The assistant creates appropriate pages for setting the required options.
*
* When creating a new class, an ICreateClassHelper is used for the language-specific features.
* If no such helper exists for the chosen template, a generic implementation is used.
* The actual generation of classes is done using a TemplateClassGenerator.
**/
class TemplateClassAssistant : public KAssistantDialog
{
Q_OBJECT
public:
/**
* Creates a new assistant
*
* @param parent parent widget
* @param baseUrl the directory where the new class should be created
**/
explicit TemplateClassAssistant(QWidget* parent, const QUrl& baseUrl = QUrl());
/**
* Destroys the assistant
**/
~TemplateClassAssistant() override;
/**
* Sets up the template selection page
*/
void setup();
/**
* @return The url from where the assistant was started.
*
* If the assistant was started from the context menu of a project item,
* this function returns that item's URL. Otherwise, this returns an invalid URL.
*/
QUrl baseUrl() const;
/**
* Called when the user selected a template in the first page of the assistant.
*
* This function creates all the other pages, depending on the type of the selected template.
*
* @param templateDescription template description file of the selected template
*/
void templateChosen(const QString& templateDescription);
public Q_SLOTS:
void next() override;
void back() override;
void accept() override;
/**
* Sets whether the current page is valid or not.
* If the page is valid, the "Next" or "Finish" button will be displayed.
*
* @param valid true if the user-provided information on the current page is valid, false otherwise
*/
void setCurrentPageValid(bool valid);
private:
class TemplateClassAssistantPrivate* const d;
};
}
#endif // KDEVPLATFORM_PLUGIN_TEMPLATECLASSASSISTANT_H
|