diff --git a/develop/detail/input/binary_reader.hpp b/develop/detail/input/binary_reader.hpp index ebb0683478..ce48fd93b8 100644 --- a/develop/detail/input/binary_reader.hpp +++ b/develop/detail/input/binary_reader.hpp @@ -36,6 +36,7 @@ class binary_reader { using number_integer_t = typename BasicJsonType::number_integer_t; using number_unsigned_t = typename BasicJsonType::number_unsigned_t; + using string_t = typename BasicJsonType::string_t; public: /*! @@ -863,9 +864,9 @@ class binary_reader @throw parse_error.110 if input has less than @a len bytes */ template - std::string get_string(const NumberType len) + string_t get_string(const NumberType len) { - std::string result; + string_t result; std::generate_n(std::back_inserter(result), len, [this]() { get(); @@ -887,7 +888,7 @@ class binary_reader @throw parse_error.110 if input ended @throw parse_error.113 if an unexpected byte is read */ - std::string get_cbor_string() + string_t get_cbor_string() { unexpect_eof(); @@ -944,7 +945,7 @@ class binary_reader case 0x7F: // UTF-8 string (indefinite length) { - std::string result; + string_t result; while (get() != 0xFF) { unexpect_eof(); @@ -1000,7 +1001,7 @@ class binary_reader @throw parse_error.110 if input ended @throw parse_error.113 if an unexpected byte is read */ - std::string get_msgpack_string() + string_t get_msgpack_string() { unexpect_eof(); @@ -1111,7 +1112,7 @@ class binary_reader @throw parse_error.110 if input ended @throw parse_error.113 if an unexpected byte is read */ - std::string get_ubjson_string(const bool get_char = true) + string_t get_ubjson_string(const bool get_char = true) { if (get_char) { @@ -1150,7 +1151,7 @@ class binary_reader */ std::pair get_ubjson_size_type() { - std::size_t sz = std::string::npos; + std::size_t sz = string_t::npos; int tc = 0; get_ignore_noop(); @@ -1219,7 +1220,7 @@ class binary_reader JSON_THROW(parse_error::create(113, chars_read, "byte after 'C' must be in range 0x00..0x7F; last byte: 0x" + ss.str())); } - return std::string(1, static_cast(current)); + return string_t(1, static_cast(current)); } case 'S': // string @@ -1244,7 +1245,7 @@ class binary_reader BasicJsonType result = value_t::array; const auto size_and_type = get_ubjson_size_type(); - if (size_and_type.first != std::string::npos) + if (size_and_type.first != string_t::npos) { if (size_and_type.second != 0) { @@ -1281,7 +1282,7 @@ class binary_reader BasicJsonType result = value_t::object; const auto size_and_type = get_ubjson_size_type(); - if (size_and_type.first != std::string::npos) + if (size_and_type.first != string_t::npos) { if (size_and_type.second != 0) { diff --git a/src/json.hpp b/src/json.hpp index 62411195ee..7dbce3b812 100644 --- a/src/json.hpp +++ b/src/json.hpp @@ -4856,6 +4856,7 @@ class binary_reader { using number_integer_t = typename BasicJsonType::number_integer_t; using number_unsigned_t = typename BasicJsonType::number_unsigned_t; + using string_t = typename BasicJsonType::string_t; public: /*! @@ -5683,9 +5684,9 @@ class binary_reader @throw parse_error.110 if input has less than @a len bytes */ template - std::string get_string(const NumberType len) + string_t get_string(const NumberType len) { - std::string result; + string_t result; std::generate_n(std::back_inserter(result), len, [this]() { get(); @@ -5707,7 +5708,7 @@ class binary_reader @throw parse_error.110 if input ended @throw parse_error.113 if an unexpected byte is read */ - std::string get_cbor_string() + string_t get_cbor_string() { unexpect_eof(); @@ -5764,7 +5765,7 @@ class binary_reader case 0x7F: // UTF-8 string (indefinite length) { - std::string result; + string_t result; while (get() != 0xFF) { unexpect_eof(); @@ -5820,7 +5821,7 @@ class binary_reader @throw parse_error.110 if input ended @throw parse_error.113 if an unexpected byte is read */ - std::string get_msgpack_string() + string_t get_msgpack_string() { unexpect_eof(); @@ -5931,7 +5932,7 @@ class binary_reader @throw parse_error.110 if input ended @throw parse_error.113 if an unexpected byte is read */ - std::string get_ubjson_string(const bool get_char = true) + string_t get_ubjson_string(const bool get_char = true) { if (get_char) { @@ -5970,7 +5971,7 @@ class binary_reader */ std::pair get_ubjson_size_type() { - std::size_t sz = std::string::npos; + std::size_t sz = string_t::npos; int tc = 0; get_ignore_noop(); @@ -6039,7 +6040,7 @@ class binary_reader JSON_THROW(parse_error::create(113, chars_read, "byte after 'C' must be in range 0x00..0x7F; last byte: 0x" + ss.str())); } - return std::string(1, static_cast(current)); + return string_t(1, static_cast(current)); } case 'S': // string @@ -6064,7 +6065,7 @@ class binary_reader BasicJsonType result = value_t::array; const auto size_and_type = get_ubjson_size_type(); - if (size_and_type.first != std::string::npos) + if (size_and_type.first != string_t::npos) { if (size_and_type.second != 0) { @@ -6101,7 +6102,7 @@ class binary_reader BasicJsonType result = value_t::object; const auto size_and_type = get_ubjson_size_type(); - if (size_and_type.first != std::string::npos) + if (size_and_type.first != string_t::npos) { if (size_and_type.second != 0) {