-
-
Notifications
You must be signed in to change notification settings - Fork 6.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Inconsistent behavior in conversion to array type #473
Comments
My first thought is that the solution 2 can lead to a lot of bugs, whereas the solution 1 is consistent and straightforward. I would go for solution 1, but again this is my first thought |
I started watching this library yesterday, so I haven't contributed code, but what I'd suggest is... Solution one seems the most logical for a user, because converting some single JSON value (not an array) to an array doesn't make much sense. The second solution is more convenient, though, because it allows the users of this library to not have to stick the JSON value into a JSON array/STL container if they wanted to make a single value into an array. |
I'd vote for solution 1 - a scalar type can't be converted to an array/vector type. |
Me too - solution 1. Less implicitness - more clarity |
So option 1 it is. Thanks for the input! |
These tests currently pass without any adjustments to the source code.
So I wanted to fix this issue and added a regression test: SECTION("issue #473 - inconsistent behavior in conversion to array type")
{
json j_array = {1, 2, 3, 4};
json j_number = 42;
json j_null = nullptr;
SECTION("std::vector")
{
auto create = [](const json & j)
{
std::vector<int> v = j;
};
CHECK_NOTHROW(create(j_array));
CHECK_THROWS_AS(create(j_number), std::domain_error);
CHECK_THROWS_WITH(create(j_number), "type must be array, but is number");
CHECK_THROWS_AS(create(j_null), std::domain_error);
CHECK_THROWS_WITH(create(j_null), "type must be array, but is null");
}
SECTION("std::list")
{
auto create = [](const json & j)
{
std::list<int> v = j;
};
CHECK_NOTHROW(create(j_array));
CHECK_THROWS_AS(create(j_number), std::domain_error);
CHECK_THROWS_WITH(create(j_number), "type must be array, but is number");
CHECK_THROWS_AS(create(j_null), std::domain_error);
CHECK_THROWS_WITH(create(j_null), "type must be array, but is null");
}
SECTION("std::forward_list")
{
auto create = [](const json & j)
{
std::forward_list<int> v = j;
};
CHECK_NOTHROW(create(j_array));
CHECK_THROWS_AS(create(j_number), std::domain_error);
CHECK_THROWS_WITH(create(j_number), "type must be array, but is number");
CHECK_THROWS_AS(create(j_null), std::domain_error);
CHECK_THROWS_WITH(create(j_null), "type must be array, but is null");
}
} "Unfortunately", the test passed without me fixing anything. |
@theodelrieu I would like to ask you some questions on the |
Removed some code that is not needed any more. Thus, streamlining the array from_json methods.
With commit 9355f05 I cleaned the array |
The library supports the conversion from JSON arrays to STL containers such as
std::vector
,std::list
, etc. Example code would be:However, the library's behavior is inconsistent when it comes to non-array values:
This inconsistent behavior is bad design. There are two possibilities to fix it:
null
).Internally, we need to iterate over the array in most cases anyway, so we would have no extra costs for solution 2 irregardless of the type. That means: removing the test for an array type would not mean additional costs.
Any thoughts on this?
The text was updated successfully, but these errors were encountered: