aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/json/json_reader.cpp
diff options
context:
space:
mode:
authord-dima <d-dima@yandex-team.com>2024-08-05 13:19:22 +0300
committerd-dima <d-dima@yandex-team.com>2024-08-05 13:29:58 +0300
commitacf04c75cb52f804ce76b16c356611268be3daf3 (patch)
tree73df11988fb2ba789ad9f71bd26ff3da92ca3e1e /library/cpp/json/json_reader.cpp
parent8ead472243985333d15c527eb0d998468dc716e1 (diff)
downloadydb-acf04c75cb52f804ce76b16c356611268be3daf3.tar.gz
Allow to read Nan/Inf values from JSON
Allow to read Nan/Inf values from JSON 9fbb79a21d81cf178abc89cd11d7ac75a9a4aaed
Diffstat (limited to 'library/cpp/json/json_reader.cpp')
-rw-r--r--library/cpp/json/json_reader.cpp7
1 files changed, 7 insertions, 0 deletions
diff --git a/library/cpp/json/json_reader.cpp b/library/cpp/json/json_reader.cpp
index 0d048dfcd1..a1a9584481 100644
--- a/library/cpp/json/json_reader.cpp
+++ b/library/cpp/json/json_reader.cpp
@@ -336,6 +336,9 @@ namespace NJson {
constexpr ui32 ConvertToRapidJsonFlags(ui8 flags) {
ui32 rapidjsonFlags = rapidjson::kParseNoFlags;
+ if (flags & ReaderConfigFlags::NANINF) {
+ rapidjsonFlags |= rapidjson::kParseNanAndInfFlag;
+ }
if (flags & ReaderConfigFlags::ITERATIVE) {
rapidjsonFlags |= rapidjson::kParseIterativeFlag;
}
@@ -371,6 +374,7 @@ namespace NJson {
); \
}
+ TRY_EXTRACT_FLAG(ReaderConfigFlags::NANINF);
TRY_EXTRACT_FLAG(ReaderConfigFlags::ITERATIVE);
TRY_EXTRACT_FLAG(ReaderConfigFlags::COMMENTS);
TRY_EXTRACT_FLAG(ReaderConfigFlags::VALIDATE);
@@ -405,6 +409,9 @@ namespace NJson {
if (config.AllowEscapedApostrophe) {
flags |= ReaderConfigFlags::ESCAPE;
}
+ if (config.AllowReadNanInf) {
+ flags |= ReaderConfigFlags::NANINF;
+ }
return ReadWithRuntimeFlags(flags, reader, is, handler);
}