From d762bfa1953933dfac0a29a74523c25719396b8c Mon Sep 17 00:00:00 2001 From: Oliver Reiche Date: Sat, 15 Apr 2023 16:28:33 +0200 Subject: imports: Switch to Microsoft GSL implementation ... with two minor code base changes compared to previous use of gsl-lite: - dag.hpp: ActionNode::Ptr and ArtifactNode::Ptr are not wrapped in gsl::not_null<> anymore, due to lack of support for wrapping std::unique_ptr<>. More specifically, the move constructor is missing, rendering it impossible to use std::vector<>::emplace_back(). - utils/cpp/gsl.hpp: New header file added to implement the macros ExpectsAudit() and EnsureAudit(), asserts running only in debug builds, which were available in gsl-lite but are missing in MS GSL. --- src/utils/cpp/json.hpp | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) (limited to 'src/utils/cpp/json.hpp') diff --git a/src/utils/cpp/json.hpp b/src/utils/cpp/json.hpp index 4921a39b..aed2f3f4 100644 --- a/src/utils/cpp/json.hpp +++ b/src/utils/cpp/json.hpp @@ -21,8 +21,9 @@ #include #include -#include "gsl-lite/gsl-lite.hpp" +#include "gsl/gsl" #include "nlohmann/json.hpp" +#include "src/utils/cpp/gsl.hpp" template auto ExtractValueAs( @@ -65,7 +66,7 @@ namespace detail { } std::fill_n(iterator{oss}, depth, indent); oss << '}'; - gsl_EnsuresAudit(nlohmann::json::parse(oss.str()) == json); + EnsuresAudit(nlohmann::json::parse(oss.str()) == json); return oss.str(); } if (json.is_array() and depth < until) { @@ -79,7 +80,7 @@ namespace detail { } std::fill_n(iterator{oss}, depth, indent); oss << ']'; - gsl_EnsuresAudit(nlohmann::json::parse(oss.str()) == json); + EnsuresAudit(nlohmann::json::parse(oss.str()) == json); return oss.str(); } return json.dump(); @@ -116,7 +117,7 @@ namespace detail { } std::fill_n(iterator{oss}, depth, indent); oss << '}'; - gsl_EnsuresAudit(nlohmann::json::parse(oss.str()) == json); + EnsuresAudit(nlohmann::json::parse(oss.str()) == json); return oss.str(); } if (json.is_array() and depth < until) { @@ -131,7 +132,7 @@ namespace detail { } std::fill_n(iterator{oss}, depth, indent); oss << ']'; - gsl_EnsuresAudit(nlohmann::json::parse(oss.str()) == json); + EnsuresAudit(nlohmann::json::parse(oss.str()) == json); return oss.str(); } return json.dump(); -- cgit v1.2.3