mirror of
https://github.com/google/flatbuffers.git
synced 2026-06-02 12:05:50 +00:00
* First working hack of adding 64-bit. Don't judge :) * Made vector_downward work on 64 bit types * vector_downward uses size_t, added offset64 to reflection * cleaned up adding offset64 in parser * Add C++ testing skeleton for 64-bit * working test for CreateVector64 * working >2 GiB buffers * support for large strings * simplified CreateString<> to just provide the offset type * generalize CreateVector template * update test_64.afb due to upstream format change * Added Vector64 type, which is just an alias for vector ATM * Switch to Offset64 for Vector64 * Update for reflection bfbs output change * Starting to add support for vector64 type in C++ * made a generic CreateVector that can handle different offsets and vector types * Support for 32-vector with 64-addressing * Vector64 basic builder + tests working * basic support for json vector64 support * renamed fields in test_64bit.fbs to better reflect their use * working C++ vector64 builder * Apply --annotate-sparse-vector to 64-bit tests * Enable Vector64 for --annotate-sparse-vectors * Merged from upstream * Add `near_string` field for testing 32-bit offsets alongside * keep track of where the 32-bit and 64-bit regions are for flatbufferbuilder * move template<> outside class body for GCC * update run.sh to build and run tests * basic assertion for adding 64-bit offset at the wrong time * started to separate `FlatBufferBuilder` into two classes, 1 64-bit aware, the other not * add test for nested flatbuffer vector64, fix bug in alignment of big vectors * fixed CreateDirect method by iterating by Offset64 first * internal refactoring of flatbufferbuilder * block not supported languages in the parser from using 64-bit * evolution tests for adding a vector64 field * conformity tests for adding/removing offset64 attributes * ensure test is for a big buffer * add parser error tests for `offset64` and `vector64` attributes * add missing static that GCC only complains about * remove stdint-uintn.h header that gets automatically added * move 64-bit CalculateOffset internal * fixed return size of EndVector * various fixes on windows * add SizeT to vector_downward * minimze range of size changes in vector and builder * reworked how tracking if 64-offsets are added * Add ReturnT to EndVector * small cleanups * remove need for second Array definition * combine IndirectHelpers into one definition * started support for vector of struct * Support for 32/64-vectors of structs + Offset64 * small cleanups * add verification for vector64 * add sized prefix for 64-bit buffers * add fuzzer for 64-bit * add example of adding many vectors using a wrapper table * run the new -bfbs-gen-embed logic on the 64-bit tests * remove run.sh and fix cmakelist issue * fixed bazel rules * fixed some PR comments * add 64-bit tests to cmakelist
53 lines
1.7 KiB
C++
53 lines
1.7 KiB
C++
|
|
#include <filesystem>
|
|
#include <string>
|
|
|
|
#include "binary_annotator.h"
|
|
#include "test_init.h"
|
|
|
|
static std::filesystem::path exe_path_;
|
|
static const uint8_t *schema_bfbs_;
|
|
static size_t schema_bfbs_length_;
|
|
|
|
bool TestFileExists(std::filesystem::path file_path) {
|
|
if (file_path.has_filename() && std::filesystem::exists(file_path))
|
|
return true;
|
|
|
|
TEST_OUTPUT_LINE("@DEBUG: file '%s' not found", file_path.string().c_str());
|
|
for (const auto &entry :
|
|
std::filesystem::directory_iterator(file_path.parent_path())) {
|
|
TEST_OUTPUT_LINE("@DEBUG: parent path entry: '%s'",
|
|
entry.path().string().c_str());
|
|
}
|
|
return false;
|
|
}
|
|
|
|
std::string LoadBinarySchema(const char *file_name) {
|
|
const auto file_path = exe_path_.parent_path() / file_name;
|
|
TEST_EQ(true, TestFileExists(file_path));
|
|
std::string schemafile;
|
|
TEST_EQ(true,
|
|
flatbuffers::LoadFile(file_path.string().c_str(), true, &schemafile));
|
|
|
|
flatbuffers::Verifier verifier(
|
|
reinterpret_cast<const uint8_t *>(schemafile.c_str()), schemafile.size());
|
|
TEST_EQ(true, reflection::VerifySchemaBuffer(verifier));
|
|
return schemafile;
|
|
}
|
|
|
|
extern "C" int LLVMFuzzerInitialize(int *, char ***argv) {
|
|
exe_path_ = (*argv)[0];
|
|
static const std::string schema_file =
|
|
LoadBinarySchema("annotated_binary.bfbs");
|
|
schema_bfbs_ = reinterpret_cast<const uint8_t *>(schema_file.c_str());
|
|
schema_bfbs_length_ = schema_file.size();
|
|
return 0;
|
|
}
|
|
|
|
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
|
|
flatbuffers::BinaryAnnotator annotator(schema_bfbs_, schema_bfbs_length_,
|
|
data, size, false);
|
|
|
|
annotator.Annotate();
|
|
return 0;
|
|
} |