From 595606ca4ed3011af19c6d8a9f95519d84320120 Mon Sep 17 00:00:00 2001 From: "Matthias P. Braendli" Date: Thu, 20 Jul 2023 13:06:22 +0200 Subject: Rework Json so that it works with map that doesn't support incomplete types --- lib/Json.cpp | 5 +++-- lib/Json.h | 7 +++++-- lib/RemoteControl.cpp | 3 ++- 3 files changed, 10 insertions(+), 5 deletions(-) diff --git a/lib/Json.cpp b/lib/Json.cpp index da5b078..121c2de 100644 --- a/lib/Json.cpp +++ b/lib/Json.cpp @@ -86,8 +86,9 @@ namespace json { else if (std::holds_alternative(value)) { ss << "null"; } - else if (std::holds_alternative(value)) { - ss << map_to_json(std::get(value)); + else if (std::holds_alternative >(value)) { + const map_t& v = *std::get >(value); + ss << map_to_json(v); } else { throw std::logic_error("variant alternative not handled"); diff --git a/lib/Json.h b/lib/Json.h index ee67f35..706394f 100644 --- a/lib/Json.h +++ b/lib/Json.h @@ -41,11 +41,12 @@ namespace json { - using map_t = std::unordered_map; + // STL containers are not required to support incomplete types, + // hence the shared_ptr struct value_t { std::variant< - map_t, + std::shared_ptr>, std::string, double, size_t, @@ -54,5 +55,7 @@ namespace json { std::nullopt_t> v; }; + using map_t = std::unordered_map; + std::string map_to_json(const map_t& values); } diff --git a/lib/RemoteControl.cpp b/lib/RemoteControl.cpp index fbe0662..dca3373 100644 --- a/lib/RemoteControl.cpp +++ b/lib/RemoteControl.cpp @@ -109,7 +109,8 @@ std::list< std::vector > RemoteControllers::get_param_list_values(c std::string RemoteControllers::get_showjson() { json::map_t root; for (auto &controllable : rcs.controllables) { - root[controllable->get_rc_name()].v = controllable->get_all_values(); + root[controllable->get_rc_name()].v = + std::make_shared(controllable->get_all_values()); } return json::map_to_json(root); -- cgit v1.2.3