diff options
author | Martin Duffy <martin.duffy@kitware.com> | 2023-03-22 17:11:21 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2023-03-29 14:41:19 (GMT) |
commit | 19305afd8a2a46925b1a880de68f7be0ad1f3091 (patch) | |
tree | cdef4417cd852c2a5dd85886df4ff61d7fd2e653 /Source/cmCMakePresetsGraphReadJSONWorkflowPresets.cxx | |
parent | 6b08358e17f5b85ad04ab512e4b6e39e989cea35 (diff) | |
download | CMake-19305afd8a2a46925b1a880de68f7be0ad1f3091.zip CMake-19305afd8a2a46925b1a880de68f7be0ad1f3091.tar.gz CMake-19305afd8a2a46925b1a880de68f7be0ad1f3091.tar.bz2 |
presets: Improve JSON parser and error messages
Diffstat (limited to 'Source/cmCMakePresetsGraphReadJSONWorkflowPresets.cxx')
-rw-r--r-- | Source/cmCMakePresetsGraphReadJSONWorkflowPresets.cxx | 53 |
1 files changed, 27 insertions, 26 deletions
diff --git a/Source/cmCMakePresetsGraphReadJSONWorkflowPresets.cxx b/Source/cmCMakePresetsGraphReadJSONWorkflowPresets.cxx index 33680a1..7224e17 100644 --- a/Source/cmCMakePresetsGraphReadJSONWorkflowPresets.cxx +++ b/Source/cmCMakePresetsGraphReadJSONWorkflowPresets.cxx @@ -9,69 +9,72 @@ #include <cm3p/json/value.h> +#include "cmCMakePresetErrors.h" #include "cmCMakePresetsGraph.h" #include "cmCMakePresetsGraphInternal.h" #include "cmJSONHelpers.h" +class cmJSONState; + namespace { -using ReadFileResult = cmCMakePresetsGraph::ReadFileResult; using WorkflowPreset = cmCMakePresetsGraph::WorkflowPreset; -ReadFileResult WorkflowStepTypeHelper(WorkflowPreset::WorkflowStep::Type& out, - const Json::Value* value) +bool WorkflowStepTypeHelper(WorkflowPreset::WorkflowStep::Type& out, + const Json::Value* value, cmJSONState* state) { if (!value) { - return ReadFileResult::INVALID_PRESET; + cmCMakePresetErrors::INVALID_PRESET(value, state); + return false; } if (!value->isString()) { - return ReadFileResult::INVALID_PRESET; + return false; } if (value->asString() == "configure") { out = WorkflowPreset::WorkflowStep::Type::Configure; - return ReadFileResult::READ_OK; + return true; } if (value->asString() == "build") { out = WorkflowPreset::WorkflowStep::Type::Build; - return ReadFileResult::READ_OK; + return true; } if (value->asString() == "test") { out = WorkflowPreset::WorkflowStep::Type::Test; - return ReadFileResult::READ_OK; + return true; } if (value->asString() == "package") { out = WorkflowPreset::WorkflowStep::Type::Package; - return ReadFileResult::READ_OK; + return true; } - return ReadFileResult::INVALID_PRESET; + cmCMakePresetErrors::INVALID_PRESET(value, state); + return false; } auto const WorkflowStepHelper = - cmJSONHelperBuilder<ReadFileResult>::Object<WorkflowPreset::WorkflowStep>( - ReadFileResult::READ_OK, ReadFileResult::INVALID_PRESET, false) + cmJSONHelperBuilder::Object<WorkflowPreset::WorkflowStep>( + JsonErrors::INVALID_OBJECT, false) .Bind("type"_s, &WorkflowPreset::WorkflowStep::PresetType, WorkflowStepTypeHelper) .Bind("name"_s, &WorkflowPreset::WorkflowStep::PresetName, cmCMakePresetsGraphInternal::PresetStringHelper); auto const WorkflowStepsHelper = - cmJSONHelperBuilder<ReadFileResult>::Vector<WorkflowPreset::WorkflowStep>( - ReadFileResult::READ_OK, ReadFileResult::INVALID_PRESET, - WorkflowStepHelper); + cmJSONHelperBuilder::Vector<WorkflowPreset::WorkflowStep>( + cmCMakePresetErrors::INVALID_PRESET, WorkflowStepHelper); auto const WorkflowPresetHelper = - cmJSONHelperBuilder<ReadFileResult>::Object<WorkflowPreset>( - ReadFileResult::READ_OK, ReadFileResult::INVALID_PRESET, false) + cmJSONHelperBuilder::Object<WorkflowPreset>( + cmCMakePresetErrors::INVALID_PRESET_OBJECT, false) .Bind("name"_s, &WorkflowPreset::Name, - cmCMakePresetsGraphInternal::PresetStringHelper) + cmCMakePresetsGraphInternal::PresetNameHelper) .Bind<std::nullptr_t>("vendor"_s, nullptr, cmCMakePresetsGraphInternal::VendorHelper( - ReadFileResult::INVALID_PRESET), + cmCMakePresetErrors::INVALID_PRESET), false) .Bind("displayName"_s, &WorkflowPreset::DisplayName, cmCMakePresetsGraphInternal::PresetStringHelper, false) @@ -81,15 +84,13 @@ auto const WorkflowPresetHelper = } namespace cmCMakePresetsGraphInternal { -cmCMakePresetsGraph::ReadFileResult WorkflowPresetsHelper( +bool WorkflowPresetsHelper( std::vector<cmCMakePresetsGraph::WorkflowPreset>& out, - const Json::Value* value) + const Json::Value* value, cmJSONState* state) { - static auto const helper = - cmJSONHelperBuilder<ReadFileResult>::Vector<WorkflowPreset>( - ReadFileResult::READ_OK, ReadFileResult::INVALID_PRESETS, - WorkflowPresetHelper); + static auto const helper = cmJSONHelperBuilder::Vector<WorkflowPreset>( + cmCMakePresetErrors::INVALID_PRESETS, WorkflowPresetHelper); - return helper(out, value); + return helper(out, value, state); } } |