#include #include #include // test that this option is ignored #define FASTFLOAT_ALLOWS_LEADING_PLUS #include "fast_float/fast_float.h" int main_readme() { const std::string input = "+.1"; // not valid double result; fast_float::parse_options options{ fast_float::chars_format::json }; auto answer = fast_float::from_chars_advanced(input.data(), input.data()+input.size(), result, options); if(answer.ec == std::errc()) { std::cerr << "should have failed\n"; return EXIT_FAILURE; } return EXIT_SUCCESS; } int main_readme2() { const std::string input = "inf"; // not valid in JSON double result; fast_float::parse_options options{ fast_float::chars_format::json }; auto answer = fast_float::from_chars_advanced(input.data(), input.data()+input.size(), result, options); if(answer.ec == std::errc()) { std::cerr << "should have failed\n"; return EXIT_FAILURE; } return EXIT_SUCCESS; } int main_readme3() { const std::string input = "inf"; // not valid in JSON but we allow it with json_or_infnan double result; fast_float::parse_options options{ fast_float::chars_format::json_or_infnan }; auto answer = fast_float::from_chars_advanced(input.data(), input.data()+input.size(), result, options); if(answer.ec != std::errc() || (!std::isinf(result))) { std::cerr << "should have parsed infinity\n"; return EXIT_FAILURE; } return EXIT_SUCCESS; } struct ExpectedResult { double value; std::string junk_chars; }; struct AcceptedValue { std::string input; ExpectedResult expected; }; int main() { const std::vector accept{ {"-0.2", {-0.2, ""}}, {"0.02", {0.02, ""}}, {"0.002", {0.002, ""}}, {"1e+0000", {1., ""}}, {"0e-2", {0., ""}}, {"1e", {1., "e"}}, {"1e+", {1., "e+"}}, {"inf", {std::numeric_limits::infinity(), ""}}}; const std::vector reject{"-.2", "00.02", "0.e+1", "00.e+1", ".25", "+0.25", "inf", "nan(snan)"}; for (std::size_t i = 0; i < accept.size(); ++i) { const auto& s = accept[i].input; const auto& expected = accept[i].expected; double result; auto answer = fast_float::from_chars(s.data(), s.data() + s.size(), result, fast_float::chars_format::json_or_infnan); if (answer.ec != std::errc()) { std::cerr << "json fmt rejected valid json " << s << std::endl; return EXIT_FAILURE; } if (result != expected.value) { std::cerr << "json fmt gave wrong result " << s << " (expected " << expected.value << " got " << result << ")" << std::endl; return EXIT_FAILURE; } if (std::string(answer.ptr) != expected.junk_chars) { std::cerr << "json fmt has wrong trailing characters " << s << " (expected " << expected.junk_chars << " got " << answer.ptr << ")" << std::endl; return EXIT_FAILURE; } } for (std::size_t i = 0; i < reject.size(); ++i) { const auto& s = reject[i]; double result; auto answer = fast_float::from_chars(s.data(), s.data() + s.size(), result, fast_float::chars_format::json); if (answer.ec == std::errc()) { std::cerr << "json fmt accepted invalid json " << s << std::endl; return EXIT_FAILURE; } } if(main_readme() != EXIT_SUCCESS) { return EXIT_FAILURE; } if(main_readme2() != EXIT_SUCCESS) { return EXIT_FAILURE; } return EXIT_SUCCESS; }