diff --git a/src/json.hpp b/src/json.hpp index 2dd55104a..eb4df22f6 100644 --- a/src/json.hpp +++ b/src/json.hpp @@ -8862,7 +8862,8 @@ class basic_json // We initially read a lot of characters into the buffer, and we // may not have processed all of them. Therefore, we need to // "rewind" the stream after the last processed char. - is.seekg(start_position + static_cast(processed_chars)); + is.seekg(start_position); + is.ignore(static_cast(processed_chars)); // clear stream flags is.clear(); } diff --git a/test/src/unit-regression.cpp b/test/src/unit-regression.cpp index ec8ba6ad6..cd2374ff8 100644 --- a/test/src/unit-regression.cpp +++ b/test/src/unit-regression.cpp @@ -711,7 +711,6 @@ TEST_CASE("regression tests") "[json.exception.parse_error.101] parse error at 1: syntax error - unexpected end of input"); } - /* SECTION("second example from #529") { std::string str = "{\n\"one\" : 1,\n\"two\" : 2\n}\n{\n\"three\" : 3\n}"; @@ -735,13 +734,11 @@ TEST_CASE("regression tests") if (i == 0) { CHECK(val == json({{"one", 1}, {"two", 2}})); - CHECK(static_cast(stream.tellg()) == 28); } if (i == 1) { CHECK(val == json({{"three", 3}})); - CHECK(static_cast(stream.tellg()) == 44); } ++i; @@ -749,7 +746,6 @@ TEST_CASE("regression tests") std::remove("test.json"); } - */ } SECTION("issue #389 - Integer-overflow (OSS-Fuzz issue 267)")