// ArduinoJson - https://arduinojson.org // Copyright © 2014-2023, Benoit BLANCHON // MIT License // This file is NOT use by Google's OSS fuzz // I only use it to reproduce the bugs found #include // size_t #include // fopen et al. #include // exit #include #include extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size); std::vector read(const char* path) { FILE* f = fopen(path, "rb"); if (!f) { std::cerr << "Failed to open " << path << std::endl; exit(1); } fseek(f, 0, SEEK_END); size_t size = static_cast(ftell(f)); fseek(f, 0, SEEK_SET); std::vector buffer(size); if (fread(buffer.data(), 1, size, f) != size) { fclose(f); std::cerr << "Failed to read " << path << std::endl; exit(1); } fclose(f); return buffer; } int main(int argc, const char* argv[]) { if (argc < 2) { std::cerr << "Usage: msgpack_fuzzer files" << std::endl; return 1; } for (int i = 1; i < argc; i++) { std::cout << "Loading " << argv[i] << std::endl; std::vector buffer = read(argv[i]); LLVMFuzzerTestOneInput(buffer.data(), buffer.size()); } return 0; }