2022-07-20 12:38:07 +02:00
|
|
|
// __ _____ _____ _____
|
|
|
|
// __| | __| | | | JSON for Modern C++ (supporting code)
|
2023-11-28 22:36:31 +01:00
|
|
|
// | | |__ | | | | | | version 3.11.3
|
2022-07-20 12:38:07 +02:00
|
|
|
// |_____|_____|_____|_|___| https://github.com/nlohmann/json
|
|
|
|
//
|
2023-11-26 15:51:19 +01:00
|
|
|
// SPDX-FileCopyrightText: 2013-2023 Niels Lohmann <https://nlohmann.me>
|
2022-07-20 12:38:07 +02:00
|
|
|
// SPDX-License-Identifier: MIT
|
2016-08-04 21:55:47 +02:00
|
|
|
|
2019-01-13 17:41:21 +01:00
|
|
|
#include "doctest_compatibility.h"
|
2016-08-04 21:55:47 +02:00
|
|
|
|
2018-01-29 11:21:11 +01:00
|
|
|
#include <nlohmann/json.hpp>
|
2016-08-04 21:55:47 +02:00
|
|
|
using nlohmann::json;
|
|
|
|
|
|
|
|
TEST_CASE("pointer access")
|
|
|
|
{
|
|
|
|
SECTION("pointer access to object_t")
|
|
|
|
{
|
|
|
|
using test_type = json::object_t;
|
|
|
|
json value = {{"one", 1}, {"two", 2}};
|
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
|
|
|
CHECK(*p1 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p2 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p3 == value.get<test_type>());
|
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<json::object_t*>() != nullptr);
|
|
|
|
CHECK(value.get_ptr<json::array_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::string_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::boolean_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_integer_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_unsigned_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_float_t*>() == nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<json::binary_t*>() == nullptr);
|
2016-08-04 21:55:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("pointer access to const object_t")
|
|
|
|
{
|
2016-08-10 22:41:09 +02:00
|
|
|
using test_type = const json::object_t;
|
2016-08-04 21:55:47 +02:00
|
|
|
const json value = {{"one", 1}, {"two", 2}};
|
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
2016-08-10 22:41:09 +02:00
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
|
|
|
CHECK(*p1 == value.get<test_type>());
|
|
|
|
|
2016-08-04 21:55:47 +02:00
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p2 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2016-08-10 22:41:09 +02:00
|
|
|
CHECK(*p3 == value.get<test_type>());
|
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<const json::object_t*>() != nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::array_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::string_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::boolean_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_integer_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_unsigned_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_float_t*>() == nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<const json::binary_t*>() == nullptr);
|
2016-08-04 21:55:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("pointer access to array_t")
|
|
|
|
{
|
|
|
|
using test_type = json::array_t;
|
|
|
|
json value = {1, 2, 3, 4};
|
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
|
|
|
CHECK(*p1 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p2 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p3 == value.get<test_type>());
|
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<json::object_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::array_t*>() != nullptr);
|
|
|
|
CHECK(value.get_ptr<json::string_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::boolean_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_integer_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_unsigned_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_float_t*>() == nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<json::binary_t*>() == nullptr);
|
2016-08-04 21:55:47 +02:00
|
|
|
}
|
|
|
|
|
2016-08-10 22:41:09 +02:00
|
|
|
SECTION("pointer access to const array_t")
|
|
|
|
{
|
|
|
|
using test_type = const json::array_t;
|
|
|
|
const json value = {1, 2, 3, 4};
|
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
|
|
|
CHECK(*p1 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2016-08-10 22:41:09 +02:00
|
|
|
CHECK(*p2 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2016-08-10 22:41:09 +02:00
|
|
|
CHECK(*p3 == value.get<test_type>());
|
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<const json::object_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::array_t*>() != nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::string_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::boolean_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_integer_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_unsigned_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_float_t*>() == nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<const json::binary_t*>() == nullptr);
|
2016-08-10 22:41:09 +02:00
|
|
|
}
|
|
|
|
|
2016-08-04 21:55:47 +02:00
|
|
|
SECTION("pointer access to string_t")
|
|
|
|
{
|
|
|
|
using test_type = json::string_t;
|
|
|
|
json value = "hello";
|
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
|
|
|
CHECK(*p1 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p2 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p3 == value.get<test_type>());
|
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<json::object_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::array_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::string_t*>() != nullptr);
|
|
|
|
CHECK(value.get_ptr<json::boolean_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_integer_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_unsigned_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_float_t*>() == nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<json::binary_t*>() == nullptr);
|
2016-08-04 21:55:47 +02:00
|
|
|
}
|
|
|
|
|
2016-08-10 22:41:09 +02:00
|
|
|
SECTION("pointer access to const string_t")
|
|
|
|
{
|
|
|
|
using test_type = const json::string_t;
|
|
|
|
const json value = "hello";
|
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
|
|
|
CHECK(*p1 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2016-08-10 22:41:09 +02:00
|
|
|
CHECK(*p2 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2016-08-10 22:41:09 +02:00
|
|
|
CHECK(*p3 == value.get<test_type>());
|
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<const json::object_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::array_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::string_t*>() != nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::boolean_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_integer_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_unsigned_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_float_t*>() == nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<const json::binary_t*>() == nullptr);
|
2016-08-10 22:41:09 +02:00
|
|
|
}
|
|
|
|
|
2016-08-04 21:55:47 +02:00
|
|
|
SECTION("pointer access to boolean_t")
|
|
|
|
{
|
|
|
|
using test_type = json::boolean_t;
|
|
|
|
json value = false;
|
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
|
|
|
CHECK(*p1 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p2 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p3 == value.get<test_type>());
|
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<json::object_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::array_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::string_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::boolean_t*>() != nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_integer_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_unsigned_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_float_t*>() == nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<json::binary_t*>() == nullptr);
|
2016-08-04 21:55:47 +02:00
|
|
|
}
|
|
|
|
|
2016-08-10 22:41:09 +02:00
|
|
|
SECTION("pointer access to const boolean_t")
|
|
|
|
{
|
|
|
|
using test_type = const json::boolean_t;
|
|
|
|
const json value = false;
|
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
|
|
|
//CHECK(*p1 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2017-07-07 23:38:04 +02:00
|
|
|
CHECK(*p2 == value.get<test_type>());
|
2016-08-10 22:41:09 +02:00
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2017-07-07 23:38:04 +02:00
|
|
|
CHECK(*p3 == value.get<test_type>());
|
2016-08-10 22:41:09 +02:00
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<const json::object_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::array_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::string_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::boolean_t*>() != nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_integer_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_unsigned_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_float_t*>() == nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<const json::binary_t*>() == nullptr);
|
2016-08-10 22:41:09 +02:00
|
|
|
}
|
|
|
|
|
2016-08-04 21:55:47 +02:00
|
|
|
SECTION("pointer access to number_integer_t")
|
|
|
|
{
|
|
|
|
using test_type = json::number_integer_t;
|
|
|
|
json value = 23;
|
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
|
|
|
CHECK(*p1 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p2 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p3 == value.get<test_type>());
|
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<json::object_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::array_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::string_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::boolean_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_integer_t*>() != nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_unsigned_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_float_t*>() == nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<json::binary_t*>() == nullptr);
|
2016-08-04 21:55:47 +02:00
|
|
|
}
|
|
|
|
|
2016-08-10 22:41:09 +02:00
|
|
|
SECTION("pointer access to const number_integer_t")
|
|
|
|
{
|
|
|
|
using test_type = const json::number_integer_t;
|
|
|
|
const json value = 23;
|
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
|
|
|
CHECK(*p1 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2016-08-10 22:41:09 +02:00
|
|
|
CHECK(*p2 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2016-08-10 22:41:09 +02:00
|
|
|
CHECK(*p3 == value.get<test_type>());
|
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<const json::object_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::array_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::string_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::boolean_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_integer_t*>() != nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_unsigned_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_float_t*>() == nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<const json::binary_t*>() == nullptr);
|
2016-08-10 22:41:09 +02:00
|
|
|
}
|
|
|
|
|
2016-08-04 21:55:47 +02:00
|
|
|
SECTION("pointer access to number_unsigned_t")
|
|
|
|
{
|
|
|
|
using test_type = json::number_unsigned_t;
|
|
|
|
json value = 23u;
|
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
|
|
|
CHECK(*p1 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p2 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p3 == value.get<test_type>());
|
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<json::object_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::array_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::string_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::boolean_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_integer_t*>() != nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_unsigned_t*>() != nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_float_t*>() == nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<json::binary_t*>() == nullptr);
|
2016-08-04 21:55:47 +02:00
|
|
|
}
|
|
|
|
|
2016-08-10 22:41:09 +02:00
|
|
|
SECTION("pointer access to const number_unsigned_t")
|
|
|
|
{
|
|
|
|
using test_type = const json::number_unsigned_t;
|
|
|
|
const json value = 23u;
|
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
|
|
|
CHECK(*p1 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2016-08-10 22:41:09 +02:00
|
|
|
CHECK(*p2 == value.get<test_type>());
|
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2016-08-10 22:41:09 +02:00
|
|
|
CHECK(*p3 == value.get<test_type>());
|
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<const json::object_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::array_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::string_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::boolean_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_integer_t*>() != nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_unsigned_t*>() != nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_float_t*>() == nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<const json::binary_t*>() == nullptr);
|
2016-08-10 22:41:09 +02:00
|
|
|
}
|
|
|
|
|
2016-08-04 21:55:47 +02:00
|
|
|
SECTION("pointer access to number_float_t")
|
|
|
|
{
|
|
|
|
using test_type = json::number_float_t;
|
|
|
|
json value = 42.23;
|
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
|
|
|
CHECK(*p1 == Approx(value.get<test_type>()));
|
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p2 == Approx(value.get<test_type>()));
|
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2016-08-04 21:55:47 +02:00
|
|
|
CHECK(*p3 == Approx(value.get<test_type>()));
|
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<json::object_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::array_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::string_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::boolean_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_integer_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_unsigned_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<json::number_float_t*>() != nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<json::binary_t*>() == nullptr);
|
2016-08-04 21:55:47 +02:00
|
|
|
}
|
2016-08-10 22:41:09 +02:00
|
|
|
|
|
|
|
SECTION("pointer access to const number_float_t")
|
|
|
|
{
|
|
|
|
using test_type = const json::number_float_t;
|
|
|
|
const json value = 42.23;
|
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
|
|
|
CHECK(*p1 == Approx(value.get<test_type>()));
|
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2016-08-10 22:41:09 +02:00
|
|
|
CHECK(*p2 == Approx(value.get<test_type>()));
|
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
2020-05-06 22:13:55 +02:00
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2016-08-10 22:41:09 +02:00
|
|
|
CHECK(*p3 == Approx(value.get<test_type>()));
|
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<const json::object_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::array_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::string_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::boolean_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_integer_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_unsigned_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_float_t*>() != nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<const json::binary_t*>() == nullptr);
|
2016-08-10 22:41:09 +02:00
|
|
|
}
|
2020-05-08 14:21:11 +02:00
|
|
|
|
2020-05-17 22:50:27 +02:00
|
|
|
SECTION("pointer access to const binary_t")
|
2020-05-08 14:21:11 +02:00
|
|
|
{
|
2020-05-17 22:50:27 +02:00
|
|
|
using test_type = const json::binary_t;
|
2020-05-19 13:30:22 +02:00
|
|
|
const json value = json::binary({1, 2, 3});
|
2020-05-08 14:21:11 +02:00
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
2020-05-15 14:12:32 +02:00
|
|
|
CHECK(*p1 == value.get<test_type>());
|
2020-05-08 14:21:11 +02:00
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2020-05-15 14:12:32 +02:00
|
|
|
CHECK(*p2 == value.get<test_type>());
|
2020-05-08 14:21:11 +02:00
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2020-05-15 14:12:32 +02:00
|
|
|
CHECK(*p3 == value.get<test_type>());
|
2020-05-08 14:21:11 +02:00
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<const json::object_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::array_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::string_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::boolean_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_integer_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_unsigned_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_float_t*>() == nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<const json::binary_t*>() != nullptr);
|
2020-05-08 14:21:11 +02:00
|
|
|
}
|
2020-05-10 13:23:18 +02:00
|
|
|
|
2020-05-17 22:50:27 +02:00
|
|
|
SECTION("pointer access to const binary_t")
|
2020-05-10 13:23:18 +02:00
|
|
|
{
|
2020-05-17 22:50:27 +02:00
|
|
|
using test_type = const json::binary_t;
|
2020-05-19 13:30:22 +02:00
|
|
|
const json value = json::binary({});
|
2020-05-10 13:23:18 +02:00
|
|
|
|
|
|
|
// check if pointers are returned correctly
|
|
|
|
test_type* p1 = value.get_ptr<test_type*>();
|
|
|
|
CHECK(p1 == value.get_ptr<test_type*>());
|
2020-05-15 14:12:32 +02:00
|
|
|
CHECK(*p1 == value.get<test_type>());
|
2020-05-10 13:23:18 +02:00
|
|
|
|
|
|
|
const test_type* p2 = value.get_ptr<const test_type*>();
|
|
|
|
CHECK(p2 == value.get_ptr<const test_type*>());
|
2020-05-15 14:12:32 +02:00
|
|
|
CHECK(*p2 == value.get<test_type>());
|
2020-05-10 13:23:18 +02:00
|
|
|
|
|
|
|
const test_type* const p3 = value.get_ptr<const test_type* const>();
|
|
|
|
CHECK(p3 == value.get_ptr<const test_type* const>());
|
2020-05-15 14:12:32 +02:00
|
|
|
CHECK(*p3 == value.get<test_type>());
|
2020-05-10 13:23:18 +02:00
|
|
|
|
|
|
|
// check if null pointers are returned correctly
|
|
|
|
CHECK(value.get_ptr<const json::object_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::array_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::string_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::boolean_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_integer_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_unsigned_t*>() == nullptr);
|
|
|
|
CHECK(value.get_ptr<const json::number_float_t*>() == nullptr);
|
2020-05-17 22:50:27 +02:00
|
|
|
CHECK(value.get_ptr<const json::binary_t*>() != nullptr);
|
2020-05-10 13:23:18 +02:00
|
|
|
}
|
2016-08-04 21:55:47 +02:00
|
|
|
}
|