2022-07-20 13:38:07 +03:00
|
|
|
// __ _____ _____ _____
|
|
|
|
|
// __| | __| | | | JSON for Modern C++ (supporting code)
|
2022-08-12 16:04:06 +03:00
|
|
|
// | | |__ | | | | | | version 3.11.2
|
2022-07-20 13:38:07 +03:00
|
|
|
// |_____|_____|_____|_|___| https://github.com/nlohmann/json
|
|
|
|
|
//
|
|
|
|
|
// SPDX-FileCopyrightText: 2013-2022 Niels Lohmann <https://nlohmann.me>
|
|
|
|
|
// SPDX-License-Identifier: MIT
|
2018-04-01 20:12:36 +03:00
|
|
|
|
2019-01-13 19:41:21 +03:00
|
|
|
#include "doctest_compatibility.h"
|
2018-04-01 20:12:36 +03:00
|
|
|
|
|
|
|
|
#include <nlohmann/json.hpp>
|
|
|
|
|
using nlohmann::json;
|
|
|
|
|
|
2022-05-01 23:46:45 +03:00
|
|
|
// ICPC errors out on multibyte character sequences in source files
|
|
|
|
|
#ifndef __INTEL_COMPILER
|
2019-04-04 09:56:36 +03:00
|
|
|
namespace
|
|
|
|
|
{
|
2018-04-02 13:27:07 +03:00
|
|
|
bool wstring_is_utf16();
|
|
|
|
|
bool wstring_is_utf16()
|
2018-04-02 12:34:36 +03:00
|
|
|
{
|
2018-04-02 13:27:07 +03:00
|
|
|
return (std::wstring(L"💩") == std::wstring(L"\U0001F4A9"));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool u16string_is_utf16();
|
|
|
|
|
bool u16string_is_utf16()
|
|
|
|
|
{
|
|
|
|
|
return (std::u16string(u"💩") == std::u16string(u"\U0001F4A9"));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool u32string_is_utf32();
|
|
|
|
|
bool u32string_is_utf32()
|
|
|
|
|
{
|
|
|
|
|
return (std::u32string(U"💩") == std::u32string(U"\U0001F4A9"));
|
2018-04-02 12:34:36 +03:00
|
|
|
}
|
2021-03-24 09:15:18 +03:00
|
|
|
} // namespace
|
2018-04-01 20:12:36 +03:00
|
|
|
|
|
|
|
|
TEST_CASE("wide strings")
|
|
|
|
|
{
|
|
|
|
|
SECTION("std::wstring")
|
|
|
|
|
{
|
2018-04-02 13:27:07 +03:00
|
|
|
if (wstring_is_utf16())
|
2018-04-02 12:34:36 +03:00
|
|
|
{
|
2022-09-13 13:58:26 +03:00
|
|
|
std::wstring const w = L"[12.2,\"Ⴥaäö💤🧢\"]";
|
|
|
|
|
json const j = json::parse(w);
|
2018-04-02 12:34:36 +03:00
|
|
|
CHECK(j.dump() == "[12.2,\"Ⴥaäö💤🧢\"]");
|
|
|
|
|
}
|
2018-04-01 20:12:36 +03:00
|
|
|
}
|
|
|
|
|
|
2018-04-02 16:38:49 +03:00
|
|
|
SECTION("invalid std::wstring")
|
|
|
|
|
{
|
|
|
|
|
if (wstring_is_utf16())
|
|
|
|
|
{
|
2022-09-13 13:58:26 +03:00
|
|
|
std::wstring const w = L"\"\xDBFF";
|
2019-07-02 22:06:42 +03:00
|
|
|
json _;
|
|
|
|
|
CHECK_THROWS_AS(_ = json::parse(w), json::parse_error&);
|
2018-04-02 16:38:49 +03:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-04-01 20:12:36 +03:00
|
|
|
SECTION("std::u16string")
|
|
|
|
|
{
|
2018-04-02 13:27:07 +03:00
|
|
|
if (u16string_is_utf16())
|
2018-04-02 12:34:36 +03:00
|
|
|
{
|
2022-09-13 13:58:26 +03:00
|
|
|
std::u16string const w = u"[12.2,\"Ⴥaäö💤🧢\"]";
|
|
|
|
|
json const j = json::parse(w);
|
2018-04-02 12:34:36 +03:00
|
|
|
CHECK(j.dump() == "[12.2,\"Ⴥaäö💤🧢\"]");
|
|
|
|
|
}
|
2018-04-01 20:12:36 +03:00
|
|
|
}
|
|
|
|
|
|
2018-04-02 16:38:49 +03:00
|
|
|
SECTION("invalid std::u16string")
|
|
|
|
|
{
|
|
|
|
|
if (wstring_is_utf16())
|
|
|
|
|
{
|
2022-09-13 13:58:26 +03:00
|
|
|
std::u16string const w = u"\"\xDBFF";
|
2019-07-02 22:06:42 +03:00
|
|
|
json _;
|
|
|
|
|
CHECK_THROWS_AS(_ = json::parse(w), json::parse_error&);
|
2018-04-02 16:38:49 +03:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-04-01 20:12:36 +03:00
|
|
|
SECTION("std::u32string")
|
|
|
|
|
{
|
2018-04-02 13:27:07 +03:00
|
|
|
if (u32string_is_utf32())
|
2018-04-02 12:34:36 +03:00
|
|
|
{
|
2022-09-13 13:58:26 +03:00
|
|
|
std::u32string const w = U"[12.2,\"Ⴥaäö💤🧢\"]";
|
|
|
|
|
json const j = json::parse(w);
|
2018-04-02 12:34:36 +03:00
|
|
|
CHECK(j.dump() == "[12.2,\"Ⴥaäö💤🧢\"]");
|
|
|
|
|
}
|
2018-04-01 20:12:36 +03:00
|
|
|
}
|
2018-04-02 16:38:49 +03:00
|
|
|
|
|
|
|
|
SECTION("invalid std::u32string")
|
|
|
|
|
{
|
|
|
|
|
if (u32string_is_utf32())
|
|
|
|
|
{
|
2022-09-13 13:58:26 +03:00
|
|
|
std::u32string const w = U"\"\x110000";
|
2019-07-02 22:06:42 +03:00
|
|
|
json _;
|
|
|
|
|
CHECK_THROWS_AS(_ = json::parse(w), json::parse_error&);
|
2018-04-02 16:38:49 +03:00
|
|
|
}
|
|
|
|
|
}
|
2018-04-01 20:12:36 +03:00
|
|
|
}
|
2022-05-01 23:46:45 +03:00
|
|
|
#endif
|