You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The example in the current section "Custom data source" does not compile with the current header. I don't know if the example or the library is erroneous (I suspect the former). But even if it is just an example I would expect it to compile - or to have an explanation of the necessary steps to make it work.
This does not allow begin() and end() to require lvalue references.
In the example those functions require lvalue references (begin(MyContainer& tgt)). This should be legitimate as std::begin() also expects lvalue references for container types. But std::declval() returns an rvalue reference by definition.
@nlohmann I’d like to work on this issue. Could you confirm if updating the example as suggested by @dhebbeker would be sufficient to resolve it, or if additional changes are needed?
Please note that I made no suggestion on how to actually fix the issue. The changes I mentioned above are how to make it compile. But those changes contradict the intention of the example! Because then one would use iterators instead of a container.
Also I am not sure a clean resolution can be achieved by only changing the example code.
All these statements are based on the version based in the first made (OP).
Description
The example in the current section "Custom data source" does not compile with the current header. I don't know if the example or the library is erroneous (I suspect the former). But even if it is just an example I would expect it to compile - or to have an explanation of the necessary steps to make it work.
Current refers to the current
develop
branch.Reproduction steps
To reproduce:
#include
andusing namespace
.MyContainer::advance()
andMyContainer::get_current()
(does not make any difference at this stage)See result on Compiler Explorer with clang 15.0.0.
Expected vs. actual results
I would expect the code to compile (without linking) without errors.
Note: It compiles (not linking) if this call to the parser is used instead:
But the example is about using a container.
Minimal code example
Error messages
Compiler and operating system
x86-64 clang 15.0.0
Library version
8c391e0
Validation
develop
branch is used.The text was updated successfully, but these errors were encountered: