5 #ifndef BITCOIN_TEST_FUZZ_FUZZ_H 6 #define BITCOIN_TEST_FUZZ_FUZZ_H 12 #include <string_view> 18 #define LIMITED_WHILE(condition, limit) \ 19 for (unsigned _count{limit}; (condition) && _count; --_count) 25 std::function<void()>
init{[] {}};
31 #if defined(__clang__) 32 #define FUZZ_TARGET(...) _Pragma("clang diagnostic push") _Pragma("clang diagnostic ignored \"-Wgnu-zero-variadic-macro-arguments\"") DETAIL_FUZZ(__VA_ARGS__) _Pragma("clang diagnostic pop") 34 #define FUZZ_TARGET(...) DETAIL_FUZZ(__VA_ARGS__) 37 #define DETAIL_FUZZ(name, ...) \ 38 void name##_fuzz_target(FuzzBufferType); \ 39 struct name##_Before_Main { \ 40 name##_Before_Main() \ 42 FuzzFrameworkRegisterTarget(#name, name##_fuzz_target, {__VA_ARGS__}); \ 44 } const static g_##name##_before_main; \ 45 void name##_fuzz_target(FuzzBufferType buffer) 47 #endif // BITCOIN_TEST_FUZZ_FUZZ_H
std::function< void(FuzzBufferType)> TypeTestOneInput
void FuzzFrameworkRegisterTarget(std::string_view name, TypeTestOneInput target, FuzzTargetOptions opts)
A Span is an object that can refer to a contiguous sequence of objects.