21 std::optional<BufferedFile> opt_buffered_file;
24 opt_buffered_file.emplace(fuzzed_file, fuzzed_data_provider.ConsumeIntegralInRange<uint64_t>(0, 4096), fuzzed_data_provider.ConsumeIntegralInRange<uint64_t>(0, 4096));
25 }
catch (
const std::ios_base::failure&) {
27 if (opt_buffered_file && !fuzzed_file.IsNull()) {
28 bool setpos_fail =
false;
33 std::array<std::byte, 4096> arr{};
35 opt_buffered_file->read({arr.data(), fuzzed_data_provider.ConsumeIntegralInRange<
size_t>(0, 4096)});
36 }
catch (
const std::ios_base::failure&) {
40 opt_buffered_file->SetLimit(fuzzed_data_provider.ConsumeIntegralInRange<uint64_t>(0, 4096));
43 if (!opt_buffered_file->SetPos(fuzzed_data_provider.ConsumeIntegralInRange<uint64_t>(0, 4096))) {
53 opt_buffered_file->FindByte(std::byte(fuzzed_data_provider.ConsumeIntegral<uint8_t>()));
54 }
catch (
const std::ios_base::failure&) {
61 opt_buffered_file->GetPos();
62 opt_buffered_file->GetVersion();
#define LIMITED_WHILE(condition, limit)
Can be used to limit a theoretically unbounded loop.
FUZZ_TARGET(buffered_file)
FuzzedFileProvider ConsumeFile(FuzzedDataProvider &fuzzed_data_provider) noexcept
void ReadFromStream(AddrMan &addr, DataStream &ssPeers)
Only used by tests.
size_t CallOneOf(FuzzedDataProvider &fuzzed_data_provider, Callables... callables)