Files
BloomPatched/src/ProjectConfig.cpp

242 lines
8.6 KiB
C++
Raw Normal View History

#include "ProjectConfig.hpp"
2021-10-02 17:39:27 +01:00
#include "src/Services/StringService.hpp"
#include "src/Services/PathService.hpp"
2021-04-06 02:10:14 +01:00
#include "src/Logger/Logger.hpp"
#include "src/Exceptions/InvalidConfig.hpp"
2021-04-04 21:04:12 +01:00
using Services::StringService;
ProjectConfig::ProjectConfig(const YAML::Node& configNode) {
if (!configNode["environments"]) {
throw Exceptions::InvalidConfig{
"No environments found - please review the bloom.yaml configuration file and ensure that "
"no syntax errors are present."
};
}
if (!configNode["environments"].IsMap()) {
throw Exceptions::InvalidConfig{
"Invalid environments configuration provided - 'environments' must be of mapping type."
};
}
const auto& environments = configNode["environments"];
for (auto environmentIt = environments.begin(); environmentIt != environments.end(); environmentIt++) {
auto environmentName = std::optional<std::string>{};
try {
environmentName = environmentIt->first.as<std::string>();
if (!StringService::isAscii(environmentName.value())) {
throw Exceptions::InvalidConfig{
"Environment name ('" + environmentName.value() + "') is not in ASCII form."
};
}
this->environments.emplace(
environmentName.value(),
EnvironmentConfig{environmentName.value(), environmentIt->second}
);
} catch (Exceptions::InvalidConfig& exception) {
Logger::error(
"Invalid environment config for environment '" + environmentName.value() + "': "
+ exception.getMessage() + " Environment will be ignored."
);
2021-04-04 21:04:12 +01:00
} catch (YAML::BadConversion& exception) {
Logger::error(
"Invalid environment name provided. Environment names must be ASCII strings. Environment will be "
"ignored"
);
}
}
2021-04-04 21:04:12 +01:00
if (configNode["debugServer"]) {
Logger::warning(
"The 'debugServer' key was renamed to 'server' in v1.0.0. Please update your bloom.yaml configuration. "
"See " + Services::PathService::homeDomainName() + "/docs/v1-0-0-migration for more."
);
}
if (configNode["server"]) {
this->debugServerConfig = DebugServerConfig(configNode["server"]);
}
2021-04-04 21:04:12 +01:00
if (configNode["insight"]) {
this->insightConfig = InsightConfig(configNode["insight"]);
2021-04-04 21:04:12 +01:00
}
2023-09-23 21:48:55 +01:00
// Old param name, will remove later
if (configNode["debugLoggingEnabled"]) {
2023-09-23 21:48:55 +01:00
this->debugLogging = configNode["debugLoggingEnabled"].as<bool>(this->debugLogging);
}
if (configNode["debugLogging"]) {
this->debugLogging = configNode["debugLogging"].as<bool>(this->debugLogging);
}
}
InsightConfig::InsightConfig(const YAML::Node& insightNode) {
if (!insightNode.IsMap()) {
throw Exceptions::InvalidConfig{
"Invalid insight configuration provided - node must take the form of a YAML mapping."
};
}
if (insightNode["activateOnStartup"]) {
this->activateOnStartup = insightNode["activateOnStartup"].as<bool>(this->activateOnStartup);
2021-04-04 21:04:12 +01:00
}
if (insightNode["shutdownOnClose"]) {
this->shutdownOnClose = insightNode["shutdownOnClose"].as<bool>(this->shutdownOnClose);
}
}
EnvironmentConfig::EnvironmentConfig(std::string name, const YAML::Node& environmentNode)
: name(std::move(name))
{
if (!environmentNode.IsMap()) {
throw Exceptions::InvalidConfig{"Environment node must take the form of a YAML mapping."};
}
static auto warn = true;
if (warn) {
if (environmentNode["debugTool"] && !environmentNode["tool"]) {
Logger::warning(
"The 'debugTool' key was renamed to 'tool' in v1.0.0. Please update your bloom.yaml configuration. "
"Bloom will fail to start up until this is resolved. See "
+ Services::PathService::homeDomainName() + "/docs/v1-0-0-migration for more."
);
}
if (environmentNode["debugServer"] && !environmentNode["server"]) {
Logger::warning(
2023-10-10 21:49:29 +01:00
"The 'debugServer' key was renamed to 'server' in v1.0.0. Please update your bloom.yaml configuration. "
"Bloom will fail to start up until this is resolved. See "
+ Services::PathService::homeDomainName() + "/docs/v1-0-0-migration for more."
);
}
warn = false;
}
if (!environmentNode["tool"]) {
throw Exceptions::InvalidConfig{"Missing debug tool configuration."};
}
2021-04-04 21:04:12 +01:00
if (!environmentNode["target"]) {
throw Exceptions::InvalidConfig{"Missing target configuration."};
}
this->debugToolConfig = DebugToolConfig{environmentNode["tool"]};
this->targetConfig = TargetConfig{environmentNode["target"]};
2021-04-04 21:04:12 +01:00
if (environmentNode["server"]) {
this->debugServerConfig = DebugServerConfig{environmentNode["server"]};
}
if (environmentNode["insight"]) {
this->insightConfig = InsightConfig(environmentNode["insight"]);
2021-04-04 21:04:12 +01:00
}
if (environmentNode["shutdownPostDebugSession"]) {
this->shutdownPostDebugSession = environmentNode["shutdownPostDebugSession"].as<bool>(
this->shutdownPostDebugSession
);
}
}
TargetConfig::TargetConfig(const YAML::Node& targetNode) {
using Targets::TargetPhysicalInterface;
if (!targetNode.IsMap()) {
throw Exceptions::InvalidConfig{
"Invalid target configuration provided - node must take the form of a YAML mapping."
};
}
2021-04-04 21:04:12 +01:00
if (!targetNode["name"]) {
throw Exceptions::InvalidConfig{"No target name found."};
}
this->name = StringService::asciiToLower(targetNode["name"].as<std::string>());
static auto physicalInterfacesByConfigName = std::map<std::string, TargetPhysicalInterface>{
{"debugwire", TargetPhysicalInterface::DEBUG_WIRE}, // Deprecated - left here for backwards compatibility
{"debug-wire", TargetPhysicalInterface::DEBUG_WIRE},
{"pdi", TargetPhysicalInterface::PDI},
{"jtag", TargetPhysicalInterface::JTAG},
{"updi", TargetPhysicalInterface::UPDI},
2024-10-03 22:55:40 +01:00
{"sdi", TargetPhysicalInterface::SDI},
};
if (!targetNode["physicalInterface"]) {
throw Exceptions::InvalidConfig{"No physical interface specified."};
}
const auto physicalInterfaceName = StringService::asciiToLower(targetNode["physicalInterface"].as<std::string>());
const auto physicalInterfaceIt = physicalInterfacesByConfigName.find(physicalInterfaceName);
if (physicalInterfaceIt == physicalInterfacesByConfigName.end()) {
throw Exceptions::InvalidConfig{
"Invalid physical interface provided (\"" + physicalInterfaceName + "\") for target. "
"See " + Services::PathService::homeDomainName() + "/docs/configuration/target-physical-interfaces "
"for valid physical interface configuration values."
};
}
this->physicalInterface = physicalInterfaceIt->second;
if (targetNode["variantName"]) {
this->variantName = StringService::asciiToLower(targetNode["variantName"].as<std::string>());
}
2023-09-20 23:37:54 +01:00
if (targetNode["hardwareBreakpoints"]) {
this->hardwareBreakpoints = targetNode["hardwareBreakpoints"].as<bool>(this->hardwareBreakpoints);
}
2023-09-22 17:52:28 +01:00
if (targetNode["programMemoryCache"]) {
this->programMemoryCache = targetNode["programMemoryCache"].as<bool>(this->programMemoryCache);
}
if (targetNode["reserveSteppingBreakpoint"]) {
this->reserveSteppingBreakpoint = targetNode["reserveSteppingBreakpoint"].as<bool>(false);
}
this->targetNode = targetNode;
}
DebugToolConfig::DebugToolConfig(const YAML::Node& toolNode) {
if (!toolNode.IsMap()) {
throw Exceptions::InvalidConfig{
"Invalid debug tool configuration provided - node must take the form of a YAML mapping."
};
}
2021-04-04 21:04:12 +01:00
if (!toolNode["name"]) {
throw Exceptions::InvalidConfig{"No debug tool name found."};
}
this->name = StringService::asciiToLower(toolNode["name"].as<std::string>());
this->toolNode = toolNode;
}
DebugServerConfig::DebugServerConfig(const YAML::Node& debugServerNode) {
if (!debugServerNode.IsMap()) {
throw Exceptions::InvalidConfig{
"Invalid debug server configuration provided - node must take the form of a YAML mapping."
};
}
if (!debugServerNode["name"]) {
throw Exceptions::InvalidConfig{"No debug server name found."};
}
this->name = StringService::asciiToLower(debugServerNode["name"].as<std::string>());
this->debugServerNode = debugServerNode;
2021-04-04 21:04:12 +01:00
}