mirror of
https://github.com/google/flatbuffers.git
synced 2026-06-29 17:12:01 +00:00
[idl_parser] Mark typefield as deprecated (#5958)
* Mark typefield as deprecated * Add UnionDeprecation Test. * Update to use evolution schema instead. * Use --scoped-enums to compile.
This commit is contained in:
@@ -878,6 +878,11 @@ CheckedError Parser::ParseField(StructDef &struct_def) {
|
|||||||
val->constant = NumToString(id - 1);
|
val->constant = NumToString(id - 1);
|
||||||
typefield->attributes.Add("id", val);
|
typefield->attributes.Add("id", val);
|
||||||
}
|
}
|
||||||
|
// if this field is a union that is deprecated,
|
||||||
|
// the automatically added type field should be deprecated as well
|
||||||
|
if (field->deprecated) {
|
||||||
|
typefield->deprecated = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
EXPECT(';');
|
EXPECT(';');
|
||||||
|
|||||||
@@ -34,6 +34,7 @@ table Root {
|
|||||||
g:[int];
|
g:[int];
|
||||||
h:[TableB];
|
h:[TableB];
|
||||||
i:int = 1234;
|
i:int = 1234;
|
||||||
|
j:Union;
|
||||||
}
|
}
|
||||||
|
|
||||||
root_type Root;
|
root_type Root;
|
||||||
@@ -22,5 +22,8 @@
|
|||||||
{
|
{
|
||||||
"a": 459
|
"a": 459
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"j": {
|
||||||
|
"a": 984
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -10,12 +10,15 @@ namespace Evolution {
|
|||||||
namespace V1 {
|
namespace V1 {
|
||||||
|
|
||||||
struct TableA;
|
struct TableA;
|
||||||
|
struct TableABuilder;
|
||||||
|
|
||||||
struct TableB;
|
struct TableB;
|
||||||
|
struct TableBBuilder;
|
||||||
|
|
||||||
struct Struct;
|
struct Struct;
|
||||||
|
|
||||||
struct Root;
|
struct Root;
|
||||||
|
struct RootBuilder;
|
||||||
|
|
||||||
enum class Enum : int8_t {
|
enum class Enum : int8_t {
|
||||||
King = 0,
|
King = 0,
|
||||||
@@ -42,7 +45,7 @@ inline const char * const *EnumNamesEnum() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline const char *EnumNameEnum(Enum e) {
|
inline const char *EnumNameEnum(Enum e) {
|
||||||
if (e < Enum::King || e > Enum::Queen) return "";
|
if (flatbuffers::IsOutRange(e, Enum::King, Enum::Queen)) return "";
|
||||||
const size_t index = static_cast<size_t>(e);
|
const size_t index = static_cast<size_t>(e);
|
||||||
return EnumNamesEnum()[index];
|
return EnumNamesEnum()[index];
|
||||||
}
|
}
|
||||||
@@ -75,7 +78,7 @@ inline const char * const *EnumNamesUnion() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline const char *EnumNameUnion(Union e) {
|
inline const char *EnumNameUnion(Union e) {
|
||||||
if (e < Union::NONE || e > Union::TableB) return "";
|
if (flatbuffers::IsOutRange(e, Union::NONE, Union::TableB)) return "";
|
||||||
const size_t index = static_cast<size_t>(e);
|
const size_t index = static_cast<size_t>(e);
|
||||||
return EnumNamesUnion()[index];
|
return EnumNamesUnion()[index];
|
||||||
}
|
}
|
||||||
@@ -102,14 +105,16 @@ FLATBUFFERS_MANUALLY_ALIGNED_STRUCT(8) Struct FLATBUFFERS_FINAL_CLASS {
|
|||||||
double b_;
|
double b_;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Struct() {
|
Struct()
|
||||||
memset(static_cast<void *>(this), 0, sizeof(Struct));
|
: a_(0),
|
||||||
|
padding0__(0),
|
||||||
|
b_(0) {
|
||||||
|
(void)padding0__;
|
||||||
}
|
}
|
||||||
Struct(int32_t _a, double _b)
|
Struct(int32_t _a, double _b)
|
||||||
: a_(flatbuffers::EndianScalar(_a)),
|
: a_(flatbuffers::EndianScalar(_a)),
|
||||||
padding0__(0),
|
padding0__(0),
|
||||||
b_(flatbuffers::EndianScalar(_b)) {
|
b_(flatbuffers::EndianScalar(_b)) {
|
||||||
(void)padding0__;
|
|
||||||
}
|
}
|
||||||
int32_t a() const {
|
int32_t a() const {
|
||||||
return flatbuffers::EndianScalar(a_);
|
return flatbuffers::EndianScalar(a_);
|
||||||
@@ -121,6 +126,7 @@ FLATBUFFERS_MANUALLY_ALIGNED_STRUCT(8) Struct FLATBUFFERS_FINAL_CLASS {
|
|||||||
FLATBUFFERS_STRUCT_END(Struct, 16);
|
FLATBUFFERS_STRUCT_END(Struct, 16);
|
||||||
|
|
||||||
struct TableA FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct TableA FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
|
typedef TableABuilder Builder;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_A = 4,
|
VT_A = 4,
|
||||||
VT_B = 6
|
VT_B = 6
|
||||||
@@ -140,6 +146,7 @@ struct TableA FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct TableABuilder {
|
struct TableABuilder {
|
||||||
|
typedef TableA Table;
|
||||||
flatbuffers::FlatBufferBuilder &fbb_;
|
flatbuffers::FlatBufferBuilder &fbb_;
|
||||||
flatbuffers::uoffset_t start_;
|
flatbuffers::uoffset_t start_;
|
||||||
void add_a(float a) {
|
void add_a(float a) {
|
||||||
@@ -170,6 +177,7 @@ inline flatbuffers::Offset<TableA> CreateTableA(
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct TableB FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct TableB FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
|
typedef TableBBuilder Builder;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_A = 4
|
VT_A = 4
|
||||||
};
|
};
|
||||||
@@ -184,6 +192,7 @@ struct TableB FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct TableBBuilder {
|
struct TableBBuilder {
|
||||||
|
typedef TableB Table;
|
||||||
flatbuffers::FlatBufferBuilder &fbb_;
|
flatbuffers::FlatBufferBuilder &fbb_;
|
||||||
flatbuffers::uoffset_t start_;
|
flatbuffers::uoffset_t start_;
|
||||||
void add_a(int32_t a) {
|
void add_a(int32_t a) {
|
||||||
@@ -209,6 +218,7 @@ inline flatbuffers::Offset<TableB> CreateTableB(
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct Root FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct Root FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
|
typedef RootBuilder Builder;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_A = 4,
|
VT_A = 4,
|
||||||
VT_B = 6,
|
VT_B = 6,
|
||||||
@@ -219,7 +229,9 @@ struct Root FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
|||||||
VT_F = 16,
|
VT_F = 16,
|
||||||
VT_G = 18,
|
VT_G = 18,
|
||||||
VT_H = 20,
|
VT_H = 20,
|
||||||
VT_I = 22
|
VT_I = 22,
|
||||||
|
VT_J_TYPE = 24,
|
||||||
|
VT_J = 26
|
||||||
};
|
};
|
||||||
int32_t a() const {
|
int32_t a() const {
|
||||||
return GetField<int32_t>(VT_A, 0);
|
return GetField<int32_t>(VT_A, 0);
|
||||||
@@ -258,6 +270,19 @@ struct Root FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
|||||||
int32_t i() const {
|
int32_t i() const {
|
||||||
return GetField<int32_t>(VT_I, 1234);
|
return GetField<int32_t>(VT_I, 1234);
|
||||||
}
|
}
|
||||||
|
Evolution::V1::Union j_type() const {
|
||||||
|
return static_cast<Evolution::V1::Union>(GetField<uint8_t>(VT_J_TYPE, 0));
|
||||||
|
}
|
||||||
|
const void *j() const {
|
||||||
|
return GetPointer<const void *>(VT_J);
|
||||||
|
}
|
||||||
|
template<typename T> const T *j_as() const;
|
||||||
|
const Evolution::V1::TableA *j_as_TableA() const {
|
||||||
|
return j_type() == Evolution::V1::Union::TableA ? static_cast<const Evolution::V1::TableA *>(j()) : nullptr;
|
||||||
|
}
|
||||||
|
const Evolution::V1::TableB *j_as_TableB() const {
|
||||||
|
return j_type() == Evolution::V1::Union::TableB ? static_cast<const Evolution::V1::TableB *>(j()) : nullptr;
|
||||||
|
}
|
||||||
bool Verify(flatbuffers::Verifier &verifier) const {
|
bool Verify(flatbuffers::Verifier &verifier) const {
|
||||||
return VerifyTableStart(verifier) &&
|
return VerifyTableStart(verifier) &&
|
||||||
VerifyField<int32_t>(verifier, VT_A) &&
|
VerifyField<int32_t>(verifier, VT_A) &&
|
||||||
@@ -275,6 +300,9 @@ struct Root FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
|||||||
verifier.VerifyVector(h()) &&
|
verifier.VerifyVector(h()) &&
|
||||||
verifier.VerifyVectorOfTables(h()) &&
|
verifier.VerifyVectorOfTables(h()) &&
|
||||||
VerifyField<int32_t>(verifier, VT_I) &&
|
VerifyField<int32_t>(verifier, VT_I) &&
|
||||||
|
VerifyField<uint8_t>(verifier, VT_J_TYPE) &&
|
||||||
|
VerifyOffset(verifier, VT_J) &&
|
||||||
|
VerifyUnion(verifier, j(), j_type()) &&
|
||||||
verifier.EndTable();
|
verifier.EndTable();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@@ -287,7 +315,16 @@ template<> inline const Evolution::V1::TableB *Root::c_as<Evolution::V1::TableB>
|
|||||||
return c_as_TableB();
|
return c_as_TableB();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template<> inline const Evolution::V1::TableA *Root::j_as<Evolution::V1::TableA>() const {
|
||||||
|
return j_as_TableA();
|
||||||
|
}
|
||||||
|
|
||||||
|
template<> inline const Evolution::V1::TableB *Root::j_as<Evolution::V1::TableB>() const {
|
||||||
|
return j_as_TableB();
|
||||||
|
}
|
||||||
|
|
||||||
struct RootBuilder {
|
struct RootBuilder {
|
||||||
|
typedef Root Table;
|
||||||
flatbuffers::FlatBufferBuilder &fbb_;
|
flatbuffers::FlatBufferBuilder &fbb_;
|
||||||
flatbuffers::uoffset_t start_;
|
flatbuffers::uoffset_t start_;
|
||||||
void add_a(int32_t a) {
|
void add_a(int32_t a) {
|
||||||
@@ -320,6 +357,12 @@ struct RootBuilder {
|
|||||||
void add_i(int32_t i) {
|
void add_i(int32_t i) {
|
||||||
fbb_.AddElement<int32_t>(Root::VT_I, i, 1234);
|
fbb_.AddElement<int32_t>(Root::VT_I, i, 1234);
|
||||||
}
|
}
|
||||||
|
void add_j_type(Evolution::V1::Union j_type) {
|
||||||
|
fbb_.AddElement<uint8_t>(Root::VT_J_TYPE, static_cast<uint8_t>(j_type), 0);
|
||||||
|
}
|
||||||
|
void add_j(flatbuffers::Offset<void> j) {
|
||||||
|
fbb_.AddOffset(Root::VT_J, j);
|
||||||
|
}
|
||||||
explicit RootBuilder(flatbuffers::FlatBufferBuilder &_fbb)
|
explicit RootBuilder(flatbuffers::FlatBufferBuilder &_fbb)
|
||||||
: fbb_(_fbb) {
|
: fbb_(_fbb) {
|
||||||
start_ = fbb_.StartTable();
|
start_ = fbb_.StartTable();
|
||||||
@@ -342,8 +385,11 @@ inline flatbuffers::Offset<Root> CreateRoot(
|
|||||||
const Evolution::V1::Struct *f = 0,
|
const Evolution::V1::Struct *f = 0,
|
||||||
flatbuffers::Offset<flatbuffers::Vector<int32_t>> g = 0,
|
flatbuffers::Offset<flatbuffers::Vector<int32_t>> g = 0,
|
||||||
flatbuffers::Offset<flatbuffers::Vector<flatbuffers::Offset<Evolution::V1::TableB>>> h = 0,
|
flatbuffers::Offset<flatbuffers::Vector<flatbuffers::Offset<Evolution::V1::TableB>>> h = 0,
|
||||||
int32_t i = 1234) {
|
int32_t i = 1234,
|
||||||
|
Evolution::V1::Union j_type = Evolution::V1::Union::NONE,
|
||||||
|
flatbuffers::Offset<void> j = 0) {
|
||||||
RootBuilder builder_(_fbb);
|
RootBuilder builder_(_fbb);
|
||||||
|
builder_.add_j(j);
|
||||||
builder_.add_i(i);
|
builder_.add_i(i);
|
||||||
builder_.add_h(h);
|
builder_.add_h(h);
|
||||||
builder_.add_g(g);
|
builder_.add_g(g);
|
||||||
@@ -351,6 +397,7 @@ inline flatbuffers::Offset<Root> CreateRoot(
|
|||||||
builder_.add_e(e);
|
builder_.add_e(e);
|
||||||
builder_.add_c(c);
|
builder_.add_c(c);
|
||||||
builder_.add_a(a);
|
builder_.add_a(a);
|
||||||
|
builder_.add_j_type(j_type);
|
||||||
builder_.add_d(d);
|
builder_.add_d(d);
|
||||||
builder_.add_c_type(c_type);
|
builder_.add_c_type(c_type);
|
||||||
builder_.add_b(b);
|
builder_.add_b(b);
|
||||||
@@ -368,7 +415,9 @@ inline flatbuffers::Offset<Root> CreateRootDirect(
|
|||||||
const Evolution::V1::Struct *f = 0,
|
const Evolution::V1::Struct *f = 0,
|
||||||
const std::vector<int32_t> *g = nullptr,
|
const std::vector<int32_t> *g = nullptr,
|
||||||
const std::vector<flatbuffers::Offset<Evolution::V1::TableB>> *h = nullptr,
|
const std::vector<flatbuffers::Offset<Evolution::V1::TableB>> *h = nullptr,
|
||||||
int32_t i = 1234) {
|
int32_t i = 1234,
|
||||||
|
Evolution::V1::Union j_type = Evolution::V1::Union::NONE,
|
||||||
|
flatbuffers::Offset<void> j = 0) {
|
||||||
auto g__ = g ? _fbb.CreateVector<int32_t>(*g) : 0;
|
auto g__ = g ? _fbb.CreateVector<int32_t>(*g) : 0;
|
||||||
auto h__ = h ? _fbb.CreateVector<flatbuffers::Offset<Evolution::V1::TableB>>(*h) : 0;
|
auto h__ = h ? _fbb.CreateVector<flatbuffers::Offset<Evolution::V1::TableB>>(*h) : 0;
|
||||||
return Evolution::V1::CreateRoot(
|
return Evolution::V1::CreateRoot(
|
||||||
@@ -382,7 +431,9 @@ inline flatbuffers::Offset<Root> CreateRootDirect(
|
|||||||
f,
|
f,
|
||||||
g__,
|
g__,
|
||||||
h__,
|
h__,
|
||||||
i);
|
i,
|
||||||
|
j_type,
|
||||||
|
j);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool VerifyUnion(flatbuffers::Verifier &verifier, const void *obj, Union type) {
|
inline bool VerifyUnion(flatbuffers::Verifier &verifier, const void *obj, Union type) {
|
||||||
|
|||||||
@@ -43,8 +43,9 @@ table Root {
|
|||||||
g:[int];
|
g:[int];
|
||||||
h:[TableB];
|
h:[TableB];
|
||||||
i:uint = 1234;
|
i:uint = 1234;
|
||||||
j:TableC; // new in v2
|
j:Union (deprecated); // deprecated in v2
|
||||||
k:uint8 = 56; // new in v2
|
k:TableC; // new in v2
|
||||||
|
l:uint8 = 56; // new in v2
|
||||||
}
|
}
|
||||||
|
|
||||||
root_type Root;
|
root_type Root;
|
||||||
@@ -27,7 +27,7 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"i": 4321,
|
"i": 4321,
|
||||||
"j": {
|
"k": {
|
||||||
"a": 9874.342,
|
"a": 9874.342,
|
||||||
"b": "more please"
|
"b": "more please"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -10,14 +10,18 @@ namespace Evolution {
|
|||||||
namespace V2 {
|
namespace V2 {
|
||||||
|
|
||||||
struct TableA;
|
struct TableA;
|
||||||
|
struct TableABuilder;
|
||||||
|
|
||||||
struct TableB;
|
struct TableB;
|
||||||
|
struct TableBBuilder;
|
||||||
|
|
||||||
struct TableC;
|
struct TableC;
|
||||||
|
struct TableCBuilder;
|
||||||
|
|
||||||
struct Struct;
|
struct Struct;
|
||||||
|
|
||||||
struct Root;
|
struct Root;
|
||||||
|
struct RootBuilder;
|
||||||
|
|
||||||
enum class Enum : int8_t {
|
enum class Enum : int8_t {
|
||||||
King = 0,
|
King = 0,
|
||||||
@@ -50,7 +54,7 @@ inline const char * const *EnumNamesEnum() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline const char *EnumNameEnum(Enum e) {
|
inline const char *EnumNameEnum(Enum e) {
|
||||||
if (e < Enum::King || e > Enum::Bishop) return "";
|
if (flatbuffers::IsOutRange(e, Enum::King, Enum::Bishop)) return "";
|
||||||
const size_t index = static_cast<size_t>(e);
|
const size_t index = static_cast<size_t>(e);
|
||||||
return EnumNamesEnum()[index];
|
return EnumNamesEnum()[index];
|
||||||
}
|
}
|
||||||
@@ -86,7 +90,7 @@ inline const char * const *EnumNamesUnion() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline const char *EnumNameUnion(Union e) {
|
inline const char *EnumNameUnion(Union e) {
|
||||||
if (e < Union::NONE || e > Union::TableC) return "";
|
if (flatbuffers::IsOutRange(e, Union::NONE, Union::TableC)) return "";
|
||||||
const size_t index = static_cast<size_t>(e);
|
const size_t index = static_cast<size_t>(e);
|
||||||
return EnumNamesUnion()[index];
|
return EnumNamesUnion()[index];
|
||||||
}
|
}
|
||||||
@@ -117,14 +121,16 @@ FLATBUFFERS_MANUALLY_ALIGNED_STRUCT(8) Struct FLATBUFFERS_FINAL_CLASS {
|
|||||||
double b_;
|
double b_;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Struct() {
|
Struct()
|
||||||
memset(static_cast<void *>(this), 0, sizeof(Struct));
|
: a_(0),
|
||||||
|
padding0__(0),
|
||||||
|
b_(0) {
|
||||||
|
(void)padding0__;
|
||||||
}
|
}
|
||||||
Struct(int32_t _a, double _b)
|
Struct(int32_t _a, double _b)
|
||||||
: a_(flatbuffers::EndianScalar(_a)),
|
: a_(flatbuffers::EndianScalar(_a)),
|
||||||
padding0__(0),
|
padding0__(0),
|
||||||
b_(flatbuffers::EndianScalar(_b)) {
|
b_(flatbuffers::EndianScalar(_b)) {
|
||||||
(void)padding0__;
|
|
||||||
}
|
}
|
||||||
int32_t a() const {
|
int32_t a() const {
|
||||||
return flatbuffers::EndianScalar(a_);
|
return flatbuffers::EndianScalar(a_);
|
||||||
@@ -136,6 +142,7 @@ FLATBUFFERS_MANUALLY_ALIGNED_STRUCT(8) Struct FLATBUFFERS_FINAL_CLASS {
|
|||||||
FLATBUFFERS_STRUCT_END(Struct, 16);
|
FLATBUFFERS_STRUCT_END(Struct, 16);
|
||||||
|
|
||||||
struct TableA FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct TableA FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
|
typedef TableABuilder Builder;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_A = 4,
|
VT_A = 4,
|
||||||
VT_B = 6,
|
VT_B = 6,
|
||||||
@@ -161,6 +168,7 @@ struct TableA FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct TableABuilder {
|
struct TableABuilder {
|
||||||
|
typedef TableA Table;
|
||||||
flatbuffers::FlatBufferBuilder &fbb_;
|
flatbuffers::FlatBufferBuilder &fbb_;
|
||||||
flatbuffers::uoffset_t start_;
|
flatbuffers::uoffset_t start_;
|
||||||
void add_a(float a) {
|
void add_a(float a) {
|
||||||
@@ -209,6 +217,7 @@ inline flatbuffers::Offset<TableA> CreateTableADirect(
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct TableB FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct TableB FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
|
typedef TableBBuilder Builder;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_A = 4
|
VT_A = 4
|
||||||
};
|
};
|
||||||
@@ -223,6 +232,7 @@ struct TableB FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct TableBBuilder {
|
struct TableBBuilder {
|
||||||
|
typedef TableB Table;
|
||||||
flatbuffers::FlatBufferBuilder &fbb_;
|
flatbuffers::FlatBufferBuilder &fbb_;
|
||||||
flatbuffers::uoffset_t start_;
|
flatbuffers::uoffset_t start_;
|
||||||
void add_a(int32_t a) {
|
void add_a(int32_t a) {
|
||||||
@@ -248,6 +258,7 @@ inline flatbuffers::Offset<TableB> CreateTableB(
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct TableC FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct TableC FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
|
typedef TableCBuilder Builder;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_A = 4,
|
VT_A = 4,
|
||||||
VT_B = 6
|
VT_B = 6
|
||||||
@@ -268,6 +279,7 @@ struct TableC FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct TableCBuilder {
|
struct TableCBuilder {
|
||||||
|
typedef TableC Table;
|
||||||
flatbuffers::FlatBufferBuilder &fbb_;
|
flatbuffers::FlatBufferBuilder &fbb_;
|
||||||
flatbuffers::uoffset_t start_;
|
flatbuffers::uoffset_t start_;
|
||||||
void add_a(double a) {
|
void add_a(double a) {
|
||||||
@@ -309,6 +321,7 @@ inline flatbuffers::Offset<TableC> CreateTableCDirect(
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct Root FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct Root FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
|
typedef RootBuilder Builder;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_B = 6,
|
VT_B = 6,
|
||||||
VT_C_TYPE = 8,
|
VT_C_TYPE = 8,
|
||||||
@@ -319,8 +332,8 @@ struct Root FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
|||||||
VT_G = 18,
|
VT_G = 18,
|
||||||
VT_H = 20,
|
VT_H = 20,
|
||||||
VT_I = 22,
|
VT_I = 22,
|
||||||
VT_J = 24,
|
VT_K = 28,
|
||||||
VT_K = 26
|
VT_L = 30
|
||||||
};
|
};
|
||||||
bool b() const {
|
bool b() const {
|
||||||
return GetField<uint8_t>(VT_B, 0) != 0;
|
return GetField<uint8_t>(VT_B, 0) != 0;
|
||||||
@@ -359,11 +372,11 @@ struct Root FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
|||||||
uint32_t i() const {
|
uint32_t i() const {
|
||||||
return GetField<uint32_t>(VT_I, 1234);
|
return GetField<uint32_t>(VT_I, 1234);
|
||||||
}
|
}
|
||||||
const Evolution::V2::TableC *j() const {
|
const Evolution::V2::TableC *k() const {
|
||||||
return GetPointer<const Evolution::V2::TableC *>(VT_J);
|
return GetPointer<const Evolution::V2::TableC *>(VT_K);
|
||||||
}
|
}
|
||||||
uint8_t k() const {
|
uint8_t l() const {
|
||||||
return GetField<uint8_t>(VT_K, 56);
|
return GetField<uint8_t>(VT_L, 56);
|
||||||
}
|
}
|
||||||
bool Verify(flatbuffers::Verifier &verifier) const {
|
bool Verify(flatbuffers::Verifier &verifier) const {
|
||||||
return VerifyTableStart(verifier) &&
|
return VerifyTableStart(verifier) &&
|
||||||
@@ -381,9 +394,9 @@ struct Root FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
|||||||
verifier.VerifyVector(h()) &&
|
verifier.VerifyVector(h()) &&
|
||||||
verifier.VerifyVectorOfTables(h()) &&
|
verifier.VerifyVectorOfTables(h()) &&
|
||||||
VerifyField<uint32_t>(verifier, VT_I) &&
|
VerifyField<uint32_t>(verifier, VT_I) &&
|
||||||
VerifyOffset(verifier, VT_J) &&
|
VerifyOffset(verifier, VT_K) &&
|
||||||
verifier.VerifyTable(j()) &&
|
verifier.VerifyTable(k()) &&
|
||||||
VerifyField<uint8_t>(verifier, VT_K) &&
|
VerifyField<uint8_t>(verifier, VT_L) &&
|
||||||
verifier.EndTable();
|
verifier.EndTable();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@@ -401,6 +414,7 @@ template<> inline const Evolution::V2::TableC *Root::c_as<Evolution::V2::TableC>
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct RootBuilder {
|
struct RootBuilder {
|
||||||
|
typedef Root Table;
|
||||||
flatbuffers::FlatBufferBuilder &fbb_;
|
flatbuffers::FlatBufferBuilder &fbb_;
|
||||||
flatbuffers::uoffset_t start_;
|
flatbuffers::uoffset_t start_;
|
||||||
void add_b(bool b) {
|
void add_b(bool b) {
|
||||||
@@ -430,11 +444,11 @@ struct RootBuilder {
|
|||||||
void add_i(uint32_t i) {
|
void add_i(uint32_t i) {
|
||||||
fbb_.AddElement<uint32_t>(Root::VT_I, i, 1234);
|
fbb_.AddElement<uint32_t>(Root::VT_I, i, 1234);
|
||||||
}
|
}
|
||||||
void add_j(flatbuffers::Offset<Evolution::V2::TableC> j) {
|
void add_k(flatbuffers::Offset<Evolution::V2::TableC> k) {
|
||||||
fbb_.AddOffset(Root::VT_J, j);
|
fbb_.AddOffset(Root::VT_K, k);
|
||||||
}
|
}
|
||||||
void add_k(uint8_t k) {
|
void add_l(uint8_t l) {
|
||||||
fbb_.AddElement<uint8_t>(Root::VT_K, k, 56);
|
fbb_.AddElement<uint8_t>(Root::VT_L, l, 56);
|
||||||
}
|
}
|
||||||
explicit RootBuilder(flatbuffers::FlatBufferBuilder &_fbb)
|
explicit RootBuilder(flatbuffers::FlatBufferBuilder &_fbb)
|
||||||
: fbb_(_fbb) {
|
: fbb_(_fbb) {
|
||||||
@@ -458,17 +472,17 @@ inline flatbuffers::Offset<Root> CreateRoot(
|
|||||||
flatbuffers::Offset<flatbuffers::Vector<int32_t>> g = 0,
|
flatbuffers::Offset<flatbuffers::Vector<int32_t>> g = 0,
|
||||||
flatbuffers::Offset<flatbuffers::Vector<flatbuffers::Offset<Evolution::V2::TableB>>> h = 0,
|
flatbuffers::Offset<flatbuffers::Vector<flatbuffers::Offset<Evolution::V2::TableB>>> h = 0,
|
||||||
uint32_t i = 1234,
|
uint32_t i = 1234,
|
||||||
flatbuffers::Offset<Evolution::V2::TableC> j = 0,
|
flatbuffers::Offset<Evolution::V2::TableC> k = 0,
|
||||||
uint8_t k = 56) {
|
uint8_t l = 56) {
|
||||||
RootBuilder builder_(_fbb);
|
RootBuilder builder_(_fbb);
|
||||||
builder_.add_j(j);
|
builder_.add_k(k);
|
||||||
builder_.add_i(i);
|
builder_.add_i(i);
|
||||||
builder_.add_h(h);
|
builder_.add_h(h);
|
||||||
builder_.add_g(g);
|
builder_.add_g(g);
|
||||||
builder_.add_ff(ff);
|
builder_.add_ff(ff);
|
||||||
builder_.add_e(e);
|
builder_.add_e(e);
|
||||||
builder_.add_c(c);
|
builder_.add_c(c);
|
||||||
builder_.add_k(k);
|
builder_.add_l(l);
|
||||||
builder_.add_d(d);
|
builder_.add_d(d);
|
||||||
builder_.add_c_type(c_type);
|
builder_.add_c_type(c_type);
|
||||||
builder_.add_b(b);
|
builder_.add_b(b);
|
||||||
@@ -486,8 +500,8 @@ inline flatbuffers::Offset<Root> CreateRootDirect(
|
|||||||
const std::vector<int32_t> *g = nullptr,
|
const std::vector<int32_t> *g = nullptr,
|
||||||
const std::vector<flatbuffers::Offset<Evolution::V2::TableB>> *h = nullptr,
|
const std::vector<flatbuffers::Offset<Evolution::V2::TableB>> *h = nullptr,
|
||||||
uint32_t i = 1234,
|
uint32_t i = 1234,
|
||||||
flatbuffers::Offset<Evolution::V2::TableC> j = 0,
|
flatbuffers::Offset<Evolution::V2::TableC> k = 0,
|
||||||
uint8_t k = 56) {
|
uint8_t l = 56) {
|
||||||
auto g__ = g ? _fbb.CreateVector<int32_t>(*g) : 0;
|
auto g__ = g ? _fbb.CreateVector<int32_t>(*g) : 0;
|
||||||
auto h__ = h ? _fbb.CreateVector<flatbuffers::Offset<Evolution::V2::TableB>>(*h) : 0;
|
auto h__ = h ? _fbb.CreateVector<flatbuffers::Offset<Evolution::V2::TableB>>(*h) : 0;
|
||||||
return Evolution::V2::CreateRoot(
|
return Evolution::V2::CreateRoot(
|
||||||
@@ -501,8 +515,8 @@ inline flatbuffers::Offset<Root> CreateRootDirect(
|
|||||||
g__,
|
g__,
|
||||||
h__,
|
h__,
|
||||||
i,
|
i,
|
||||||
j,
|
k,
|
||||||
k);
|
l);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool VerifyUnion(flatbuffers::Verifier &verifier, const void *obj, Union type) {
|
inline bool VerifyUnion(flatbuffers::Verifier &verifier, const void *obj, Union type) {
|
||||||
|
|||||||
@@ -2490,10 +2490,10 @@ void EvolutionTest() {
|
|||||||
|
|
||||||
// Test backwards compatibility by reading old data with an evolved schema.
|
// Test backwards compatibility by reading old data with an evolved schema.
|
||||||
auto root_v1_viewed_from_v2 = Evolution::V2::GetRoot(&binaries[0].front());
|
auto root_v1_viewed_from_v2 = Evolution::V2::GetRoot(&binaries[0].front());
|
||||||
// field 'j' is new in version 2, so it should be null.
|
// field 'k' is new in version 2, so it should be null.
|
||||||
TEST_ASSERT(nullptr == root_v1_viewed_from_v2->j());
|
TEST_ASSERT(nullptr == root_v1_viewed_from_v2->k());
|
||||||
// field 'k' is new in version 2 with a default of 56.
|
// field 'l' is new in version 2 with a default of 56.
|
||||||
TEST_EQ(root_v1_viewed_from_v2->k(), 56);
|
TEST_EQ(root_v1_viewed_from_v2->l(), 56);
|
||||||
// field 'c' of 'TableA' is new in version 2, so it should be null.
|
// field 'c' of 'TableA' is new in version 2, so it should be null.
|
||||||
TEST_ASSERT(nullptr == root_v1_viewed_from_v2->e()->c());
|
TEST_ASSERT(nullptr == root_v1_viewed_from_v2->e()->c());
|
||||||
// 'TableC' was added to field 'c' union in version 2, so it should be null.
|
// 'TableC' was added to field 'c' union in version 2, so it should be null.
|
||||||
@@ -2522,6 +2522,41 @@ void EvolutionTest() {
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void UnionDeprecationTest() {
|
||||||
|
const int NUM_VERSIONS = 2;
|
||||||
|
std::string schemas[NUM_VERSIONS];
|
||||||
|
std::string jsonfiles[NUM_VERSIONS];
|
||||||
|
std::vector<uint8_t> binaries[NUM_VERSIONS];
|
||||||
|
|
||||||
|
flatbuffers::IDLOptions idl_opts;
|
||||||
|
idl_opts.lang_to_generate |= flatbuffers::IDLOptions::kBinary;
|
||||||
|
flatbuffers::Parser parser(idl_opts);
|
||||||
|
|
||||||
|
// Load all the schema versions and their associated data.
|
||||||
|
for (int i = 0; i < NUM_VERSIONS; ++i) {
|
||||||
|
std::string schema = test_data_path + "evolution_test/evolution_v" +
|
||||||
|
flatbuffers::NumToString(i + 1) + ".fbs";
|
||||||
|
TEST_ASSERT(flatbuffers::LoadFile(schema.c_str(), false, &schemas[i]));
|
||||||
|
std::string json = test_data_path + "evolution_test/evolution_v" +
|
||||||
|
flatbuffers::NumToString(i + 1) + ".json";
|
||||||
|
TEST_ASSERT(flatbuffers::LoadFile(json.c_str(), false, &jsonfiles[i]));
|
||||||
|
|
||||||
|
TEST_ASSERT(parser.Parse(schemas[i].c_str()));
|
||||||
|
TEST_ASSERT(parser.Parse(jsonfiles[i].c_str()));
|
||||||
|
|
||||||
|
auto bufLen = parser.builder_.GetSize();
|
||||||
|
auto buf = parser.builder_.GetBufferPointer();
|
||||||
|
binaries[i].reserve(bufLen);
|
||||||
|
std::copy(buf, buf + bufLen, std::back_inserter(binaries[i]));
|
||||||
|
}
|
||||||
|
|
||||||
|
auto v2 = parser.LookupStruct("Evolution.V2.Root");
|
||||||
|
TEST_NOTNULL(v2);
|
||||||
|
auto j_type_field = v2->fields.Lookup("j_type");
|
||||||
|
TEST_NOTNULL(j_type_field);
|
||||||
|
TEST_ASSERT(j_type_field->deprecated);
|
||||||
|
}
|
||||||
|
|
||||||
void UnionVectorTest() {
|
void UnionVectorTest() {
|
||||||
// load FlatBuffer fbs schema and json.
|
// load FlatBuffer fbs schema and json.
|
||||||
std::string schemafile, jsonfile;
|
std::string schemafile, jsonfile;
|
||||||
@@ -3420,6 +3455,7 @@ int FlatBufferTests() {
|
|||||||
ParseProtoTestWithSuffix();
|
ParseProtoTestWithSuffix();
|
||||||
ParseProtoTestWithIncludes();
|
ParseProtoTestWithIncludes();
|
||||||
EvolutionTest();
|
EvolutionTest();
|
||||||
|
UnionDeprecationTest();
|
||||||
UnionVectorTest();
|
UnionVectorTest();
|
||||||
LoadVerifyBinaryTest();
|
LoadVerifyBinaryTest();
|
||||||
GenerateTableTextTest();
|
GenerateTableTextTest();
|
||||||
|
|||||||
Reference in New Issue
Block a user