Coco: Move plugin class definition to .cpp

Change-Id: Ic183657636ab2d8094eee5253a0d6679ea5a805d
Reviewed-by: David Schulz <david.schulz@qt.io>
This commit is contained in:
hjk
2023-12-19 18:29:22 +01:00
parent 3f24752247
commit 913a17734b
4 changed files with 78 additions and 105 deletions

View File

@@ -2,6 +2,6 @@ add_qtc_plugin(Coco
PLUGIN_DEPENDS Core LanguageClient PLUGIN_DEPENDS Core LanguageClient
SOURCES SOURCES
cocolanguageclient.cpp cocolanguageclient.h cocolanguageclient.cpp cocolanguageclient.h
cocoplugin.cpp cocoplugin.h cocoplugin.cpp
cocotr.h cocotr.h
) )

View File

@@ -11,7 +11,6 @@ QtcPlugin {
files: [ files: [
"cocoplugin.cpp", "cocoplugin.cpp",
"cocoplugin.h",
"cocolanguageclient.cpp", "cocolanguageclient.cpp",
"cocolanguageclient.h", "cocolanguageclient.h",
] ]

View File

@@ -1,15 +1,17 @@
// Copyright (C) 2022 The Qt Company Ltd. // Copyright (C) 2022 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0 // SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
#include "cocoplugin.h"
#include "cocolanguageclient.h" #include "cocolanguageclient.h"
#include "cocotr.h" #include "cocotr.h"
#include <coreplugin/actionmanager/actioncontainer.h> #include <coreplugin/actionmanager/actioncontainer.h>
#include <coreplugin/actionmanager/actionmanager.h> #include <coreplugin/actionmanager/actionmanager.h>
#include <coreplugin/icore.h> #include <coreplugin/icore.h>
#include <debugger/analyzer/analyzerconstants.h> #include <debugger/analyzer/analyzerconstants.h>
#include <extensionsystem/iplugin.h>
#include <utils/environment.h> #include <utils/environment.h>
#include <utils/pathchooser.h> #include <utils/pathchooser.h>
@@ -21,85 +23,83 @@ using namespace Utils;
namespace Coco { namespace Coco {
class CocoPluginPrivate class CocoPlugin final : public ExtensionSystem::IPlugin
{ {
public: Q_OBJECT
void startCoco(); Q_PLUGIN_METADATA(IID "org.qt-project.Qt.QtCreatorPlugin" FILE "Coco.json")
public:
~CocoPlugin() final
{
// FIXME: Kill m_client?
}
void initialize() final
{
using namespace Core;
ActionContainer *menu = ActionManager::actionContainer(Debugger::Constants::M_DEBUG_ANALYZER);
if (menu) {
auto startCoco = new QAction("Squish Coco ...", this);
Command *cmd = ActionManager::registerAction(startCoco, "Coco.startCoco");
menu->addAction(cmd, Debugger::Constants::G_ANALYZER_TOOLS);
connect(startCoco, &QAction::triggered, this, [this] { this->startCoco(); });
}
}
void startCoco()
{
if (m_client)
m_client->shutdown();
m_client = nullptr;
QDialog dialog(Core::ICore::dialogParent());
dialog.setModal(true);
auto layout = new QFormLayout();
const Environment env = Environment::systemEnvironment();
const FilePath squishCocoPath = FilePath::fromUserInput(env.value("SQUISHCOCO"));
const FilePath candidate = FilePath("coveragebrowser").searchInPath({squishCocoPath},
FilePath::PrependToPath);
PathChooser cocoChooser;
if (!candidate.isEmpty())
cocoChooser.setFilePath(candidate);
cocoChooser.setExpectedKind(PathChooser::Command);
cocoChooser.setPromptDialogTitle(Tr::tr("Select a Squish Coco CoverageBrowser Executable"));
cocoChooser.setHistoryCompleter("Coco.CoverageBrowser.history", true);
layout->addRow(Tr::tr("CoverageBrowser:"), &cocoChooser);
PathChooser csmesChoser;
csmesChoser.setHistoryCompleter("Coco.CSMes.history", true);
csmesChoser.setExpectedKind(PathChooser::File);
csmesChoser.setInitialBrowsePathBackup(FileUtils::homePath());
csmesChoser.setPromptDialogFilter(Tr::tr("Coco instrumentation files (*.csmes)"));
csmesChoser.setPromptDialogTitle(Tr::tr("Select a Squish Coco Instrumentation File"));
layout->addRow(Tr::tr("CSMes:"), &csmesChoser);
QDialogButtonBox buttons(QDialogButtonBox::Cancel | QDialogButtonBox::Open);
layout->addItem(new QSpacerItem(0, 20, QSizePolicy::Expanding, QSizePolicy::MinimumExpanding));
layout->addWidget(&buttons);
dialog.setLayout(layout);
dialog.resize(480, dialog.height());
QObject::connect(&buttons, &QDialogButtonBox::accepted, &dialog, &QDialog::accept);
QObject::connect(&buttons, &QDialogButtonBox::rejected, &dialog, &QDialog::reject);
if (dialog.exec() == QDialog::Accepted) {
const FilePath cocoPath = cocoChooser.filePath();
const FilePath csmesPath = csmesChoser.filePath();
if (cocoPath.isExecutableFile() && csmesPath.exists()) {
m_client = new CocoLanguageClient(cocoPath, csmesPath);
m_client->start();
}
}
}
private:
CocoLanguageClient *m_client = nullptr; CocoLanguageClient *m_client = nullptr;
}; };
void CocoPluginPrivate::startCoco()
{
if (m_client)
m_client->shutdown();
m_client = nullptr;
QDialog dialog(Core::ICore::dialogParent());
dialog.setModal(true);
auto layout = new QFormLayout();
const Environment env = Environment::systemEnvironment();
const FilePath squishCocoPath = FilePath::fromUserInput(env.value("SQUISHCOCO"));
const FilePath candidate = FilePath("coveragebrowser").searchInPath({squishCocoPath},
FilePath::PrependToPath);
PathChooser cocoChooser;
if (!candidate.isEmpty())
cocoChooser.setFilePath(candidate);
cocoChooser.setExpectedKind(PathChooser::Command);
cocoChooser.setPromptDialogTitle(Tr::tr("Select a Squish Coco CoverageBrowser Executable"));
cocoChooser.setHistoryCompleter("Coco.CoverageBrowser.history", true);
layout->addRow(Tr::tr("CoverageBrowser:"), &cocoChooser);
PathChooser csmesChoser;
csmesChoser.setHistoryCompleter("Coco.CSMes.history", true);
csmesChoser.setExpectedKind(PathChooser::File);
csmesChoser.setInitialBrowsePathBackup(FileUtils::homePath());
csmesChoser.setPromptDialogFilter(Tr::tr("Coco instrumentation files (*.csmes)"));
csmesChoser.setPromptDialogTitle(Tr::tr("Select a Squish Coco Instrumentation File"));
layout->addRow(Tr::tr("CSMes:"), &csmesChoser);
QDialogButtonBox buttons(QDialogButtonBox::Cancel | QDialogButtonBox::Open);
layout->addItem(new QSpacerItem(0, 20, QSizePolicy::Expanding, QSizePolicy::MinimumExpanding));
layout->addWidget(&buttons);
dialog.setLayout(layout);
dialog.resize(480, dialog.height());
QObject::connect(&buttons, &QDialogButtonBox::accepted, &dialog, &QDialog::accept);
QObject::connect(&buttons, &QDialogButtonBox::rejected, &dialog, &QDialog::reject);
if (dialog.exec() == QDialog::Accepted) {
const FilePath cocoPath = cocoChooser.filePath();
const FilePath csmesPath = csmesChoser.filePath();
if (cocoPath.isExecutableFile() && csmesPath.exists()) {
m_client = new CocoLanguageClient(cocoPath, csmesPath);
m_client->start();
}
}
}
CocoPlugin::CocoPlugin()
: d (new CocoPluginPrivate)
{}
CocoPlugin::~CocoPlugin()
{
delete d;
}
void CocoPlugin::initialize()
{
using namespace Core;
ActionContainer *menu = ActionManager::actionContainer(Debugger::Constants::M_DEBUG_ANALYZER);
if (menu) {
auto startCoco = new QAction("Squish Coco ...", this);
Command *cmd = ActionManager::registerAction(startCoco, "Coco.startCoco");
menu->addAction(cmd, Debugger::Constants::G_ANALYZER_TOOLS);
connect(startCoco, &QAction::triggered, this, [this] { d->startCoco(); });
}
}
} // namespace Coco } // namespace Coco
#include "cocoplugin.moc"

View File

@@ -1,26 +0,0 @@
// Copyright (C) 2022 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
#pragma once
#include <extensionsystem/iplugin.h>
namespace Coco {
class CocoPluginPrivate;
class CocoPlugin : public ExtensionSystem::IPlugin
{
Q_OBJECT
Q_PLUGIN_METADATA(IID "org.qt-project.Qt.QtCreatorPlugin" FILE "Coco.json")
public:
CocoPlugin();
~CocoPlugin() override;
void initialize() override;
private:
CocoPluginPrivate *d;
};
} // namespace Coco