forked from qt-creator/qt-creator
MesonProjectManager: Hide KitAspectFactory implementations
Change-Id: I7ba81771475905f63f4696b3d9073311eea0ee0a Reviewed-by: Jarek Kobus <jaroslaw.kobus@qt.io> Reviewed-by: <github-actions-qt-creator@cristianadam.eu>
This commit is contained in:
@@ -8,9 +8,7 @@
|
|||||||
#include "mesonbuildsystem.h"
|
#include "mesonbuildsystem.h"
|
||||||
#include "mesonproject.h"
|
#include "mesonproject.h"
|
||||||
#include "mesonrunconfiguration.h"
|
#include "mesonrunconfiguration.h"
|
||||||
#include "mesontoolkitaspect.h"
|
|
||||||
#include "ninjabuildstep.h"
|
#include "ninjabuildstep.h"
|
||||||
#include "ninjatoolkitaspect.h"
|
|
||||||
#include "toolssettingsaccessor.h"
|
#include "toolssettingsaccessor.h"
|
||||||
#include "toolssettingspage.h"
|
#include "toolssettingspage.h"
|
||||||
|
|
||||||
@@ -46,8 +44,6 @@ public:
|
|||||||
private:
|
private:
|
||||||
ToolsSettingsPage m_toolslSettingsPage;
|
ToolsSettingsPage m_toolslSettingsPage;
|
||||||
ToolsSettingsAccessor m_toolsSettings;
|
ToolsSettingsAccessor m_toolsSettings;
|
||||||
MesonToolKitAspectFactory m_mesonKitAspectFactory;
|
|
||||||
NinjaToolKitAspectFactory m_ninjaKitAspectFactory;
|
|
||||||
MesonBuildStepFactory m_buildStepFactory;
|
MesonBuildStepFactory m_buildStepFactory;
|
||||||
MesonBuildConfigurationFactory m_buildConfigurationFactory;
|
MesonBuildConfigurationFactory m_buildConfigurationFactory;
|
||||||
MesonRunConfigurationFactory m_runConfigurationFactory;
|
MesonRunConfigurationFactory m_runConfigurationFactory;
|
||||||
|
@@ -8,70 +8,76 @@
|
|||||||
|
|
||||||
#include <utils/qtcassert.h>
|
#include <utils/qtcassert.h>
|
||||||
|
|
||||||
|
using namespace ProjectExplorer;
|
||||||
|
|
||||||
namespace MesonProjectManager::Internal {
|
namespace MesonProjectManager::Internal {
|
||||||
|
|
||||||
static const char TOOL_ID[] = "MesonProjectManager.MesonKitInformation.Meson";
|
const char TOOL_ID[] = "MesonProjectManager.MesonKitInformation.Meson";
|
||||||
|
|
||||||
MesonToolKitAspectFactory::MesonToolKitAspectFactory()
|
void MesonToolKitAspect::setMesonTool(Kit *kit, Utils::Id id)
|
||||||
{
|
|
||||||
setObjectName(QLatin1String("MesonKitAspect"));
|
|
||||||
setId(TOOL_ID);
|
|
||||||
setDisplayName(Tr::tr("Meson Tool"));
|
|
||||||
setDescription(Tr::tr("The Meson tool to use when building a project with Meson.<br>"
|
|
||||||
"This setting is ignored when using other build systems."));
|
|
||||||
setPriority(9000);
|
|
||||||
}
|
|
||||||
|
|
||||||
ProjectExplorer::Tasks MesonToolKitAspectFactory::validate(const ProjectExplorer::Kit *k) const
|
|
||||||
{
|
|
||||||
ProjectExplorer::Tasks tasks;
|
|
||||||
const auto tool = MesonToolKitAspect::mesonTool(k);
|
|
||||||
if (tool && !tool->isValid())
|
|
||||||
tasks << ProjectExplorer::BuildSystemTask{ProjectExplorer::Task::Warning,
|
|
||||||
Tr::tr("Cannot validate this meson executable.")};
|
|
||||||
return tasks;
|
|
||||||
}
|
|
||||||
|
|
||||||
void MesonToolKitAspectFactory::setup(ProjectExplorer::Kit *k)
|
|
||||||
{
|
|
||||||
const auto tool = MesonToolKitAspect::mesonTool(k);
|
|
||||||
if (!tool) {
|
|
||||||
const auto autoDetected = MesonTools::mesonWrapper();
|
|
||||||
if (autoDetected)
|
|
||||||
MesonToolKitAspect::setMesonTool(k, autoDetected->id());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void MesonToolKitAspectFactory::fix(ProjectExplorer::Kit *k)
|
|
||||||
{
|
|
||||||
setup(k);
|
|
||||||
}
|
|
||||||
|
|
||||||
ProjectExplorer::KitAspectFactory::ItemList MesonToolKitAspectFactory::toUserOutput(
|
|
||||||
const ProjectExplorer::Kit *k) const
|
|
||||||
{
|
|
||||||
const auto tool = MesonToolKitAspect::mesonTool(k);
|
|
||||||
if (tool)
|
|
||||||
return {{Tr::tr("Meson"), tool->name()}};
|
|
||||||
return {{Tr::tr("Meson"), Tr::tr("Unconfigured")}};
|
|
||||||
}
|
|
||||||
|
|
||||||
ProjectExplorer::KitAspect *MesonToolKitAspectFactory::createKitAspect(ProjectExplorer::Kit *k) const
|
|
||||||
{
|
|
||||||
QTC_ASSERT(k, return nullptr);
|
|
||||||
return new ToolKitAspectWidget{k, this, ToolKitAspectWidget::ToolType::Meson};
|
|
||||||
}
|
|
||||||
|
|
||||||
void MesonToolKitAspect::setMesonTool(ProjectExplorer::Kit *kit, Utils::Id id)
|
|
||||||
{
|
{
|
||||||
QTC_ASSERT(kit && id.isValid(), return );
|
QTC_ASSERT(kit && id.isValid(), return );
|
||||||
kit->setValue(TOOL_ID, id.toSetting());
|
kit->setValue(TOOL_ID, id.toSetting());
|
||||||
}
|
}
|
||||||
|
|
||||||
Utils::Id MesonToolKitAspect::mesonToolId(const ProjectExplorer::Kit *kit)
|
Utils::Id MesonToolKitAspect::mesonToolId(const Kit *kit)
|
||||||
{
|
{
|
||||||
QTC_ASSERT(kit, return {});
|
QTC_ASSERT(kit, return {});
|
||||||
return Utils::Id::fromSetting(kit->value(TOOL_ID));
|
return Utils::Id::fromSetting(kit->value(TOOL_ID));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// MesonToolKitAspectFactory
|
||||||
|
|
||||||
|
class MesonToolKitAspectFactory final : public KitAspectFactory
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
MesonToolKitAspectFactory()
|
||||||
|
{
|
||||||
|
setObjectName(QLatin1String("MesonKitAspect"));
|
||||||
|
setId(TOOL_ID);
|
||||||
|
setDisplayName(Tr::tr("Meson Tool"));
|
||||||
|
setDescription(Tr::tr("The Meson tool to use when building a project with Meson.<br>"
|
||||||
|
"This setting is ignored when using other build systems."));
|
||||||
|
setPriority(9000);
|
||||||
|
}
|
||||||
|
|
||||||
|
Tasks validate(const Kit *k) const final
|
||||||
|
{
|
||||||
|
Tasks tasks;
|
||||||
|
const auto tool = MesonToolKitAspect::mesonTool(k);
|
||||||
|
if (tool && !tool->isValid())
|
||||||
|
tasks << BuildSystemTask{Task::Warning, Tr::tr("Cannot validate this meson executable.")};
|
||||||
|
return tasks;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setup(Kit *k) final
|
||||||
|
{
|
||||||
|
const auto tool = MesonToolKitAspect::mesonTool(k);
|
||||||
|
if (!tool) {
|
||||||
|
const auto autoDetected = MesonTools::mesonWrapper();
|
||||||
|
if (autoDetected)
|
||||||
|
MesonToolKitAspect::setMesonTool(k, autoDetected->id());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void fix(Kit *k) final
|
||||||
|
{
|
||||||
|
setup(k);
|
||||||
|
}
|
||||||
|
|
||||||
|
KitAspect *createKitAspect(Kit *k) const
|
||||||
|
{
|
||||||
|
return new ToolKitAspectWidget{k, this, ToolKitAspectWidget::ToolType::Meson};
|
||||||
|
}
|
||||||
|
|
||||||
|
ItemList toUserOutput( const Kit *k) const
|
||||||
|
{
|
||||||
|
const auto tool = MesonToolKitAspect::mesonTool(k);
|
||||||
|
if (tool)
|
||||||
|
return {{Tr::tr("Meson"), tool->name()}};
|
||||||
|
return {{Tr::tr("Meson"), Tr::tr("Unconfigured")}};
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const MesonToolKitAspectFactory theMesonKitAspectFactory;
|
||||||
|
|
||||||
} // MesonProjectManager::Internal
|
} // MesonProjectManager::Internal
|
||||||
|
@@ -28,17 +28,4 @@ public:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class MesonToolKitAspectFactory final : public ProjectExplorer::KitAspectFactory
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
MesonToolKitAspectFactory();
|
|
||||||
|
|
||||||
ProjectExplorer::Tasks validate(const ProjectExplorer::Kit *k) const final;
|
|
||||||
void setup(ProjectExplorer::Kit *k) final;
|
|
||||||
void fix(ProjectExplorer::Kit *k) final;
|
|
||||||
ItemList toUserOutput(const ProjectExplorer::Kit *k) const final;
|
|
||||||
ProjectExplorer::KitAspect *createKitAspect(ProjectExplorer::Kit *) const final;
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
} // MesonProjectManager::Internal
|
} // MesonProjectManager::Internal
|
||||||
|
@@ -8,59 +8,11 @@
|
|||||||
|
|
||||||
#include <utils/qtcassert.h>
|
#include <utils/qtcassert.h>
|
||||||
|
|
||||||
|
using namespace ProjectExplorer;
|
||||||
|
|
||||||
namespace MesonProjectManager::Internal {
|
namespace MesonProjectManager::Internal {
|
||||||
|
|
||||||
static const char TOOL_ID[] = "MesonProjectManager.MesonKitInformation.Ninja";
|
const char TOOL_ID[] = "MesonProjectManager.MesonKitInformation.Ninja";
|
||||||
|
|
||||||
NinjaToolKitAspectFactory::NinjaToolKitAspectFactory()
|
|
||||||
{
|
|
||||||
setObjectName(QLatin1String("NinjaKitAspect"));
|
|
||||||
setId(TOOL_ID);
|
|
||||||
setDisplayName(Tr::tr("Ninja Tool"));
|
|
||||||
setDescription(Tr::tr("The Ninja tool to use when building a project with Meson.<br>"
|
|
||||||
"This setting is ignored when using other build systems."));
|
|
||||||
setPriority(9000);
|
|
||||||
}
|
|
||||||
|
|
||||||
ProjectExplorer::Tasks NinjaToolKitAspectFactory::validate(const ProjectExplorer::Kit *k) const
|
|
||||||
{
|
|
||||||
ProjectExplorer::Tasks tasks;
|
|
||||||
const auto tool = NinjaToolKitAspect::ninjaTool(k);
|
|
||||||
if (tool && !tool->isValid())
|
|
||||||
tasks << ProjectExplorer::BuildSystemTask{ProjectExplorer::Task::Warning,
|
|
||||||
Tr::tr("Cannot validate this Ninja executable.")};
|
|
||||||
return tasks;
|
|
||||||
}
|
|
||||||
|
|
||||||
void NinjaToolKitAspectFactory::setup(ProjectExplorer::Kit *k)
|
|
||||||
{
|
|
||||||
const auto tool = NinjaToolKitAspect::ninjaTool(k);
|
|
||||||
if (!tool) {
|
|
||||||
const auto autoDetected = MesonTools::ninjaWrapper();
|
|
||||||
if (autoDetected)
|
|
||||||
NinjaToolKitAspect::setNinjaTool(k, autoDetected->id());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void NinjaToolKitAspectFactory::fix(ProjectExplorer::Kit *k)
|
|
||||||
{
|
|
||||||
setup(k);
|
|
||||||
}
|
|
||||||
|
|
||||||
ProjectExplorer::KitAspectFactory::ItemList NinjaToolKitAspectFactory::toUserOutput(
|
|
||||||
const ProjectExplorer::Kit *k) const
|
|
||||||
{
|
|
||||||
const auto tool = NinjaToolKitAspect::ninjaTool(k);
|
|
||||||
if (tool)
|
|
||||||
return {{Tr::tr("Ninja"), tool->name()}};
|
|
||||||
return {{Tr::tr("Ninja"), Tr::tr("Unconfigured")}};
|
|
||||||
}
|
|
||||||
|
|
||||||
ProjectExplorer::KitAspect *NinjaToolKitAspectFactory::createKitAspect(ProjectExplorer::Kit *k) const
|
|
||||||
{
|
|
||||||
QTC_ASSERT(k, return nullptr);
|
|
||||||
return new ToolKitAspectWidget{k, this, ToolKitAspectWidget::ToolType::Ninja};
|
|
||||||
}
|
|
||||||
|
|
||||||
void NinjaToolKitAspect::setNinjaTool(ProjectExplorer::Kit *kit, Utils::Id id)
|
void NinjaToolKitAspect::setNinjaTool(ProjectExplorer::Kit *kit, Utils::Id id)
|
||||||
{
|
{
|
||||||
@@ -74,4 +26,59 @@ Utils::Id NinjaToolKitAspect::ninjaToolId(const ProjectExplorer::Kit *kit)
|
|||||||
return Utils::Id::fromSetting(kit->value(TOOL_ID));
|
return Utils::Id::fromSetting(kit->value(TOOL_ID));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NinjaToolKitAspectFactory
|
||||||
|
|
||||||
|
class NinjaToolKitAspectFactory final : public ProjectExplorer::KitAspectFactory
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
NinjaToolKitAspectFactory()
|
||||||
|
{
|
||||||
|
setObjectName(QLatin1String("NinjaKitAspect"));
|
||||||
|
setId(TOOL_ID);
|
||||||
|
setDisplayName(Tr::tr("Ninja Tool"));
|
||||||
|
setDescription(Tr::tr("The Ninja tool to use when building a project with Meson.<br>"
|
||||||
|
"This setting is ignored when using other build systems."));
|
||||||
|
setPriority(9000);
|
||||||
|
}
|
||||||
|
|
||||||
|
Tasks validate(const Kit *k) const final
|
||||||
|
{
|
||||||
|
Tasks tasks;
|
||||||
|
const auto tool = NinjaToolKitAspect::ninjaTool(k);
|
||||||
|
if (tool && !tool->isValid())
|
||||||
|
tasks << BuildSystemTask{Task::Warning,
|
||||||
|
Tr::tr("Cannot validate this Ninja executable.")};
|
||||||
|
return tasks;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setup(Kit *k) final
|
||||||
|
{
|
||||||
|
const auto tool = NinjaToolKitAspect::ninjaTool(k);
|
||||||
|
if (!tool) {
|
||||||
|
const auto autoDetected = MesonTools::ninjaWrapper();
|
||||||
|
if (autoDetected)
|
||||||
|
NinjaToolKitAspect::setNinjaTool(k, autoDetected->id());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void fix(Kit *k) final
|
||||||
|
{
|
||||||
|
setup(k);
|
||||||
|
}
|
||||||
|
|
||||||
|
ItemList toUserOutput( const Kit *k) const
|
||||||
|
{
|
||||||
|
const auto tool = NinjaToolKitAspect::ninjaTool(k);
|
||||||
|
if (tool)
|
||||||
|
return {{Tr::tr("Ninja"), tool->name()}};
|
||||||
|
return {{Tr::tr("Ninja"), Tr::tr("Unconfigured")}};
|
||||||
|
}
|
||||||
|
|
||||||
|
KitAspect *createKitAspect(Kit *k) const final
|
||||||
|
{
|
||||||
|
return new ToolKitAspectWidget(k, this, ToolKitAspectWidget::ToolType::Ninja);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const NinjaToolKitAspectFactory theNinjaToolKitAspectFactory;
|
||||||
|
|
||||||
} // MesonProjectManager::Internal
|
} // MesonProjectManager::Internal
|
||||||
|
@@ -27,16 +27,4 @@ public:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class NinjaToolKitAspectFactory final : public ProjectExplorer::KitAspectFactory
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
NinjaToolKitAspectFactory();
|
|
||||||
|
|
||||||
ProjectExplorer::Tasks validate(const ProjectExplorer::Kit *k) const final;
|
|
||||||
void setup(ProjectExplorer::Kit *k) final;
|
|
||||||
void fix(ProjectExplorer::Kit *k) final;
|
|
||||||
ItemList toUserOutput(const ProjectExplorer::Kit *k) const final;
|
|
||||||
ProjectExplorer::KitAspect *createKitAspect(ProjectExplorer::Kit *) const final;
|
|
||||||
};
|
|
||||||
|
|
||||||
} // MesonProjectManager::Internal
|
} // MesonProjectManager::Internal
|
||||||
|
Reference in New Issue
Block a user