diff --git a/samples/monster_generated.h b/samples/monster_generated.h index 854e712ee..53935ee93 100644 --- a/samples/monster_generated.h +++ b/samples/monster_generated.h @@ -59,28 +59,36 @@ MANUALLY_ALIGNED_STRUCT(4) Vec3 FLATBUFFERS_FINAL_CLASS { STRUCT_END(Vec3, 12); struct Monster FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table { - const Vec3 *pos() const { return GetStruct(4); } - Vec3 *mutable_pos() { return GetStruct(4); } - int16_t mana() const { return GetField(6, 150); } - bool mutate_mana(int16_t _mana) { return SetField(6, _mana); } - int16_t hp() const { return GetField(8, 100); } - bool mutate_hp(int16_t _hp) { return SetField(8, _hp); } - const flatbuffers::String *name() const { return GetPointer(10); } - flatbuffers::String *mutable_name() { return GetPointer(10); } - const flatbuffers::Vector *inventory() const { return GetPointer *>(14); } - flatbuffers::Vector *mutable_inventory() { return GetPointer *>(14); } - Color color() const { return static_cast(GetField(16, 2)); } - bool mutate_color(Color _color) { return SetField(16, static_cast(_color)); } + enum { + VT_POS = 4, + VT_MANA = 6, + VT_HP = 8, + VT_NAME = 10, + VT_INVENTORY = 14, + VT_COLOR = 16, + }; + const Vec3 *pos() const { return GetStruct(VT_POS); } + Vec3 *mutable_pos() { return GetStruct(VT_POS); } + int16_t mana() const { return GetField(VT_MANA, 150); } + bool mutate_mana(int16_t _mana) { return SetField(VT_MANA, _mana); } + int16_t hp() const { return GetField(VT_HP, 100); } + bool mutate_hp(int16_t _hp) { return SetField(VT_HP, _hp); } + const flatbuffers::String *name() const { return GetPointer(VT_NAME); } + flatbuffers::String *mutable_name() { return GetPointer(VT_NAME); } + const flatbuffers::Vector *inventory() const { return GetPointer *>(VT_INVENTORY); } + flatbuffers::Vector *mutable_inventory() { return GetPointer *>(VT_INVENTORY); } + Color color() const { return static_cast(GetField(VT_COLOR, 2)); } + bool mutate_color(Color _color) { return SetField(VT_COLOR, static_cast(_color)); } bool Verify(flatbuffers::Verifier &verifier) const { return VerifyTableStart(verifier) && - VerifyField(verifier, 4 /* pos */) && - VerifyField(verifier, 6 /* mana */) && - VerifyField(verifier, 8 /* hp */) && - VerifyField(verifier, 10 /* name */) && + VerifyField(verifier, VT_POS) && + VerifyField(verifier, VT_MANA) && + VerifyField(verifier, VT_HP) && + VerifyField(verifier, VT_NAME) && verifier.Verify(name()) && - VerifyField(verifier, 14 /* inventory */) && + VerifyField(verifier, VT_INVENTORY) && verifier.Verify(inventory()) && - VerifyField(verifier, 16 /* color */) && + VerifyField(verifier, VT_COLOR) && verifier.EndTable(); } }; @@ -88,12 +96,12 @@ struct Monster FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table { struct MonsterBuilder { flatbuffers::FlatBufferBuilder &fbb_; flatbuffers::uoffset_t start_; - void add_pos(const Vec3 *pos) { fbb_.AddStruct(4, pos); } - void add_mana(int16_t mana) { fbb_.AddElement(6, mana, 150); } - void add_hp(int16_t hp) { fbb_.AddElement(8, hp, 100); } - void add_name(flatbuffers::Offset name) { fbb_.AddOffset(10, name); } - void add_inventory(flatbuffers::Offset> inventory) { fbb_.AddOffset(14, inventory); } - void add_color(Color color) { fbb_.AddElement(16, static_cast(color), 2); } + void add_pos(const Vec3 *pos) { fbb_.AddStruct(Monster::VT_POS, pos); } + void add_mana(int16_t mana) { fbb_.AddElement(Monster::VT_MANA, mana, 150); } + void add_hp(int16_t hp) { fbb_.AddElement(Monster::VT_HP, hp, 100); } + void add_name(flatbuffers::Offset name) { fbb_.AddOffset(Monster::VT_NAME, name); } + void add_inventory(flatbuffers::Offset> inventory) { fbb_.AddOffset(Monster::VT_INVENTORY, inventory); } + void add_color(Color color) { fbb_.AddElement(Monster::VT_COLOR, static_cast(color), 2); } MonsterBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb) { start_ = fbb_.StartTable(); } MonsterBuilder &operator=(const MonsterBuilder &); flatbuffers::Offset Finish() { diff --git a/src/idl_gen_cpp.cpp b/src/idl_gen_cpp.cpp index 7c39c325a..ca523dcda 100644 --- a/src/idl_gen_cpp.cpp +++ b/src/idl_gen_cpp.cpp @@ -242,6 +242,12 @@ std::string GenUnderlyingCast(const Parser &parser, const FieldDef &field, : val; } +std::string GenFieldOffsetName(const FieldDef &field) { + std::string uname = field.name; + std::transform(uname.begin(), uname.end(), uname.begin(), ::toupper); + return "VT_" + uname; +} + // Generate an accessor struct, builder structs & function for a table. static void GenTable(const Parser &parser, StructDef &struct_def, const GeneratorOptions &opts, std::string *code_ptr) { @@ -254,6 +260,19 @@ static void GenTable(const Parser &parser, StructDef &struct_def, code += "struct " + struct_def.name; code += " FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table"; code += " {\n"; + // Generate field id constants. + code += " enum {\n"; + for (auto it = struct_def.fields.vec.begin(); + it != struct_def.fields.vec.end(); + ++it) { + auto &field = **it; + if (!field.deprecated) { // Deprecated fields won't be accessible. + code += " " + GenFieldOffsetName(field) + " = "; + code += NumToString(field.value.offset) + ",\n"; + } + } + code += " };\n"; + // Generate the accessors. for (auto it = struct_def.fields.vec.begin(); it != struct_def.fields.vec.end(); ++it) { @@ -268,7 +287,7 @@ static void GenTable(const Parser &parser, StructDef &struct_def, auto accessor = is_scalar ? "GetField<" : (IsStruct(field.value.type) ? "GetStruct<" : "GetPointer<"); - auto offsetstr = NumToString(field.value.offset); + auto offsetstr = GenFieldOffsetName(field); auto call = accessor + GenTypeGet(parser, field.value.type, "", "const ", " *", false) + @@ -347,8 +366,7 @@ static void GenTable(const Parser &parser, StructDef &struct_def, code += prefix + "VerifyField"; if (field.required) code += "Required"; code += "<" + GenTypeSize(parser, field.value.type); - code += ">(verifier, " + NumToString(field.value.offset); - code += " /* " + field.name + " */)"; + code += ">(verifier, " + GenFieldOffsetName(field) + ")"; switch (field.value.type.base_type) { case BASE_TYPE_UNION: code += prefix + "Verify" + field.value.type.enum_def->name; @@ -412,7 +430,7 @@ static void GenTable(const Parser &parser, StructDef &struct_def, } else { code += "Offset"; } - code += "(" + NumToString(field.value.offset) + ", "; + code += "(" + struct_def.name + "::" + GenFieldOffsetName(field) + ", "; code += GenUnderlyingCast(parser, field, false, field.name); if (IsScalar(field.value.type.base_type)) code += ", " + field.value.constant; @@ -433,7 +451,8 @@ static void GenTable(const Parser &parser, StructDef &struct_def, ++it) { auto &field = **it; if (!field.deprecated && field.required) { - code += " fbb_.Required(o, " + NumToString(field.value.offset); + code += " fbb_.Required(o, "; + code += struct_def.name + "::" + GenFieldOffsetName(field); code += "); // " + field.name + "\n"; } } diff --git a/tests/monster_test_generated.h b/tests/monster_test_generated.h index 8a78de530..90814a94f 100644 --- a/tests/monster_test_generated.h +++ b/tests/monster_test_generated.h @@ -97,11 +97,14 @@ MANUALLY_ALIGNED_STRUCT(16) Vec3 FLATBUFFERS_FINAL_CLASS { STRUCT_END(Vec3, 32); struct TestSimpleTableWithEnum FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table { - Color color() const { return static_cast(GetField(4, 2)); } - bool mutate_color(Color _color) { return SetField(4, static_cast(_color)); } + enum { + VT_COLOR = 4, + }; + Color color() const { return static_cast(GetField(VT_COLOR, 2)); } + bool mutate_color(Color _color) { return SetField(VT_COLOR, static_cast(_color)); } bool Verify(flatbuffers::Verifier &verifier) const { return VerifyTableStart(verifier) && - VerifyField(verifier, 4 /* color */) && + VerifyField(verifier, VT_COLOR) && verifier.EndTable(); } }; @@ -109,7 +112,7 @@ struct TestSimpleTableWithEnum FLATBUFFERS_FINAL_CLASS : private flatbuffers::Ta struct TestSimpleTableWithEnumBuilder { flatbuffers::FlatBufferBuilder &fbb_; flatbuffers::uoffset_t start_; - void add_color(Color color) { fbb_.AddElement(4, static_cast(color), 2); } + void add_color(Color color) { fbb_.AddElement(TestSimpleTableWithEnum::VT_COLOR, static_cast(color), 2); } TestSimpleTableWithEnumBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb) { start_ = fbb_.StartTable(); } TestSimpleTableWithEnumBuilder &operator=(const TestSimpleTableWithEnumBuilder &); flatbuffers::Offset Finish() { @@ -126,18 +129,23 @@ inline flatbuffers::Offset CreateTestSimpleTableWithEnu } struct Stat FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table { - const flatbuffers::String *id() const { return GetPointer(4); } - flatbuffers::String *mutable_id() { return GetPointer(4); } - int64_t val() const { return GetField(6, 0); } - bool mutate_val(int64_t _val) { return SetField(6, _val); } - uint16_t count() const { return GetField(8, 0); } - bool mutate_count(uint16_t _count) { return SetField(8, _count); } + enum { + VT_ID = 4, + VT_VAL = 6, + VT_COUNT = 8, + }; + const flatbuffers::String *id() const { return GetPointer(VT_ID); } + flatbuffers::String *mutable_id() { return GetPointer(VT_ID); } + int64_t val() const { return GetField(VT_VAL, 0); } + bool mutate_val(int64_t _val) { return SetField(VT_VAL, _val); } + uint16_t count() const { return GetField(VT_COUNT, 0); } + bool mutate_count(uint16_t _count) { return SetField(VT_COUNT, _count); } bool Verify(flatbuffers::Verifier &verifier) const { return VerifyTableStart(verifier) && - VerifyField(verifier, 4 /* id */) && + VerifyField(verifier, VT_ID) && verifier.Verify(id()) && - VerifyField(verifier, 6 /* val */) && - VerifyField(verifier, 8 /* count */) && + VerifyField(verifier, VT_VAL) && + VerifyField(verifier, VT_COUNT) && verifier.EndTable(); } }; @@ -145,9 +153,9 @@ struct Stat FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table { struct StatBuilder { flatbuffers::FlatBufferBuilder &fbb_; flatbuffers::uoffset_t start_; - void add_id(flatbuffers::Offset id) { fbb_.AddOffset(4, id); } - void add_val(int64_t val) { fbb_.AddElement(6, val, 0); } - void add_count(uint16_t count) { fbb_.AddElement(8, count, 0); } + void add_id(flatbuffers::Offset id) { fbb_.AddOffset(Stat::VT_ID, id); } + void add_val(int64_t val) { fbb_.AddElement(Stat::VT_VAL, val, 0); } + void add_count(uint16_t count) { fbb_.AddElement(Stat::VT_COUNT, count, 0); } StatBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb) { start_ = fbb_.StartTable(); } StatBuilder &operator=(const StatBuilder &); flatbuffers::Offset Finish() { @@ -169,96 +177,122 @@ inline flatbuffers::Offset CreateStat(flatbuffers::FlatBufferBuilder &_fbb /// an example documentation comment: monster object struct Monster FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table { - const Vec3 *pos() const { return GetStruct(4); } - Vec3 *mutable_pos() { return GetStruct(4); } - int16_t mana() const { return GetField(6, 150); } - bool mutate_mana(int16_t _mana) { return SetField(6, _mana); } - int16_t hp() const { return GetField(8, 100); } - bool mutate_hp(int16_t _hp) { return SetField(8, _hp); } - const flatbuffers::String *name() const { return GetPointer(10); } - flatbuffers::String *mutable_name() { return GetPointer(10); } + enum { + VT_POS = 4, + VT_MANA = 6, + VT_HP = 8, + VT_NAME = 10, + VT_INVENTORY = 14, + VT_COLOR = 16, + VT_TEST_TYPE = 18, + VT_TEST = 20, + VT_TEST4 = 22, + VT_TESTARRAYOFSTRING = 24, + VT_TESTARRAYOFTABLES = 26, + VT_ENEMY = 28, + VT_TESTNESTEDFLATBUFFER = 30, + VT_TESTEMPTY = 32, + VT_TESTBOOL = 34, + VT_TESTHASHS32_FNV1 = 36, + VT_TESTHASHU32_FNV1 = 38, + VT_TESTHASHS64_FNV1 = 40, + VT_TESTHASHU64_FNV1 = 42, + VT_TESTHASHS32_FNV1A = 44, + VT_TESTHASHU32_FNV1A = 46, + VT_TESTHASHS64_FNV1A = 48, + VT_TESTHASHU64_FNV1A = 50, + VT_TESTARRAYOFBOOLS = 52, + }; + const Vec3 *pos() const { return GetStruct(VT_POS); } + Vec3 *mutable_pos() { return GetStruct(VT_POS); } + int16_t mana() const { return GetField(VT_MANA, 150); } + bool mutate_mana(int16_t _mana) { return SetField(VT_MANA, _mana); } + int16_t hp() const { return GetField(VT_HP, 100); } + bool mutate_hp(int16_t _hp) { return SetField(VT_HP, _hp); } + const flatbuffers::String *name() const { return GetPointer(VT_NAME); } + flatbuffers::String *mutable_name() { return GetPointer(VT_NAME); } bool KeyCompareLessThan(const Monster *o) const { return *name() < *o->name(); } int KeyCompareWithValue(const char *val) const { return strcmp(name()->c_str(), val); } - const flatbuffers::Vector *inventory() const { return GetPointer *>(14); } - flatbuffers::Vector *mutable_inventory() { return GetPointer *>(14); } - Color color() const { return static_cast(GetField(16, 8)); } - bool mutate_color(Color _color) { return SetField(16, static_cast(_color)); } - Any test_type() const { return static_cast(GetField(18, 0)); } - bool mutate_test_type(Any _test_type) { return SetField(18, static_cast(_test_type)); } - const void *test() const { return GetPointer(20); } - void *mutable_test() { return GetPointer(20); } - const flatbuffers::Vector *test4() const { return GetPointer *>(22); } - flatbuffers::Vector *mutable_test4() { return GetPointer *>(22); } - const flatbuffers::Vector> *testarrayofstring() const { return GetPointer> *>(24); } - flatbuffers::Vector> *mutable_testarrayofstring() { return GetPointer> *>(24); } + const flatbuffers::Vector *inventory() const { return GetPointer *>(VT_INVENTORY); } + flatbuffers::Vector *mutable_inventory() { return GetPointer *>(VT_INVENTORY); } + Color color() const { return static_cast(GetField(VT_COLOR, 8)); } + bool mutate_color(Color _color) { return SetField(VT_COLOR, static_cast(_color)); } + Any test_type() const { return static_cast(GetField(VT_TEST_TYPE, 0)); } + bool mutate_test_type(Any _test_type) { return SetField(VT_TEST_TYPE, static_cast(_test_type)); } + const void *test() const { return GetPointer(VT_TEST); } + void *mutable_test() { return GetPointer(VT_TEST); } + const flatbuffers::Vector *test4() const { return GetPointer *>(VT_TEST4); } + flatbuffers::Vector *mutable_test4() { return GetPointer *>(VT_TEST4); } + const flatbuffers::Vector> *testarrayofstring() const { return GetPointer> *>(VT_TESTARRAYOFSTRING); } + flatbuffers::Vector> *mutable_testarrayofstring() { return GetPointer> *>(VT_TESTARRAYOFSTRING); } /// an example documentation comment: this will end up in the generated code /// multiline too - const flatbuffers::Vector> *testarrayoftables() const { return GetPointer> *>(26); } - flatbuffers::Vector> *mutable_testarrayoftables() { return GetPointer> *>(26); } - const Monster *enemy() const { return GetPointer(28); } - Monster *mutable_enemy() { return GetPointer(28); } - const flatbuffers::Vector *testnestedflatbuffer() const { return GetPointer *>(30); } - flatbuffers::Vector *mutable_testnestedflatbuffer() { return GetPointer *>(30); } + const flatbuffers::Vector> *testarrayoftables() const { return GetPointer> *>(VT_TESTARRAYOFTABLES); } + flatbuffers::Vector> *mutable_testarrayoftables() { return GetPointer> *>(VT_TESTARRAYOFTABLES); } + const Monster *enemy() const { return GetPointer(VT_ENEMY); } + Monster *mutable_enemy() { return GetPointer(VT_ENEMY); } + const flatbuffers::Vector *testnestedflatbuffer() const { return GetPointer *>(VT_TESTNESTEDFLATBUFFER); } + flatbuffers::Vector *mutable_testnestedflatbuffer() { return GetPointer *>(VT_TESTNESTEDFLATBUFFER); } const MyGame::Example::Monster *testnestedflatbuffer_nested_root() const { return flatbuffers::GetRoot(testnestedflatbuffer()->Data()); } - const Stat *testempty() const { return GetPointer(32); } - Stat *mutable_testempty() { return GetPointer(32); } - bool testbool() const { return static_cast(GetField(34, 0)); } - bool mutate_testbool(bool _testbool) { return SetField(34, static_cast(_testbool)); } - int32_t testhashs32_fnv1() const { return GetField(36, 0); } - bool mutate_testhashs32_fnv1(int32_t _testhashs32_fnv1) { return SetField(36, _testhashs32_fnv1); } - uint32_t testhashu32_fnv1() const { return GetField(38, 0); } - bool mutate_testhashu32_fnv1(uint32_t _testhashu32_fnv1) { return SetField(38, _testhashu32_fnv1); } - int64_t testhashs64_fnv1() const { return GetField(40, 0); } - bool mutate_testhashs64_fnv1(int64_t _testhashs64_fnv1) { return SetField(40, _testhashs64_fnv1); } - uint64_t testhashu64_fnv1() const { return GetField(42, 0); } - bool mutate_testhashu64_fnv1(uint64_t _testhashu64_fnv1) { return SetField(42, _testhashu64_fnv1); } - int32_t testhashs32_fnv1a() const { return GetField(44, 0); } - bool mutate_testhashs32_fnv1a(int32_t _testhashs32_fnv1a) { return SetField(44, _testhashs32_fnv1a); } - uint32_t testhashu32_fnv1a() const { return GetField(46, 0); } - bool mutate_testhashu32_fnv1a(uint32_t _testhashu32_fnv1a) { return SetField(46, _testhashu32_fnv1a); } - int64_t testhashs64_fnv1a() const { return GetField(48, 0); } - bool mutate_testhashs64_fnv1a(int64_t _testhashs64_fnv1a) { return SetField(48, _testhashs64_fnv1a); } - uint64_t testhashu64_fnv1a() const { return GetField(50, 0); } - bool mutate_testhashu64_fnv1a(uint64_t _testhashu64_fnv1a) { return SetField(50, _testhashu64_fnv1a); } - const flatbuffers::Vector *testarrayofbools() const { return GetPointer *>(52); } - flatbuffers::Vector *mutable_testarrayofbools() { return GetPointer *>(52); } + const Stat *testempty() const { return GetPointer(VT_TESTEMPTY); } + Stat *mutable_testempty() { return GetPointer(VT_TESTEMPTY); } + bool testbool() const { return static_cast(GetField(VT_TESTBOOL, 0)); } + bool mutate_testbool(bool _testbool) { return SetField(VT_TESTBOOL, static_cast(_testbool)); } + int32_t testhashs32_fnv1() const { return GetField(VT_TESTHASHS32_FNV1, 0); } + bool mutate_testhashs32_fnv1(int32_t _testhashs32_fnv1) { return SetField(VT_TESTHASHS32_FNV1, _testhashs32_fnv1); } + uint32_t testhashu32_fnv1() const { return GetField(VT_TESTHASHU32_FNV1, 0); } + bool mutate_testhashu32_fnv1(uint32_t _testhashu32_fnv1) { return SetField(VT_TESTHASHU32_FNV1, _testhashu32_fnv1); } + int64_t testhashs64_fnv1() const { return GetField(VT_TESTHASHS64_FNV1, 0); } + bool mutate_testhashs64_fnv1(int64_t _testhashs64_fnv1) { return SetField(VT_TESTHASHS64_FNV1, _testhashs64_fnv1); } + uint64_t testhashu64_fnv1() const { return GetField(VT_TESTHASHU64_FNV1, 0); } + bool mutate_testhashu64_fnv1(uint64_t _testhashu64_fnv1) { return SetField(VT_TESTHASHU64_FNV1, _testhashu64_fnv1); } + int32_t testhashs32_fnv1a() const { return GetField(VT_TESTHASHS32_FNV1A, 0); } + bool mutate_testhashs32_fnv1a(int32_t _testhashs32_fnv1a) { return SetField(VT_TESTHASHS32_FNV1A, _testhashs32_fnv1a); } + uint32_t testhashu32_fnv1a() const { return GetField(VT_TESTHASHU32_FNV1A, 0); } + bool mutate_testhashu32_fnv1a(uint32_t _testhashu32_fnv1a) { return SetField(VT_TESTHASHU32_FNV1A, _testhashu32_fnv1a); } + int64_t testhashs64_fnv1a() const { return GetField(VT_TESTHASHS64_FNV1A, 0); } + bool mutate_testhashs64_fnv1a(int64_t _testhashs64_fnv1a) { return SetField(VT_TESTHASHS64_FNV1A, _testhashs64_fnv1a); } + uint64_t testhashu64_fnv1a() const { return GetField(VT_TESTHASHU64_FNV1A, 0); } + bool mutate_testhashu64_fnv1a(uint64_t _testhashu64_fnv1a) { return SetField(VT_TESTHASHU64_FNV1A, _testhashu64_fnv1a); } + const flatbuffers::Vector *testarrayofbools() const { return GetPointer *>(VT_TESTARRAYOFBOOLS); } + flatbuffers::Vector *mutable_testarrayofbools() { return GetPointer *>(VT_TESTARRAYOFBOOLS); } bool Verify(flatbuffers::Verifier &verifier) const { return VerifyTableStart(verifier) && - VerifyField(verifier, 4 /* pos */) && - VerifyField(verifier, 6 /* mana */) && - VerifyField(verifier, 8 /* hp */) && - VerifyFieldRequired(verifier, 10 /* name */) && + VerifyField(verifier, VT_POS) && + VerifyField(verifier, VT_MANA) && + VerifyField(verifier, VT_HP) && + VerifyFieldRequired(verifier, VT_NAME) && verifier.Verify(name()) && - VerifyField(verifier, 14 /* inventory */) && + VerifyField(verifier, VT_INVENTORY) && verifier.Verify(inventory()) && - VerifyField(verifier, 16 /* color */) && - VerifyField(verifier, 18 /* test_type */) && - VerifyField(verifier, 20 /* test */) && + VerifyField(verifier, VT_COLOR) && + VerifyField(verifier, VT_TEST_TYPE) && + VerifyField(verifier, VT_TEST) && VerifyAny(verifier, test(), test_type()) && - VerifyField(verifier, 22 /* test4 */) && + VerifyField(verifier, VT_TEST4) && verifier.Verify(test4()) && - VerifyField(verifier, 24 /* testarrayofstring */) && + VerifyField(verifier, VT_TESTARRAYOFSTRING) && verifier.Verify(testarrayofstring()) && verifier.VerifyVectorOfStrings(testarrayofstring()) && - VerifyField(verifier, 26 /* testarrayoftables */) && + VerifyField(verifier, VT_TESTARRAYOFTABLES) && verifier.Verify(testarrayoftables()) && verifier.VerifyVectorOfTables(testarrayoftables()) && - VerifyField(verifier, 28 /* enemy */) && + VerifyField(verifier, VT_ENEMY) && verifier.VerifyTable(enemy()) && - VerifyField(verifier, 30 /* testnestedflatbuffer */) && + VerifyField(verifier, VT_TESTNESTEDFLATBUFFER) && verifier.Verify(testnestedflatbuffer()) && - VerifyField(verifier, 32 /* testempty */) && + VerifyField(verifier, VT_TESTEMPTY) && verifier.VerifyTable(testempty()) && - VerifyField(verifier, 34 /* testbool */) && - VerifyField(verifier, 36 /* testhashs32_fnv1 */) && - VerifyField(verifier, 38 /* testhashu32_fnv1 */) && - VerifyField(verifier, 40 /* testhashs64_fnv1 */) && - VerifyField(verifier, 42 /* testhashu64_fnv1 */) && - VerifyField(verifier, 44 /* testhashs32_fnv1a */) && - VerifyField(verifier, 46 /* testhashu32_fnv1a */) && - VerifyField(verifier, 48 /* testhashs64_fnv1a */) && - VerifyField(verifier, 50 /* testhashu64_fnv1a */) && - VerifyField(verifier, 52 /* testarrayofbools */) && + VerifyField(verifier, VT_TESTBOOL) && + VerifyField(verifier, VT_TESTHASHS32_FNV1) && + VerifyField(verifier, VT_TESTHASHU32_FNV1) && + VerifyField(verifier, VT_TESTHASHS64_FNV1) && + VerifyField(verifier, VT_TESTHASHU64_FNV1) && + VerifyField(verifier, VT_TESTHASHS32_FNV1A) && + VerifyField(verifier, VT_TESTHASHU32_FNV1A) && + VerifyField(verifier, VT_TESTHASHS64_FNV1A) && + VerifyField(verifier, VT_TESTHASHU64_FNV1A) && + VerifyField(verifier, VT_TESTARRAYOFBOOLS) && verifier.Verify(testarrayofbools()) && verifier.EndTable(); } @@ -267,35 +301,35 @@ struct Monster FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table { struct MonsterBuilder { flatbuffers::FlatBufferBuilder &fbb_; flatbuffers::uoffset_t start_; - void add_pos(const Vec3 *pos) { fbb_.AddStruct(4, pos); } - void add_mana(int16_t mana) { fbb_.AddElement(6, mana, 150); } - void add_hp(int16_t hp) { fbb_.AddElement(8, hp, 100); } - void add_name(flatbuffers::Offset name) { fbb_.AddOffset(10, name); } - void add_inventory(flatbuffers::Offset> inventory) { fbb_.AddOffset(14, inventory); } - void add_color(Color color) { fbb_.AddElement(16, static_cast(color), 8); } - void add_test_type(Any test_type) { fbb_.AddElement(18, static_cast(test_type), 0); } - void add_test(flatbuffers::Offset test) { fbb_.AddOffset(20, test); } - void add_test4(flatbuffers::Offset> test4) { fbb_.AddOffset(22, test4); } - void add_testarrayofstring(flatbuffers::Offset>> testarrayofstring) { fbb_.AddOffset(24, testarrayofstring); } - void add_testarrayoftables(flatbuffers::Offset>> testarrayoftables) { fbb_.AddOffset(26, testarrayoftables); } - void add_enemy(flatbuffers::Offset enemy) { fbb_.AddOffset(28, enemy); } - void add_testnestedflatbuffer(flatbuffers::Offset> testnestedflatbuffer) { fbb_.AddOffset(30, testnestedflatbuffer); } - void add_testempty(flatbuffers::Offset testempty) { fbb_.AddOffset(32, testempty); } - void add_testbool(bool testbool) { fbb_.AddElement(34, static_cast(testbool), 0); } - void add_testhashs32_fnv1(int32_t testhashs32_fnv1) { fbb_.AddElement(36, testhashs32_fnv1, 0); } - void add_testhashu32_fnv1(uint32_t testhashu32_fnv1) { fbb_.AddElement(38, testhashu32_fnv1, 0); } - void add_testhashs64_fnv1(int64_t testhashs64_fnv1) { fbb_.AddElement(40, testhashs64_fnv1, 0); } - void add_testhashu64_fnv1(uint64_t testhashu64_fnv1) { fbb_.AddElement(42, testhashu64_fnv1, 0); } - void add_testhashs32_fnv1a(int32_t testhashs32_fnv1a) { fbb_.AddElement(44, testhashs32_fnv1a, 0); } - void add_testhashu32_fnv1a(uint32_t testhashu32_fnv1a) { fbb_.AddElement(46, testhashu32_fnv1a, 0); } - void add_testhashs64_fnv1a(int64_t testhashs64_fnv1a) { fbb_.AddElement(48, testhashs64_fnv1a, 0); } - void add_testhashu64_fnv1a(uint64_t testhashu64_fnv1a) { fbb_.AddElement(50, testhashu64_fnv1a, 0); } - void add_testarrayofbools(flatbuffers::Offset> testarrayofbools) { fbb_.AddOffset(52, testarrayofbools); } + void add_pos(const Vec3 *pos) { fbb_.AddStruct(Monster::VT_POS, pos); } + void add_mana(int16_t mana) { fbb_.AddElement(Monster::VT_MANA, mana, 150); } + void add_hp(int16_t hp) { fbb_.AddElement(Monster::VT_HP, hp, 100); } + void add_name(flatbuffers::Offset name) { fbb_.AddOffset(Monster::VT_NAME, name); } + void add_inventory(flatbuffers::Offset> inventory) { fbb_.AddOffset(Monster::VT_INVENTORY, inventory); } + void add_color(Color color) { fbb_.AddElement(Monster::VT_COLOR, static_cast(color), 8); } + void add_test_type(Any test_type) { fbb_.AddElement(Monster::VT_TEST_TYPE, static_cast(test_type), 0); } + void add_test(flatbuffers::Offset test) { fbb_.AddOffset(Monster::VT_TEST, test); } + void add_test4(flatbuffers::Offset> test4) { fbb_.AddOffset(Monster::VT_TEST4, test4); } + void add_testarrayofstring(flatbuffers::Offset>> testarrayofstring) { fbb_.AddOffset(Monster::VT_TESTARRAYOFSTRING, testarrayofstring); } + void add_testarrayoftables(flatbuffers::Offset>> testarrayoftables) { fbb_.AddOffset(Monster::VT_TESTARRAYOFTABLES, testarrayoftables); } + void add_enemy(flatbuffers::Offset enemy) { fbb_.AddOffset(Monster::VT_ENEMY, enemy); } + void add_testnestedflatbuffer(flatbuffers::Offset> testnestedflatbuffer) { fbb_.AddOffset(Monster::VT_TESTNESTEDFLATBUFFER, testnestedflatbuffer); } + void add_testempty(flatbuffers::Offset testempty) { fbb_.AddOffset(Monster::VT_TESTEMPTY, testempty); } + void add_testbool(bool testbool) { fbb_.AddElement(Monster::VT_TESTBOOL, static_cast(testbool), 0); } + void add_testhashs32_fnv1(int32_t testhashs32_fnv1) { fbb_.AddElement(Monster::VT_TESTHASHS32_FNV1, testhashs32_fnv1, 0); } + void add_testhashu32_fnv1(uint32_t testhashu32_fnv1) { fbb_.AddElement(Monster::VT_TESTHASHU32_FNV1, testhashu32_fnv1, 0); } + void add_testhashs64_fnv1(int64_t testhashs64_fnv1) { fbb_.AddElement(Monster::VT_TESTHASHS64_FNV1, testhashs64_fnv1, 0); } + void add_testhashu64_fnv1(uint64_t testhashu64_fnv1) { fbb_.AddElement(Monster::VT_TESTHASHU64_FNV1, testhashu64_fnv1, 0); } + void add_testhashs32_fnv1a(int32_t testhashs32_fnv1a) { fbb_.AddElement(Monster::VT_TESTHASHS32_FNV1A, testhashs32_fnv1a, 0); } + void add_testhashu32_fnv1a(uint32_t testhashu32_fnv1a) { fbb_.AddElement(Monster::VT_TESTHASHU32_FNV1A, testhashu32_fnv1a, 0); } + void add_testhashs64_fnv1a(int64_t testhashs64_fnv1a) { fbb_.AddElement(Monster::VT_TESTHASHS64_FNV1A, testhashs64_fnv1a, 0); } + void add_testhashu64_fnv1a(uint64_t testhashu64_fnv1a) { fbb_.AddElement(Monster::VT_TESTHASHU64_FNV1A, testhashu64_fnv1a, 0); } + void add_testarrayofbools(flatbuffers::Offset> testarrayofbools) { fbb_.AddOffset(Monster::VT_TESTARRAYOFBOOLS, testarrayofbools); } MonsterBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb) { start_ = fbb_.StartTable(); } MonsterBuilder &operator=(const MonsterBuilder &); flatbuffers::Offset Finish() { auto o = flatbuffers::Offset(fbb_.EndTable(start_, 25)); - fbb_.Required(o, 10); // name + fbb_.Required(o, Monster::VT_NAME); // name return o; } };