<?xml version="1.0" encoding="utf-8"?>
<resources>
    <string name="">= Numbers JSON numbers are represented using `std::int64_t`, `std::uint64_t`, and `double`. When a &lt;&lt;ref_value&gt;&gt; is constructed from an unsigned integer, its &lt;&lt;ref_kind&gt;&gt; will be `kind::uint64`. Likewise, a &lt;&lt;ref_value&gt;&gt; constructed from a signed integer will have `kind::int64`, or `kind::double_` if constructed from a floating-point type:</string>
    <string name="">When accessing a number contained within a &lt;&lt;ref_value&gt;&gt;, the function used must match the value\'s &lt;&lt;ref_kind&gt;&gt; exactly; no conversions will be performed. For example if `as_double` is called on a &lt;&lt;ref_value&gt;&gt; that contains a `std::uint64_t`, an exception is thrown. Similarly, the function `if_double` will return `nullptr` and calling `get_double` will result in undefined behavior:</string>
    <string name="">In cases where you know that a &lt;&lt;ref_value&gt;&gt; contains a number but don\'t know its &lt;&lt;ref_kind&gt;&gt;, `value::to_number` can be used to convert the &lt;&lt;ref_value&gt;&gt; to an arithmetic type:</string>
    <string name="">If the &lt;&lt;ref_value&gt;&gt; does not contain a number, or if the conversion is to an integer type `T` and the number cannot be represented exactly by `T`, the conversion will fail. Otherwise, the result is the number converted to `T` as-if by `static_cast`:</string>
    <string name="">In settings where exceptions cannot be used, an overload of `value::to_number` accepting {ref_error_code} can be used instead with identical semantics to its throwing counterpart:</string>
    <string name="">When parsing a JSON document, the type used to represent a number is not explicitly specified and must be determined from its value. In general, the parser will choose the best type which can accurately store the number as it appears in the document. Integers (i.e. numbers without decimals or exponents) that cannot be represented by `std::uint64_t` and `std::int64_t` will be represented as `double` to preserve their magnitude:</string>
    <string name="">More formally, if the number:</string>
    <string name="">contains a decimal point, or</string>
    <string name="">contains an exponent, or</string>
    <string name="">is negative and its value is less than `INT64_MIN`, or</string>
    <string name="">is positive and its value is greater than `UINT64_MAX`,</string>
    <string name="">then its type is `double`. Otherwise, if the number is positive and its value is greater than `INT64_MAX`, then its type is `std::uint64_t`. All other numbers are parsed as `std::int64_t`.</string>
</resources>
