forked from qt-creator/qt-creator
CompilationDatabasePM: Use setup function for plugin items
Change-Id: Idd1a6dc1af49fc1e713524677b80ed2010b8f17d Reviewed-by: Jarek Kobus <jaroslaw.kobus@qt.io>
This commit is contained in:
@@ -41,8 +41,7 @@
|
|||||||
using namespace ProjectExplorer;
|
using namespace ProjectExplorer;
|
||||||
using namespace Utils;
|
using namespace Utils;
|
||||||
|
|
||||||
namespace CompilationDatabaseProjectManager {
|
namespace CompilationDatabaseProjectManager::Internal {
|
||||||
namespace Internal {
|
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
@@ -481,32 +480,44 @@ static TextEditor::TextDocument *createCompilationDatabaseDocument()
|
|||||||
return doc;
|
return doc;
|
||||||
}
|
}
|
||||||
|
|
||||||
CompilationDatabaseEditorFactory::CompilationDatabaseEditorFactory()
|
class CompilationDatabaseEditorFactory final : public TextEditor::TextEditorFactory
|
||||||
{
|
{
|
||||||
|
public:
|
||||||
|
CompilationDatabaseEditorFactory()
|
||||||
|
{
|
||||||
setId(Constants::COMPILATIONDATABASEPROJECT_ID);
|
setId(Constants::COMPILATIONDATABASEPROJECT_ID);
|
||||||
setDisplayName(::Core::Tr::tr("Compilation Database"));
|
setDisplayName(::Core::Tr::tr("Compilation Database"));
|
||||||
addMimeType(Constants::COMPILATIONDATABASEMIMETYPE);
|
addMimeType(Constants::COMPILATIONDATABASEMIMETYPE);
|
||||||
|
|
||||||
setEditorCreator([]() { return new TextEditor::BaseTextEditor; });
|
setEditorCreator([] { return new TextEditor::BaseTextEditor; });
|
||||||
setEditorWidgetCreator([]() { return new TextEditor::TextEditorWidget; });
|
setEditorWidgetCreator([] { return new TextEditor::TextEditorWidget; });
|
||||||
setDocumentCreator(createCompilationDatabaseDocument);
|
setDocumentCreator(createCompilationDatabaseDocument);
|
||||||
setUseGenericHighlighter(true);
|
setUseGenericHighlighter(true);
|
||||||
setCommentDefinition(Utils::CommentDefinition::HashStyle);
|
setCommentDefinition(Utils::CommentDefinition::HashStyle);
|
||||||
setCodeFoldingSupported(true);
|
setCodeFoldingSupported(true);
|
||||||
}
|
|
||||||
|
|
||||||
class CompilationDatabaseBuildConfiguration : public BuildConfiguration
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CompilationDatabaseBuildConfiguration(Target *target, Utils::Id id)
|
|
||||||
: BuildConfiguration(target, id)
|
|
||||||
{
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
void setupCompilationDatabaseEditor()
|
||||||
CompilationDatabaseBuildConfigurationFactory::CompilationDatabaseBuildConfigurationFactory()
|
|
||||||
{
|
{
|
||||||
|
static CompilationDatabaseEditorFactory theCompilationDatabaseEditorFactory;
|
||||||
|
}
|
||||||
|
|
||||||
|
// CompilationDatabaseBuildConfigurationFactory
|
||||||
|
|
||||||
|
class CompilationDatabaseBuildConfiguration final : public BuildConfiguration
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
CompilationDatabaseBuildConfiguration(Target *target, Id id)
|
||||||
|
: BuildConfiguration(target, id)
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
|
class CompilationDatabaseBuildConfigurationFactory final : public BuildConfigurationFactory
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
CompilationDatabaseBuildConfigurationFactory()
|
||||||
|
{
|
||||||
registerBuildConfiguration<CompilationDatabaseBuildConfiguration>(
|
registerBuildConfiguration<CompilationDatabaseBuildConfiguration>(
|
||||||
"CompilationDatabase.CompilationDatabaseBuildConfiguration");
|
"CompilationDatabase.CompilationDatabaseBuildConfiguration");
|
||||||
|
|
||||||
@@ -522,7 +533,12 @@ CompilationDatabaseBuildConfigurationFactory::CompilationDatabaseBuildConfigurat
|
|||||||
info.buildDirectory = projectPath.parentDir();
|
info.buildDirectory = projectPath.parentDir();
|
||||||
return QList<BuildInfo>{info};
|
return QList<BuildInfo>{info};
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
void setupCompilationDatabaseBuildConfiguration()
|
||||||
|
{
|
||||||
|
static CompilationDatabaseBuildConfigurationFactory theCDBuildConfigurationFactory;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace Internal
|
} // CompilationDatabaseProjectManager::Internal
|
||||||
} // namespace CompilationDatabaseProjectManager
|
|
||||||
|
@@ -59,16 +59,8 @@ public:
|
|||||||
Utils::FileSystemWatcher * const m_deployFileWatcher;
|
Utils::FileSystemWatcher * const m_deployFileWatcher;
|
||||||
};
|
};
|
||||||
|
|
||||||
class CompilationDatabaseEditorFactory : public TextEditor::TextEditorFactory
|
void setupCompilationDatabaseEditor();
|
||||||
{
|
|
||||||
public:
|
|
||||||
CompilationDatabaseEditorFactory();
|
|
||||||
};
|
|
||||||
|
|
||||||
class CompilationDatabaseBuildConfigurationFactory : public ProjectExplorer::BuildConfigurationFactory
|
void setupCompilationDatabaseBuildConfiguration();
|
||||||
{
|
|
||||||
public:
|
|
||||||
CompilationDatabaseBuildConfigurationFactory();
|
|
||||||
};
|
|
||||||
|
|
||||||
} // CompilationDatabaseProjectManager::Internal
|
} // CompilationDatabaseProjectManager::Internal
|
||||||
|
@@ -29,27 +29,15 @@ namespace CompilationDatabaseProjectManager::Internal {
|
|||||||
const char CHANGEROOTDIR[] = "CompilationDatabaseProjectManager.ChangeRootDirectory";
|
const char CHANGEROOTDIR[] = "CompilationDatabaseProjectManager.ChangeRootDirectory";
|
||||||
const char COMPILE_COMMANDS_JSON[] = "compile_commands.json";
|
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
|
class CompilationDatabaseProjectManagerPlugin final : public ExtensionSystem::IPlugin
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PLUGIN_METADATA(IID "org.qt-project.Qt.QtCreatorPlugin" FILE "CompilationDatabaseProjectManager.json")
|
Q_PLUGIN_METADATA(IID "org.qt-project.Qt.QtCreatorPlugin" FILE "CompilationDatabaseProjectManager.json")
|
||||||
|
|
||||||
~CompilationDatabaseProjectManagerPlugin()
|
|
||||||
{
|
|
||||||
delete d;
|
|
||||||
}
|
|
||||||
|
|
||||||
void initialize() final
|
void initialize() final
|
||||||
{
|
{
|
||||||
d = new CompilationDatabaseProjectManagerPluginPrivate;
|
setupCompilationDatabaseEditor();
|
||||||
|
setupCompilationDatabaseBuildConfiguration();
|
||||||
|
|
||||||
Utils::FileIconProvider::registerIconOverlayForFilename(Utils::Icons::PROJECT.imageFilePath().toString(),
|
Utils::FileIconProvider::registerIconOverlayForFilename(Utils::Icons::PROJECT.imageFilePath().toString(),
|
||||||
COMPILE_COMMANDS_JSON);
|
COMPILE_COMMANDS_JSON);
|
||||||
@@ -60,21 +48,21 @@ class CompilationDatabaseProjectManagerPlugin final : public ExtensionSystem::IP
|
|||||||
ProjectManager::registerProjectType<CompilationDatabaseProject>(
|
ProjectManager::registerProjectType<CompilationDatabaseProject>(
|
||||||
Constants::COMPILATIONDATABASEMIMETYPE);
|
Constants::COMPILATIONDATABASEMIMETYPE);
|
||||||
|
|
||||||
Command *cmd = ActionManager::registerAction(&d->changeRootAction, CHANGEROOTDIR);
|
Command *cmd = ActionManager::registerAction(&m_changeRootAction, CHANGEROOTDIR);
|
||||||
|
|
||||||
ActionContainer *mprojectContextMenu = ActionManager::actionContainer(
|
ActionContainer *mprojectContextMenu = ActionManager::actionContainer(
|
||||||
ProjectExplorer::Constants::M_PROJECTCONTEXT);
|
ProjectExplorer::Constants::M_PROJECTCONTEXT);
|
||||||
mprojectContextMenu->addSeparator(ProjectExplorer::Constants::G_PROJECT_TREE);
|
mprojectContextMenu->addSeparator(ProjectExplorer::Constants::G_PROJECT_TREE);
|
||||||
mprojectContextMenu->addAction(cmd, 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);
|
ProjectTree::instance(), &ProjectTree::changeProjectRootDirectory);
|
||||||
|
|
||||||
const auto onProjectChanged = [this] {
|
const auto onProjectChanged = [this] {
|
||||||
const auto currentProject = qobject_cast<CompilationDatabaseProject *>(
|
const auto currentProject = qobject_cast<CompilationDatabaseProject *>(
|
||||||
ProjectTree::currentProject());
|
ProjectTree::currentProject());
|
||||||
|
|
||||||
d->changeRootAction.setEnabled(currentProject);
|
m_changeRootAction.setEnabled(currentProject);
|
||||||
};
|
};
|
||||||
|
|
||||||
connect(ProjectManager::instance(), &ProjectManager::startupProjectChanged,
|
connect(ProjectManager::instance(), &ProjectManager::startupProjectChanged,
|
||||||
@@ -88,7 +76,7 @@ class CompilationDatabaseProjectManagerPlugin final : public ExtensionSystem::IP
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
class CompilationDatabaseProjectManagerPluginPrivate *d = nullptr;
|
QAction m_changeRootAction{Tr::tr("Change Root Directory")};
|
||||||
};
|
};
|
||||||
|
|
||||||
} // CompilationDatabaseProjectManager::Internal
|
} // CompilationDatabaseProjectManager::Internal
|
||||||
|
Reference in New Issue
Block a user