From d00e1467311d6b9baac1d3f7e582bb757fcb2dee Mon Sep 17 00:00:00 2001 From: songruining Date: Tue, 29 Nov 2022 10:32:56 +0800 Subject: [PATCH] chore: emit more reasonable error message when using incomplete type in struct --- include/flatbuffers/idl.h | 4 ++++ src/idl_parser.cpp | 6 ++++++ 2 files changed, 10 insertions(+) diff --git a/include/flatbuffers/idl.h b/include/flatbuffers/idl.h index a07f62a30b2..f6384894535 100644 --- a/include/flatbuffers/idl.h +++ b/include/flatbuffers/idl.h @@ -473,6 +473,10 @@ inline bool IsStruct(const Type &type) { return type.base_type == BASE_TYPE_STRUCT && type.struct_def->fixed; } +inline bool IsIncompleteStruct(const Type &type) { + return type.base_type == BASE_TYPE_STRUCT && type.struct_def->predecl; +} + inline bool IsTable(const Type &type) { return type.base_type == BASE_TYPE_STRUCT && !type.struct_def->fixed; } diff --git a/src/idl_parser.cpp b/src/idl_parser.cpp index b16c3bec8ab..854d2a7cfdc 100644 --- a/src/idl_parser.cpp +++ b/src/idl_parser.cpp @@ -918,6 +918,12 @@ CheckedError Parser::ParseField(StructDef &struct_def) { ECHECK(ParseType(type)); if (struct_def.fixed) { + if (IsIncompleteStruct(type) || + (IsArray(type) && IsIncompleteStruct(type.VectorType()))) { + std::string type_name = IsArray(type) ? type.VectorType().struct_def->name : type.struct_def->name; + return Error(std::string("Incomplete type in struct is not allowed, type name: ") + type_name); + } + auto valid = IsScalar(type.base_type) || IsStruct(type); if (!valid && IsArray(type)) { const auto &elem_type = type.VectorType();