forked from qt-creator/qt-creator
Imrpvoed the importer.
This commit is contained in:
@@ -1,25 +1,202 @@
|
||||
#include "genericprojectwizard.h"
|
||||
|
||||
#include <coreplugin/icore.h>
|
||||
#include <coreplugin/mimedatabase.h>
|
||||
#include <projectexplorer/projectexplorer.h>
|
||||
|
||||
#include <utils/pathchooser.h>
|
||||
|
||||
#include <QtGui/QWizard>
|
||||
#include <QtGui/QFormLayout>
|
||||
#include <QtCore/QDir>
|
||||
#include <QtCore/QtDebug>
|
||||
|
||||
#include <QtGui/QWizard>
|
||||
#include <QtGui/QFormLayout>
|
||||
#include <QtGui/QListView>
|
||||
#include <QtGui/QTreeView>
|
||||
#include <QtGui/QDirModel>
|
||||
|
||||
using namespace GenericProjectManager::Internal;
|
||||
using namespace Core::Utils;
|
||||
|
||||
GenericProjectWizard::GenericProjectWizard()
|
||||
: Core::BaseFileWizard(parameters())
|
||||
namespace {
|
||||
|
||||
class DirModel: public QDirModel
|
||||
{
|
||||
public:
|
||||
DirModel(QObject *parent)
|
||||
: QDirModel(parent)
|
||||
{ setFilter(QDir::Dirs | QDir::NoDotAndDotDot); }
|
||||
|
||||
virtual ~DirModel()
|
||||
{ }
|
||||
|
||||
public:
|
||||
virtual int columnCount(const QModelIndex &) const
|
||||
{ return 1; }
|
||||
|
||||
virtual Qt::ItemFlags flags(const QModelIndex &index) const
|
||||
{ return QDirModel::flags(index) | Qt::ItemIsUserCheckable; }
|
||||
|
||||
virtual QVariant data(const QModelIndex &index, int role) const
|
||||
{
|
||||
if (index.column() == 0 && role == Qt::CheckStateRole) {
|
||||
if (_selectedPaths.contains(index))
|
||||
return Qt::Checked;
|
||||
|
||||
return Qt::Unchecked;
|
||||
}
|
||||
|
||||
return QDirModel::data(index, role);
|
||||
}
|
||||
|
||||
virtual bool setData(const QModelIndex &index, const QVariant &value, int role)
|
||||
{
|
||||
if (index.column() == 0 && role == Qt::CheckStateRole) {
|
||||
if (value.toBool())
|
||||
_selectedPaths.insert(index);
|
||||
else
|
||||
_selectedPaths.remove(index);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
return QDirModel::setData(index, value, role);
|
||||
}
|
||||
|
||||
void clearSelectedPaths()
|
||||
{ _selectedPaths.clear(); }
|
||||
|
||||
QSet<QString> selectedPaths() const
|
||||
{
|
||||
QSet<QString> paths;
|
||||
|
||||
foreach (const QModelIndex &index, _selectedPaths)
|
||||
paths.insert(filePath(index));
|
||||
|
||||
return paths;
|
||||
}
|
||||
|
||||
private:
|
||||
QSet<QModelIndex> _selectedPaths;
|
||||
};
|
||||
|
||||
} // end of anonymous namespace
|
||||
|
||||
|
||||
//////////////////////////////////////////////////////////////////////////////
|
||||
// GenericProjectWizardDialog
|
||||
//////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
GenericProjectWizardDialog::GenericProjectWizardDialog(QWidget *parent)
|
||||
: QWizard(parent)
|
||||
{
|
||||
setWindowTitle(tr("Import Existing Project"));
|
||||
|
||||
// first page
|
||||
QWizardPage *firstPage = new QWizardPage;
|
||||
firstPage->setTitle(tr("Project"));
|
||||
|
||||
QFormLayout *layout = new QFormLayout(firstPage);
|
||||
_pathChooser = new PathChooser;
|
||||
layout->addRow(tr("Source Directory:"), _pathChooser);
|
||||
|
||||
_firstPageId = addPage(firstPage);
|
||||
|
||||
#if 0
|
||||
// second page
|
||||
QWizardPage *secondPage = new QWizardPage;
|
||||
secondPage->setTitle(tr("Second Page Title"));
|
||||
|
||||
QFormLayout *secondPageLayout = new QFormLayout(secondPage);
|
||||
|
||||
_dirView = new QTreeView;
|
||||
_dirModel = new DirModel(this);
|
||||
_dirView->setModel(_dirModel);
|
||||
|
||||
Core::ICore *core = Core::ICore::instance();
|
||||
Core::MimeDatabase *mimeDatabase = core->mimeDatabase();
|
||||
|
||||
const QStringList suffixes = mimeDatabase->suffixes();
|
||||
|
||||
QStringList nameFilters;
|
||||
foreach (const QString &suffix, suffixes) {
|
||||
QString nameFilter;
|
||||
nameFilter.append(QLatin1String("*."));
|
||||
nameFilter.append(suffix);
|
||||
nameFilters.append(nameFilter);
|
||||
}
|
||||
|
||||
_filesView = new QListView;
|
||||
_filesModel = new QDirModel(this);
|
||||
_filesModel->setNameFilters(nameFilters);
|
||||
_filesModel->setFilter(QDir::Files);
|
||||
|
||||
connect(_dirView->selectionModel(), SIGNAL(currentChanged(QModelIndex,QModelIndex)),
|
||||
this, SLOT(updateFilesView(QModelIndex,QModelIndex)));
|
||||
|
||||
secondPageLayout->addRow(_dirView);
|
||||
secondPageLayout->addRow(_filesView);
|
||||
|
||||
_secondPageId = addPage(secondPage);
|
||||
#endif
|
||||
}
|
||||
|
||||
GenericProjectWizard::~GenericProjectWizard()
|
||||
GenericProjectWizardDialog::~GenericProjectWizardDialog()
|
||||
{ }
|
||||
|
||||
QString GenericProjectWizardDialog::path() const
|
||||
{ return _pathChooser->path(); }
|
||||
|
||||
void GenericProjectWizardDialog::updateFilesView(const QModelIndex ¤t,
|
||||
const QModelIndex &)
|
||||
{
|
||||
if (! current.isValid())
|
||||
_filesView->setModel(0);
|
||||
|
||||
else {
|
||||
const QString selectedPath = _dirModel->filePath(current);
|
||||
|
||||
if (! _filesView->model())
|
||||
_filesView->setModel(_filesModel);
|
||||
|
||||
_filesView->setRootIndex(_filesModel->index(selectedPath));
|
||||
}
|
||||
}
|
||||
|
||||
void GenericProjectWizardDialog::initializePage(int id)
|
||||
{
|
||||
if (id == _secondPageId) {
|
||||
using namespace Core::Utils;
|
||||
|
||||
const QString projectPath = _pathChooser->path();
|
||||
|
||||
QDirModel *dirModel = qobject_cast<QDirModel *>(_dirView->model());
|
||||
_dirView->setRootIndex(dirModel->index(projectPath));
|
||||
}
|
||||
}
|
||||
|
||||
bool GenericProjectWizardDialog::validateCurrentPage()
|
||||
{
|
||||
using namespace Core::Utils;
|
||||
|
||||
if (currentId() == _firstPageId) {
|
||||
return ! _pathChooser->path().isEmpty();
|
||||
|
||||
} else if (currentId() == _secondPageId) {
|
||||
return true;
|
||||
}
|
||||
|
||||
return QWizard::validateCurrentPage();
|
||||
}
|
||||
|
||||
GenericProjectWizard::GenericProjectWizard()
|
||||
: Core::BaseFileWizard(parameters())
|
||||
{ }
|
||||
|
||||
GenericProjectWizard::~GenericProjectWizard()
|
||||
{ }
|
||||
|
||||
Core::BaseFileWizardParameters GenericProjectWizard::parameters()
|
||||
{
|
||||
static Core::BaseFileWizardParameters parameters(ProjectWizard);
|
||||
@@ -35,42 +212,94 @@ QWizard *GenericProjectWizard::createWizardDialog(QWidget *parent,
|
||||
const QString &defaultPath,
|
||||
const WizardPageList &extensionPages) const
|
||||
{
|
||||
QWizard *wizard = new QWizard(parent);
|
||||
wizard->setWindowTitle(tr("Import Existing Project"));
|
||||
GenericProjectWizardDialog *wizard = new GenericProjectWizardDialog(parent);
|
||||
setupWizard(wizard);
|
||||
|
||||
QWizardPage *firstPage = new QWizardPage;
|
||||
firstPage->setTitle(tr("Project"));
|
||||
|
||||
QFormLayout *layout = new QFormLayout(firstPage);
|
||||
|
||||
PathChooser *pathChooser = new PathChooser;
|
||||
pathChooser->setObjectName("pathChooser");
|
||||
layout->addRow(tr("Source Directory:"), pathChooser);
|
||||
|
||||
wizard->addPage(firstPage);
|
||||
|
||||
foreach (QWizardPage *p, extensionPages)
|
||||
wizard->addPage(p);
|
||||
|
||||
return wizard;
|
||||
}
|
||||
|
||||
void GenericProjectWizard::getFileList(const QDir &dir, const QString &projectRoot,
|
||||
const QStringList &suffixes,
|
||||
QStringList *files, QStringList *paths) const
|
||||
{
|
||||
const QFileInfoList fileInfoList = dir.entryInfoList(QDir::Files |
|
||||
QDir::Dirs |
|
||||
QDir::NoDotAndDotDot |
|
||||
QDir::NoSymLinks);
|
||||
|
||||
foreach (const QFileInfo &fileInfo, fileInfoList) {
|
||||
QString filePath = fileInfo.absoluteFilePath();
|
||||
filePath = filePath.mid(projectRoot.length() + 1);
|
||||
|
||||
if (fileInfo.isDir() && isValidDir(fileInfo)) {
|
||||
getFileList(QDir(fileInfo.absoluteFilePath()), projectRoot,
|
||||
suffixes, files, paths);
|
||||
|
||||
if (! paths->contains(filePath))
|
||||
paths->append(filePath);
|
||||
}
|
||||
|
||||
else if (suffixes.contains(fileInfo.suffix()))
|
||||
files->append(filePath);
|
||||
}
|
||||
}
|
||||
|
||||
bool GenericProjectWizard::isValidDir(const QFileInfo &fileInfo) const
|
||||
{
|
||||
const QString fileName = fileInfo.fileName();
|
||||
const QString suffix = fileInfo.suffix();
|
||||
|
||||
if (fileName.startsWith(QLatin1Char('.')))
|
||||
return false;
|
||||
|
||||
else if (fileName == QLatin1String("CVS"))
|
||||
return false;
|
||||
|
||||
// ### user include/exclude
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
Core::GeneratedFiles GenericProjectWizard::generateFiles(const QWizard *w,
|
||||
QString *errorMessage) const
|
||||
{
|
||||
PathChooser *pathChooser = w->findChild<PathChooser *>("pathChooser");
|
||||
const QString projectName = QFileInfo(pathChooser->path()).baseName() + QLatin1String(".creator");
|
||||
const QDir dir(pathChooser->path());
|
||||
const GenericProjectWizardDialog *wizard = qobject_cast<const GenericProjectWizardDialog *>(w);
|
||||
const QString projectPath = wizard->path();
|
||||
const QString projectName = QFileInfo(projectPath).baseName() + QLatin1String(".creator");
|
||||
const QDir dir(projectPath);
|
||||
|
||||
// ### FIXME: use the mimetype database.
|
||||
// ### FIXME: import nested folders.
|
||||
const QStringList sources = dir.entryList(QStringList() << "Makefile" << "*.c" << "*.cpp" << "*.h", QDir::Files);
|
||||
Core::ICore *core = Core::ICore::instance();
|
||||
Core::MimeDatabase *mimeDatabase = core->mimeDatabase();
|
||||
|
||||
const QStringList suffixes = mimeDatabase->suffixes();
|
||||
|
||||
QStringList sources, paths;
|
||||
getFileList(dir, projectPath, suffixes, &sources, &paths);
|
||||
|
||||
Core::MimeType headerTy = mimeDatabase->findByType(QLatin1String("text/x-chdr"));
|
||||
|
||||
QStringList nameFilters;
|
||||
foreach (const QRegExp &rx, headerTy.globPatterns())
|
||||
nameFilters.append(rx.pattern());
|
||||
|
||||
QStringList includePaths;
|
||||
foreach (const QString &path, paths) {
|
||||
QFileInfo fileInfo(dir, path);
|
||||
QDir thisDir(fileInfo.absoluteFilePath());
|
||||
|
||||
if (! thisDir.entryList(nameFilters, QDir::Files).isEmpty())
|
||||
includePaths.append(path);
|
||||
}
|
||||
|
||||
QString projectContents;
|
||||
QTextStream stream(&projectContents);
|
||||
stream << "files=" << sources.join(",");
|
||||
stream << endl;
|
||||
stream << "includePaths=" << includePaths.join(",");
|
||||
stream << endl;
|
||||
|
||||
Core::GeneratedFile file(QFileInfo(dir, projectName).absoluteFilePath()); // ### fixme
|
||||
file.setContents(projectContents);
|
||||
|
||||
Reference in New Issue
Block a user