forked from qt-creator/qt-creator
pluginhowto: update example code
Still not fully compilable
This commit is contained in:
@@ -39,32 +39,27 @@
|
||||
#include "modelclasswizard.h"
|
||||
#include "modelnamepage.h"
|
||||
|
||||
#include <QFile>
|
||||
#include <QFileInfo>
|
||||
#include <cppeditor/cppeditor.h>
|
||||
#include <cppeditor/cppeditorconstants.h>
|
||||
#include <coreplugin/basefilewizard.h>
|
||||
|
||||
ModelClassWizard::ModelClassWizard(const Core::BaseFileWizardParameters ¶meters,QObject *parent)
|
||||
: Core::BaseFileWizard(parameters, parent)
|
||||
#include <QFile>
|
||||
#include <QFileInfo>
|
||||
|
||||
ModelClassWizard::ModelClassWizard(const Core::BaseFileWizardParameters ¶meters, QObject *parent)
|
||||
: Core::BaseFileWizard(parameters, parent)
|
||||
{
|
||||
}
|
||||
|
||||
ModelClassWizard::~ModelClassWizard()
|
||||
{
|
||||
}
|
||||
|
||||
QWizard * ModelClassWizard::createWizardDialog(
|
||||
QWidget *parent,
|
||||
const QString &defaultPath,
|
||||
const WizardPageList &extensionPages) const
|
||||
QWizard *ModelClassWizard::createWizardDialog(QWidget *parent,
|
||||
const QString &defaultPath, const WizardPageList &extensionPages) const
|
||||
{
|
||||
// Create a wizard
|
||||
QWizard* wizard = new QWizard(parent);
|
||||
wizard->setWindowTitle("Model Class Wizard");
|
||||
QWizard *wizard = new QWizard(parent);
|
||||
wizard->setWindowTitle(tr("Model Class Wizard"));
|
||||
|
||||
// Make our page as first page
|
||||
ModelNamePage* page = new ModelNamePage(wizard);
|
||||
ModelNamePage *page = new ModelNamePage(wizard);
|
||||
int pageId = wizard->addPage(page);
|
||||
wizard->setProperty("_PageId_", pageId);
|
||||
page->setPath(defaultPath);
|
||||
@@ -75,32 +70,29 @@ QWizard * ModelClassWizard::createWizardDialog(
|
||||
return wizard;
|
||||
}
|
||||
|
||||
QString ModelClassWizard::readFile(const QString& fileName, const QMap<QString,QString>&
|
||||
replacementMap) const
|
||||
QString ModelClassWizard::readFile(const QString& fileName,
|
||||
const QMap<QString,QString> & replacementMap) const
|
||||
{
|
||||
QFile file(fileName);
|
||||
file.open(QFile::ReadOnly);
|
||||
QString retStr = file.readAll();
|
||||
QString result = file.readAll();
|
||||
QMap<QString,QString>::const_iterator it = replacementMap.begin();
|
||||
QMap<QString,QString>::const_iterator end = replacementMap.end();
|
||||
|
||||
while(it != end)
|
||||
{
|
||||
retStr.replace(it.key(), it.value());
|
||||
++it;
|
||||
}
|
||||
return retStr;
|
||||
for (; it != end; ++it)
|
||||
result.replace(it.key(), it.value());
|
||||
return result;
|
||||
}
|
||||
|
||||
Core::GeneratedFiles ModelClassWizard::generateFiles(
|
||||
const QWizard *w,QString *errorMessage) const
|
||||
Core::GeneratedFiles ModelClassWizard::generateFiles
|
||||
(const QWizard *wizard, QString *errorMessage) const
|
||||
{
|
||||
Q_UNUSED(errorMessage);
|
||||
Core::GeneratedFiles ret;
|
||||
int pageId = w->property("_PageId_").toInt();
|
||||
ModelNamePage* page = qobject_cast<ModelNamePage*>(w->page(pageId));
|
||||
int pageId = wizard->property("_PageId_").toInt();
|
||||
ModelNamePage *page = qobject_cast<ModelNamePage*>(wizard->page(pageId));
|
||||
|
||||
if(!page)
|
||||
if (!page)
|
||||
return ret;
|
||||
ModelClassParameters params = page->parameters();
|
||||
QMap<QString,QString> replacementMap;
|
||||
@@ -110,28 +102,25 @@ Core::GeneratedFiles ModelClassWizard::generateFiles(
|
||||
replacementMap["{{CLASS_NAME}}"] = params.className;
|
||||
replacementMap["{{CLASS_HEADER}}"] = QFileInfo(params.headerFile).fileName();
|
||||
|
||||
Core::GeneratedFile headerFile(params.path + "/" + params.headerFile);
|
||||
Core::GeneratedFile headerFile(params.path + '/' + params.headerFile);
|
||||
headerFile.setEditorKind(CppEditor::Constants::CPPEDITOR_KIND);
|
||||
|
||||
Core::GeneratedFile sourceFile(params.path + "/" + params.sourceFile);
|
||||
Core::GeneratedFile sourceFile(params.path + '/' + params.sourceFile);
|
||||
sourceFile.setEditorKind(CppEditor::Constants::CPPEDITOR_KIND);
|
||||
|
||||
if(params.baseClass == "QAbstractItemModel")
|
||||
{
|
||||
headerFile.setContents(readFile(":/CustomProject/ItemModelHeader", replacementMap) );
|
||||
sourceFile.setContents(readFile(":/CustomProject/ItemModelSource", replacementMap) );
|
||||
if (params.baseClass == "QAbstractItemModel") {
|
||||
headerFile.setContents(readFile(":/CustomProject/ItemModelHeader", replacementMap));
|
||||
sourceFile.setContents(readFile(":/CustomProject/ItemModelSource", replacementMap));
|
||||
}
|
||||
|
||||
else if(params.baseClass == "QAbstractTableModel")
|
||||
{
|
||||
headerFile.setContents(readFile(":/CustomProject/TableModelHeader", replacementMap) );
|
||||
sourceFile.setContents(readFile(":/CustomProject/TableModelSource", replacementMap) );
|
||||
else if (params.baseClass == "QAbstractTableModel") {
|
||||
headerFile.setContents(readFile(":/CustomProject/TableModelHeader", replacementMap));
|
||||
sourceFile.setContents(readFile(":/CustomProject/TableModelSource", replacementMap));
|
||||
}
|
||||
|
||||
else if(params.baseClass == "QAbstractListModel")
|
||||
{
|
||||
headerFile.setContents(readFile(":/CustomProject/ListModelHeader", replacementMap) );
|
||||
sourceFile.setContents(readFile(":/CustomProject/ListModelSource", replacementMap) );
|
||||
else if (params.baseClass == "QAbstractListModel") {
|
||||
headerFile.setContents(readFile(":/CustomProject/ListModelHeader", replacementMap));
|
||||
sourceFile.setContents(readFile(":/CustomProject/ListModelSource", replacementMap));
|
||||
}
|
||||
|
||||
ret << headerFile << sourceFile;
|
||||
|
||||
Reference in New Issue
Block a user