123456789101112131415161718192021222324252627282930313233343536373839 |
- // A fuzzer for floating-point formatter.
- // For the license information refer to format.h.
- #include <fmt/format.h>
- #include <cstdint>
- #include <cstdlib>
- #include <limits>
- #include <stdexcept>
- #include "fuzzer-common.h"
- void check_round_trip(fmt::string_view format_str, double value) {
- auto buffer = fmt::memory_buffer();
- fmt::format_to(std::back_inserter(buffer), format_str, value);
- if (std::isnan(value)) {
- auto nan = std::signbit(value) ? "-nan" : "nan";
- if (fmt::string_view(buffer.data(), buffer.size()) != nan)
- throw std::runtime_error("round trip failure");
- return;
- }
- buffer.push_back('\0');
- char* ptr = nullptr;
- if (std::strtod(buffer.data(), &ptr) != value)
- throw std::runtime_error("round trip failure");
- if (ptr + 1 != buffer.end()) throw std::runtime_error("unparsed output");
- }
- extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
- if (size <= sizeof(double) || !std::numeric_limits<double>::is_iec559)
- return 0;
- check_round_trip("{}", assign_from_buf<double>(data));
- // A larger than necessary precision is used to trigger the fallback
- // formatter.
- check_round_trip("{:.50g}", assign_from_buf<double>(data));
- return 0;
- }
|