GenericProject: Cleanup and modernize

* Use nullptr instead 0
* Remove QLatin1{String|Char} where possible
* Use C++11 list init and auto
* Add some const as drive-by-change

Change-Id: Ife4c9c7b0869bcf2c864b88b8061ac6b7c3f33c0
Reviewed-by: Orgad Shaneh <orgads@gmail.com>
This commit is contained in:
Andre Hartmann
2016-12-25 17:59:17 +01:00
committed by André Hartmann
parent c2d25982a1
commit 70556e8495
9 changed files with 75 additions and 75 deletions

View File

@@ -41,7 +41,7 @@ class FilesSelectionWizardPage : public QWizardPage
Q_OBJECT Q_OBJECT
public: public:
FilesSelectionWizardPage(GenericProjectWizardDialog *genericProjectWizard, QWidget *parent = 0); FilesSelectionWizardPage(GenericProjectWizardDialog *genericProjectWizard, QWidget *parent = nullptr);
bool isComplete() const override; bool isComplete() const override;
void initializePage() override; void initializePage() override;
void cleanupPage() override; void cleanupPage() override;

View File

@@ -118,7 +118,7 @@ BuildConfiguration *GenericBuildConfigurationFactory::create(Target *parent, con
QTC_ASSERT(info->kitId == parent->kit()->id(), return 0); QTC_ASSERT(info->kitId == parent->kit()->id(), return 0);
QTC_ASSERT(!info->displayName.isEmpty(), return 0); QTC_ASSERT(!info->displayName.isEmpty(), return 0);
GenericBuildConfiguration *bc = new GenericBuildConfiguration(parent); auto bc = new GenericBuildConfiguration(parent);
bc->setDisplayName(info->displayName); bc->setDisplayName(info->displayName);
bc->setDefaultDisplayName(info->displayName); bc->setDefaultDisplayName(info->displayName);
bc->setBuildDirectory(info->buildDirectory); bc->setBuildDirectory(info->buildDirectory);
@@ -127,14 +127,14 @@ BuildConfiguration *GenericBuildConfigurationFactory::create(Target *parent, con
BuildStepList *cleanSteps = bc->stepList(ProjectExplorer::Constants::BUILDSTEPS_CLEAN); BuildStepList *cleanSteps = bc->stepList(ProjectExplorer::Constants::BUILDSTEPS_CLEAN);
Q_ASSERT(buildSteps); Q_ASSERT(buildSteps);
GenericMakeStep *makeStep = new GenericMakeStep(buildSteps); auto makeStep = new GenericMakeStep(buildSteps);
buildSteps->insertStep(0, makeStep); buildSteps->insertStep(0, makeStep);
makeStep->setBuildTarget(QLatin1String("all"), /* on = */ true); makeStep->setBuildTarget("all", /* on = */ true);
Q_ASSERT(cleanSteps); Q_ASSERT(cleanSteps);
GenericMakeStep *cleanMakeStep = new GenericMakeStep(cleanSteps); auto cleanMakeStep = new GenericMakeStep(cleanSteps);
cleanSteps->insertStep(0, cleanMakeStep); cleanSteps->insertStep(0, cleanMakeStep);
cleanMakeStep->setBuildTarget(QLatin1String("clean"), /* on = */ true); cleanMakeStep->setBuildTarget("clean", /* on = */ true);
cleanMakeStep->setClean(true); cleanMakeStep->setClean(true);
return bc; return bc;
@@ -165,7 +165,7 @@ BuildConfiguration *GenericBuildConfigurationFactory::restore(Target *parent, co
{ {
if (!canRestore(parent, map)) if (!canRestore(parent, map))
return 0; return 0;
GenericBuildConfiguration *bc(new GenericBuildConfiguration(parent)); auto bc = new GenericBuildConfiguration(parent);
if (bc->fromMap(map)) if (bc->fromMap(map))
return bc; return bc;
delete bc; delete bc;
@@ -182,7 +182,7 @@ bool GenericBuildConfigurationFactory::canHandle(const Target *t) const
BuildInfo *GenericBuildConfigurationFactory::createBuildInfo(const Kit *k, BuildInfo *GenericBuildConfigurationFactory::createBuildInfo(const Kit *k,
const Utils::FileName &buildDir) const const Utils::FileName &buildDir) const
{ {
BuildInfo *info = new BuildInfo(this); auto info = new BuildInfo(this);
info->typeName = tr("Build"); info->typeName = tr("Build");
info->buildDirectory = buildDir; info->buildDirectory = buildDir;
info->kitId = k->id(); info->kitId = k->id();
@@ -201,13 +201,13 @@ BuildConfiguration::BuildType GenericBuildConfiguration::buildType() const
GenericBuildSettingsWidget::GenericBuildSettingsWidget(GenericBuildConfiguration *bc) GenericBuildSettingsWidget::GenericBuildSettingsWidget(GenericBuildConfiguration *bc)
: m_buildConfiguration(0) : m_buildConfiguration(0)
{ {
QFormLayout *fl = new QFormLayout(this); auto fl = new QFormLayout(this);
fl->setContentsMargins(0, -1, 0, -1); fl->setContentsMargins(0, -1, 0, -1);
fl->setFieldGrowthPolicy(QFormLayout::ExpandingFieldsGrow); fl->setFieldGrowthPolicy(QFormLayout::ExpandingFieldsGrow);
// build directory // build directory
m_pathChooser = new Utils::PathChooser(this); m_pathChooser = new Utils::PathChooser(this);
m_pathChooser->setHistoryCompleter(QLatin1String("Generic.BuildDir.History")); m_pathChooser->setHistoryCompleter("Generic.BuildDir.History");
m_pathChooser->setEnabled(true); m_pathChooser->setEnabled(true);
fl->addRow(tr("Build directory:"), m_pathChooser); fl->addRow(tr("Build directory:"), m_pathChooser);
connect(m_pathChooser, &Utils::PathChooser::rawPathChanged, connect(m_pathChooser, &Utils::PathChooser::rawPathChanged,

View File

@@ -64,7 +64,7 @@ class GenericBuildConfigurationFactory : public ProjectExplorer::IBuildConfigura
Q_OBJECT Q_OBJECT
public: public:
explicit GenericBuildConfigurationFactory(QObject *parent = 0); explicit GenericBuildConfigurationFactory(QObject *parent = nullptr);
~GenericBuildConfigurationFactory(); ~GenericBuildConfigurationFactory();
int priority(const ProjectExplorer::Target *parent) const override; int priority(const ProjectExplorer::Target *parent) const override;

View File

@@ -142,19 +142,19 @@ QVariantMap GenericMakeStep::toMap() const
{ {
QVariantMap map(AbstractProcessStep::toMap()); QVariantMap map(AbstractProcessStep::toMap());
map.insert(QLatin1String(BUILD_TARGETS_KEY), m_buildTargets); map.insert(BUILD_TARGETS_KEY, m_buildTargets);
map.insert(QLatin1String(MAKE_ARGUMENTS_KEY), m_makeArguments); map.insert(MAKE_ARGUMENTS_KEY, m_makeArguments);
map.insert(QLatin1String(MAKE_COMMAND_KEY), m_makeCommand); map.insert(MAKE_COMMAND_KEY, m_makeCommand);
map.insert(QLatin1String(CLEAN_KEY), m_clean); map.insert(CLEAN_KEY, m_clean);
return map; return map;
} }
bool GenericMakeStep::fromMap(const QVariantMap &map) bool GenericMakeStep::fromMap(const QVariantMap &map)
{ {
m_buildTargets = map.value(QLatin1String(BUILD_TARGETS_KEY)).toStringList(); m_buildTargets = map.value(BUILD_TARGETS_KEY).toStringList();
m_makeArguments = map.value(QLatin1String(MAKE_ARGUMENTS_KEY)).toString(); m_makeArguments = map.value(MAKE_ARGUMENTS_KEY).toString();
m_makeCommand = map.value(QLatin1String(MAKE_COMMAND_KEY)).toString(); m_makeCommand = map.value(MAKE_COMMAND_KEY).toString();
m_clean = map.value(QLatin1String(CLEAN_KEY)).toBool(); m_clean = map.value(CLEAN_KEY).toBool();
return BuildStep::fromMap(map); return BuildStep::fromMap(map);
} }
@@ -174,7 +174,7 @@ QString GenericMakeStep::makeCommand(const Utils::Environment &environment) cons
if (tc) if (tc)
command = tc->makeCommand(environment); command = tc->makeCommand(environment);
else else
command = QLatin1String("make"); command = "make";
} }
return command; return command;
} }
@@ -220,9 +220,10 @@ GenericMakeStepConfigWidget::GenericMakeStepConfigWidget(GenericMakeStep *makeSt
m_ui = new Ui::GenericMakeStep; m_ui = new Ui::GenericMakeStep;
m_ui->setupUi(this); m_ui->setupUi(this);
GenericProject *pro = static_cast<GenericProject *>(m_makeStep->target()->project()); const auto pro = static_cast<GenericProject *>(m_makeStep->target()->project());
foreach (const QString &target, pro->buildTargets()) { const auto buildTargets = pro->buildTargets();
QListWidgetItem *item = new QListWidgetItem(target, m_ui->targetsList); for (const QString &target : buildTargets) {
auto item = new QListWidgetItem(target, m_ui->targetsList);
item->setFlags(item->flags() | Qt::ItemIsUserCheckable); item->setFlags(item->flags() | Qt::ItemIsUserCheckable);
item->setCheckState(m_makeStep->buildsTarget(item->text()) ? Qt::Checked : Qt::Unchecked); item->setCheckState(m_makeStep->buildsTarget(item->text()) ? Qt::Checked : Qt::Unchecked);
} }
@@ -333,19 +334,19 @@ QList<BuildStepInfo> GenericMakeStepFactory::availableSteps(BuildStepList *paren
BuildStep *GenericMakeStepFactory::create(BuildStepList *parent, const Id id) BuildStep *GenericMakeStepFactory::create(BuildStepList *parent, const Id id)
{ {
Q_UNUSED(id) Q_UNUSED(id)
GenericMakeStep *step = new GenericMakeStep(parent); auto step = new GenericMakeStep(parent);
if (parent->id() == ProjectExplorer::Constants::BUILDSTEPS_CLEAN) { if (parent->id() == ProjectExplorer::Constants::BUILDSTEPS_CLEAN) {
step->setClean(true); step->setClean(true);
step->setBuildTarget(QLatin1String("clean"), /* on = */ true); step->setBuildTarget("clean", /* on = */ true);
} else if (parent->id() == ProjectExplorer::Constants::BUILDSTEPS_BUILD) { } else if (parent->id() == ProjectExplorer::Constants::BUILDSTEPS_BUILD) {
step->setBuildTarget(QLatin1String("all"), /* on = */ true); step->setBuildTarget("all", /* on = */ true);
} }
return step; return step;
} }
BuildStep *GenericMakeStepFactory::clone(BuildStepList *parent, BuildStep *source) BuildStep *GenericMakeStepFactory::clone(BuildStepList *parent, BuildStep *source)
{ {
GenericMakeStep *old(qobject_cast<GenericMakeStep *>(source)); auto old = qobject_cast<GenericMakeStep *>(source);
Q_ASSERT(old); Q_ASSERT(old);
return new GenericMakeStep(parent, old); return new GenericMakeStep(parent, old);
} }

View File

@@ -104,7 +104,7 @@ class GenericMakeStepFactory : public ProjectExplorer::IBuildStepFactory
Q_OBJECT Q_OBJECT
public: public:
explicit GenericMakeStepFactory(QObject *parent = 0); explicit GenericMakeStepFactory(QObject *parent = nullptr);
QList<ProjectExplorer::BuildStepInfo> QList<ProjectExplorer::BuildStepInfo>
availableSteps(ProjectExplorer::BuildStepList *parent) const override; availableSteps(ProjectExplorer::BuildStepList *parent) const override;

View File

@@ -74,13 +74,13 @@ GenericProject::GenericProject(Manager *manager, const QString &fileName)
setProjectContext(Context(GenericProjectManager::Constants::PROJECTCONTEXT)); setProjectContext(Context(GenericProjectManager::Constants::PROJECTCONTEXT));
setProjectLanguages(Context(ProjectExplorer::Constants::LANG_CXX)); setProjectLanguages(Context(ProjectExplorer::Constants::LANG_CXX));
QFileInfo fileInfo = projectFilePath().toFileInfo(); const QFileInfo fileInfo = projectFilePath().toFileInfo();
QDir dir = fileInfo.dir(); const QDir dir = fileInfo.dir();
m_projectName = fileInfo.completeBaseName(); m_projectName = fileInfo.completeBaseName();
m_filesFileName = QFileInfo(dir, m_projectName + QLatin1String(".files")).absoluteFilePath(); m_filesFileName = QFileInfo(dir, m_projectName + ".files").absoluteFilePath();
m_includesFileName = QFileInfo(dir, m_projectName + QLatin1String(".includes")).absoluteFilePath(); m_includesFileName = QFileInfo(dir, m_projectName + ".includes").absoluteFilePath();
m_configFileName = QFileInfo(dir, m_projectName + QLatin1String(".config")).absoluteFilePath(); m_configFileName = QFileInfo(dir, m_projectName + ".config").absoluteFilePath();
m_filesIDocument = new GenericProjectFile(this, m_filesFileName, GenericProject::Files); m_filesIDocument = new GenericProjectFile(this, m_filesFileName, GenericProject::Files);
m_includesIDocument = new GenericProjectFile(this, m_includesFileName, GenericProject::Configuration); m_includesIDocument = new GenericProjectFile(this, m_includesFileName, GenericProject::Configuration);
@@ -91,20 +91,19 @@ GenericProject::GenericProject(Manager *manager, const QString &fileName)
DocumentManager::addDocument(m_includesIDocument); DocumentManager::addDocument(m_includesIDocument);
DocumentManager::addDocument(m_configIDocument); DocumentManager::addDocument(m_configIDocument);
FileNode *projectFilesNode = new FileNode(Utils::FileName::fromString(m_filesFileName), auto projectFilesNode = new FileNode(Utils::FileName::fromString(m_filesFileName),
FileType::Project, FileType::Project,
/* generated = */ false); /* generated = */ false);
FileNode *projectIncludesNode = new FileNode(Utils::FileName::fromString(m_includesFileName), auto projectIncludesNode = new FileNode(Utils::FileName::fromString(m_includesFileName),
FileType::Project, FileType::Project,
/* generated = */ false); /* generated = */ false);
FileNode *projectConfigNode = new FileNode(Utils::FileName::fromString(m_configFileName), auto projectConfigNode = new FileNode(Utils::FileName::fromString(m_configFileName),
FileType::Project, FileType::Project,
/* generated = */ false); /* generated = */ false);
rootProjectNode()->addFileNodes(QList<FileNode *>() << projectFilesNode rootProjectNode()->addFileNodes({ projectFilesNode, projectIncludesNode, projectConfigNode });
<< projectIncludesNode << projectConfigNode);
projectManager()->registerProject(this); projectManager()->registerProject(this);
} }
@@ -138,7 +137,7 @@ static QStringList readLines(const QString &absoluteFileName)
if (file.open(QFile::ReadOnly)) { if (file.open(QFile::ReadOnly)) {
QTextStream stream(&file); QTextStream stream(&file);
forever { for (;;) {
const QString line = stream.readLine(); const QString line = stream.readLine();
if (line.isNull()) if (line.isNull())
break; break;
@@ -164,8 +163,8 @@ bool GenericProject::saveRawList(const QStringList &rawList, const QString &file
Utils::FileSaver saver(fileName, QIODevice::Text); Utils::FileSaver saver(fileName, QIODevice::Text);
if (!saver.hasError()) { if (!saver.hasError()) {
QTextStream stream(saver.file()); QTextStream stream(saver.file());
foreach (const QString &filePath, rawList) for (const QString &filePath : rawList)
stream << filePath << QLatin1Char('\n'); stream << filePath << '\n';
saver.setResult(&stream); saver.setResult(&stream);
} }
bool result = saver.finalize(ICore::mainWindow()); bool result = saver.finalize(ICore::mainWindow());
@@ -182,24 +181,25 @@ bool GenericProject::addFiles(const QStringList &filePaths)
{ {
QStringList newList = m_rawFileList; QStringList newList = m_rawFileList;
QDir baseDir(projectDirectory().toString()); const QDir baseDir(projectDirectory().toString());
foreach (const QString &filePath, filePaths) for (const QString &filePath : filePaths)
insertSorted(&newList, baseDir.relativeFilePath(filePath)); insertSorted(&newList, baseDir.relativeFilePath(filePath));
QSet<QString> includes = projectIncludePaths().toSet(); const QSet<QString> includes = projectIncludePaths().toSet();
QSet<QString> toAdd; QSet<QString> toAdd;
foreach (const QString &filePath, filePaths) { for (const QString &filePath : filePaths) {
const QString directory = QFileInfo(filePath).absolutePath(); const QString directory = QFileInfo(filePath).absolutePath();
if (!includes.contains(directory) && !toAdd.contains(directory)) if (!includes.contains(directory) && !toAdd.contains(directory))
toAdd << directory; toAdd << directory;
} }
const QDir dir(projectDirectory().toString()); const QDir dir(projectDirectory().toString());
foreach (const QString &path, toAdd) { const auto candidates = toAdd;
for (const QString &path : candidates) {
QString relative = dir.relativeFilePath(path); QString relative = dir.relativeFilePath(path);
if (relative.isEmpty()) if (relative.isEmpty())
relative = QLatin1Char('.'); relative = '.';
m_rawProjectIncludePaths.append(relative); m_rawProjectIncludePaths.append(relative);
} }
@@ -214,7 +214,7 @@ bool GenericProject::removeFiles(const QStringList &filePaths)
{ {
QStringList newList = m_rawFileList; QStringList newList = m_rawFileList;
foreach (const QString &filePath, filePaths) { for (const QString &filePath : filePaths) {
QHash<QString, QString>::iterator i = m_rawListEntries.find(filePath); QHash<QString, QString>::iterator i = m_rawListEntries.find(filePath);
if (i != m_rawListEntries.end()) if (i != m_rawListEntries.end())
newList.removeOne(i.value()); newList.removeOne(i.value());
@@ -227,7 +227,7 @@ bool GenericProject::setFiles(const QStringList &filePaths)
{ {
QStringList newList; QStringList newList;
QDir baseDir(projectDirectory().toString()); QDir baseDir(projectDirectory().toString());
foreach (const QString &filePath, filePaths) for (const QString &filePath : filePaths)
newList.append(baseDir.relativeFilePath(filePath)); newList.append(baseDir.relativeFilePath(filePath));
Utils::sort(newList); Utils::sort(newList);
@@ -278,7 +278,7 @@ void GenericProject::refresh(RefreshOptions options)
if (options & Files) { if (options & Files) {
QList<FileNode *> fileNodes = Utils::transform(files(), [](const QString &f) { QList<FileNode *> fileNodes = Utils::transform(files(), [](const QString &f) {
FileType fileType = FileType::Source; // ### FIXME FileType fileType = FileType::Source; // ### FIXME
if (f.endsWith(QLatin1String(".qrc"))) if (f.endsWith(".qrc"))
fileType = FileType::Resource; fileType = FileType::Resource;
return new FileNode(Utils::FileName::fromString(f), fileType, false); return new FileNode(Utils::FileName::fromString(f), fileType, false);
}); });
@@ -307,7 +307,7 @@ QStringList GenericProject::processEntries(const QStringList &paths,
QFileInfo fileInfo; QFileInfo fileInfo;
QStringList absolutePaths; QStringList absolutePaths;
foreach (const QString &path, paths) { for (const QString &path : paths) {
QString trimmedPath = path.trimmed(); QString trimmedPath = path.trimmed();
if (trimmedPath.isEmpty()) if (trimmedPath.isEmpty())
continue; continue;
@@ -351,7 +351,7 @@ void GenericProject::refreshCppCodeModel()
ppBuilder.setConfigFileName(configFileName()); ppBuilder.setConfigFileName(configFileName());
const QList<Id> languages = ppBuilder.createProjectPartsForFiles(files()); const QList<Id> languages = ppBuilder.createProjectPartsForFiles(files());
foreach (Id language, languages) for (Id language : languages)
setProjectLanguage(language, true); setProjectLanguage(language, true);
m_codeModelFuture = modelManager->updateProjectInfo(pInfo); m_codeModelFuture = modelManager->updateProjectInfo(pInfo);
@@ -385,15 +385,13 @@ QStringList GenericProject::files(FilesMode fileMode) const
QStringList GenericProject::buildTargets() const QStringList GenericProject::buildTargets() const
{ {
QStringList targets; const QStringList targets = { "all", "clean" };
targets.append(QLatin1String("all"));
targets.append(QLatin1String("clean"));
return targets; return targets;
} }
Project::RestoreResult GenericProject::fromMap(const QVariantMap &map, QString *errorMessage) Project::RestoreResult GenericProject::fromMap(const QVariantMap &map, QString *errorMessage)
{ {
RestoreResult result = Project::fromMap(map, errorMessage); const RestoreResult result = Project::fromMap(map, errorMessage);
if (result != RestoreResult::Ok) if (result != RestoreResult::Ok)
return result; return result;
@@ -402,11 +400,11 @@ Project::RestoreResult GenericProject::fromMap(const QVariantMap &map, QString *
addTarget(createTarget(defaultKit)); addTarget(createTarget(defaultKit));
// Sanity check: We need both a buildconfiguration and a runconfiguration! // Sanity check: We need both a buildconfiguration and a runconfiguration!
QList<Target *> targetList = targets(); const QList<Target *> targetList = targets();
if (targetList.isEmpty()) if (targetList.isEmpty())
return RestoreResult::Error; return RestoreResult::Error;
foreach (Target *t, targetList) { for (Target *t : targetList) {
if (!t->activeBuildConfiguration()) { if (!t->activeBuildConfiguration()) {
removeTarget(t); removeTarget(t);
continue; continue;
@@ -431,7 +429,7 @@ GenericProjectFile::GenericProjectFile(GenericProject *parent, QString fileName,
m_options(options) m_options(options)
{ {
setId("Generic.ProjectFile"); setId("Generic.ProjectFile");
setMimeType(QLatin1String(Constants::GENERICMIMETYPE)); setMimeType(Constants::GENERICMIMETYPE);
setFilePath(Utils::FileName::fromString(fileName)); setFilePath(Utils::FileName::fromString(fileName));
} }

View File

@@ -85,7 +85,7 @@ private:
bool saveRawList(const QStringList &rawList, const QString &fileName); bool saveRawList(const QStringList &rawList, const QString &fileName);
void parseProject(RefreshOptions options); void parseProject(RefreshOptions options);
QStringList processEntries(const QStringList &paths, QStringList processEntries(const QStringList &paths,
QHash<QString, QString> *map = 0) const; QHash<QString, QString> *map = nullptr) const;
void refreshCppCodeModel(); void refreshCppCodeModel();

View File

@@ -61,11 +61,11 @@ QHash<QString, QStringList> sortFilesIntoPaths(const QString &base, const QSet<Q
} else { } else {
// `file' is not part of the project. // `file' is not part of the project.
relativeFilePath = baseDir.relativeFilePath(absoluteFilePath.toString()); relativeFilePath = baseDir.relativeFilePath(absoluteFilePath.toString());
if (relativeFilePath.endsWith(QLatin1Char('/'))) if (relativeFilePath.endsWith('/'))
relativeFilePath.chop(1); relativeFilePath.chop(1);
} }
if (relativeFilePath == QLatin1String(".")) if (relativeFilePath == ".")
relativeFilePath.clear(); relativeFilePath.clear();
filesInPath[relativeFilePath].append(absoluteFileName); filesInPath[relativeFilePath].append(absoluteFileName);
@@ -81,12 +81,13 @@ bool GenericProjectNode::showInSimpleTree() const
QList<ProjectAction> GenericProjectNode::supportedActions(Node *node) const QList<ProjectAction> GenericProjectNode::supportedActions(Node *node) const
{ {
Q_UNUSED(node); Q_UNUSED(node);
return QList<ProjectAction>() return {
<< AddNewFile AddNewFile,
<< AddExistingFile AddExistingFile,
<< AddExistingDirectory AddExistingDirectory,
<< RemoveFile RemoveFile,
<< Rename; Rename
};
} }
bool GenericProjectNode::addFiles(const QStringList &filePaths, QStringList *notAdded) bool GenericProjectNode::addFiles(const QStringList &filePaths, QStringList *notAdded)

View File

@@ -58,7 +58,7 @@ namespace Internal {
bool GenericProjectPlugin::initialize(const QStringList &, QString *errorMessage) bool GenericProjectPlugin::initialize(const QStringList &, QString *errorMessage)
{ {
Q_UNUSED(errorMessage) Q_UNUSED(errorMessage)
Utils::MimeDatabase::addMimeTypes(QLatin1String(":genericproject/GenericProjectManager.mimetypes.xml")); Utils::MimeDatabase::addMimeTypes(":genericproject/GenericProjectManager.mimetypes.xml");
addAutoReleasedObject(new Manager); addAutoReleasedObject(new Manager);
addAutoReleasedObject(new ProjectFilesFactory); addAutoReleasedObject(new ProjectFilesFactory);