From 35fbe8aab2a083fcd1f8850952286a1ebe33b8ca Mon Sep 17 00:00:00 2001 From: Jospeh G Date: Mon, 4 Nov 2024 11:32:48 -0800 Subject: [PATCH] Reference validation using contains() result rather than exception handling --- src/json-validator.cpp | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/json-validator.cpp b/src/json-validator.cpp index 2c1ed55..c6d3750 100644 --- a/src/json-validator.cpp +++ b/src/json-validator.cpp @@ -254,15 +254,15 @@ class root_schema // // an unknown keyword can only be referenced by a json-pointer, // not by a plain name fragment - if (uri.pointer().to_string() != "") { - try { - auto &subschema = file.unknown_keywords.at(uri.pointer()); // null is returned if not existing - auto s = schema::make(subschema, this, {}, {{uri}}); // A JSON Schema MUST be an object or a boolean. - if (s) { // nullptr if invalid schema, e.g. null + if (!uri.pointer().to_string().empty()) { + bool contains_pointer = file.unknown_keywords.contains(uri.pointer()); + if (contains_pointer) { + auto &subschema = file.unknown_keywords.at(uri.pointer()); + auto s = schema::make(subschema, this, {}, {{uri}}); + if (s) { // if schema is valid (non-null) file.unknown_keywords.erase(uri.fragment()); return s; } - } catch (nlohmann::detail::out_of_range &) { // at() did not find it } }