CompilationDatabasePM: Use setup function for plugin items

Change-Id: Idd1a6dc1af49fc1e713524677b80ed2010b8f17d
Reviewed-by: Jarek Kobus <jaroslaw.kobus@qt.io>
This commit is contained in:
hjk
2024-01-29 18:36:27 +01:00
parent d723c74858
commit 8976d78b8d
3 changed files with 62 additions and 66 deletions

View File

@@ -41,8 +41,7 @@
using namespace ProjectExplorer;
using namespace Utils;
namespace CompilationDatabaseProjectManager {
namespace Internal {
namespace CompilationDatabaseProjectManager::Internal {
namespace {
@@ -481,31 +480,43 @@ static TextEditor::TextDocument *createCompilationDatabaseDocument()
return doc;
}
CompilationDatabaseEditorFactory::CompilationDatabaseEditorFactory()
class CompilationDatabaseEditorFactory final : public TextEditor::TextEditorFactory
{
public:
CompilationDatabaseEditorFactory()
{
setId(Constants::COMPILATIONDATABASEPROJECT_ID);
setDisplayName(::Core::Tr::tr("Compilation Database"));
addMimeType(Constants::COMPILATIONDATABASEMIMETYPE);
setEditorCreator([]() { return new TextEditor::BaseTextEditor; });
setEditorWidgetCreator([]() { return new TextEditor::TextEditorWidget; });
setEditorCreator([] { return new TextEditor::BaseTextEditor; });
setEditorWidgetCreator([] { return new TextEditor::TextEditorWidget; });
setDocumentCreator(createCompilationDatabaseDocument);
setUseGenericHighlighter(true);
setCommentDefinition(Utils::CommentDefinition::HashStyle);
setCodeFoldingSupported(true);
}
class CompilationDatabaseBuildConfiguration : public BuildConfiguration
{
public:
CompilationDatabaseBuildConfiguration(Target *target, Utils::Id id)
: BuildConfiguration(target, id)
{
}
};
void setupCompilationDatabaseEditor()
{
static CompilationDatabaseEditorFactory theCompilationDatabaseEditorFactory;
}
CompilationDatabaseBuildConfigurationFactory::CompilationDatabaseBuildConfigurationFactory()
// CompilationDatabaseBuildConfigurationFactory
class CompilationDatabaseBuildConfiguration final : public BuildConfiguration
{
public:
CompilationDatabaseBuildConfiguration(Target *target, Id id)
: BuildConfiguration(target, id)
{}
};
class CompilationDatabaseBuildConfigurationFactory final : public BuildConfigurationFactory
{
public:
CompilationDatabaseBuildConfigurationFactory()
{
registerBuildConfiguration<CompilationDatabaseBuildConfiguration>(
"CompilationDatabase.CompilationDatabaseBuildConfiguration");
@@ -523,6 +534,11 @@ CompilationDatabaseBuildConfigurationFactory::CompilationDatabaseBuildConfigurat
return QList<BuildInfo>{info};
});
}
};
} // namespace Internal
} // namespace CompilationDatabaseProjectManager
void setupCompilationDatabaseBuildConfiguration()
{
static CompilationDatabaseBuildConfigurationFactory theCDBuildConfigurationFactory;
}
} // CompilationDatabaseProjectManager::Internal

View File

@@ -59,16 +59,8 @@ public:
Utils::FileSystemWatcher * const m_deployFileWatcher;
};
class CompilationDatabaseEditorFactory : public TextEditor::TextEditorFactory
{
public:
CompilationDatabaseEditorFactory();
};
void setupCompilationDatabaseEditor();
class CompilationDatabaseBuildConfigurationFactory : public ProjectExplorer::BuildConfigurationFactory
{
public:
CompilationDatabaseBuildConfigurationFactory();
};
void setupCompilationDatabaseBuildConfiguration();
} // CompilationDatabaseProjectManager::Internal

View File

@@ -29,27 +29,15 @@ namespace CompilationDatabaseProjectManager::Internal {
const char CHANGEROOTDIR[] = "CompilationDatabaseProjectManager.ChangeRootDirectory";
const char COMPILE_COMMANDS_JSON[] = "compile_commands.json";
class CompilationDatabaseProjectManagerPluginPrivate
{
public:
CompilationDatabaseEditorFactory editorFactory;
CompilationDatabaseBuildConfigurationFactory buildConfigFactory;
QAction changeRootAction{Tr::tr("Change Root Directory")};
};
class CompilationDatabaseProjectManagerPlugin final : public ExtensionSystem::IPlugin
{
Q_OBJECT
Q_PLUGIN_METADATA(IID "org.qt-project.Qt.QtCreatorPlugin" FILE "CompilationDatabaseProjectManager.json")
~CompilationDatabaseProjectManagerPlugin()
{
delete d;
}
void initialize() final
{
d = new CompilationDatabaseProjectManagerPluginPrivate;
setupCompilationDatabaseEditor();
setupCompilationDatabaseBuildConfiguration();
Utils::FileIconProvider::registerIconOverlayForFilename(Utils::Icons::PROJECT.imageFilePath().toString(),
COMPILE_COMMANDS_JSON);
@@ -60,21 +48,21 @@ class CompilationDatabaseProjectManagerPlugin final : public ExtensionSystem::IP
ProjectManager::registerProjectType<CompilationDatabaseProject>(
Constants::COMPILATIONDATABASEMIMETYPE);
Command *cmd = ActionManager::registerAction(&d->changeRootAction, CHANGEROOTDIR);
Command *cmd = ActionManager::registerAction(&m_changeRootAction, CHANGEROOTDIR);
ActionContainer *mprojectContextMenu = ActionManager::actionContainer(
ProjectExplorer::Constants::M_PROJECTCONTEXT);
mprojectContextMenu->addSeparator(ProjectExplorer::Constants::G_PROJECT_TREE);
mprojectContextMenu->addAction(cmd, ProjectExplorer::Constants::G_PROJECT_TREE);
connect(&d->changeRootAction, &QAction::triggered,
connect(&m_changeRootAction, &QAction::triggered,
ProjectTree::instance(), &ProjectTree::changeProjectRootDirectory);
const auto onProjectChanged = [this] {
const auto currentProject = qobject_cast<CompilationDatabaseProject *>(
ProjectTree::currentProject());
d->changeRootAction.setEnabled(currentProject);
m_changeRootAction.setEnabled(currentProject);
};
connect(ProjectManager::instance(), &ProjectManager::startupProjectChanged,
@@ -88,7 +76,7 @@ class CompilationDatabaseProjectManagerPlugin final : public ExtensionSystem::IP
#endif
}
class CompilationDatabaseProjectManagerPluginPrivate *d = nullptr;
QAction m_changeRootAction{Tr::tr("Change Root Directory")};
};
} // CompilationDatabaseProjectManager::Internal