From a0f5890a64e8a5d593b762183682b73ea72f2fe1 Mon Sep 17 00:00:00 2001 From: Michael Meskes Date: Sat, 13 Jan 2018 14:56:49 +0100 Subject: [PATCH] Cope with indicator arrays that do not have the correct length. Patch by: "Rader, David" --- src/interfaces/ecpg/preproc/type.c | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/src/interfaces/ecpg/preproc/type.c b/src/interfaces/ecpg/preproc/type.c index 3e37fb9d3c1..d6c4b959d53 100644 --- a/src/interfaces/ecpg/preproc/type.c +++ b/src/interfaces/ecpg/preproc/type.c @@ -560,7 +560,17 @@ ECPGdump_a_struct(FILE *o, const char *name, const char *ind_name, char *arrsiz, prefix, ind_prefix, arrsiz, type->struct_sizeof, (ind_p != NULL) ? ind_type->struct_sizeof : NULL); if (ind_p != NULL && ind_p != &struct_no_indicator) + { ind_p = ind_p->next; + if (ind_p == NULL && p->next != NULL) { + mmerror(PARSE_ERROR, ET_WARNING, "indicator struct \"%s\" has too few members", ind_name); + ind_p = &struct_no_indicator; + } + } + } + + if (ind_type != NULL && ind_p != NULL && ind_p != &struct_no_indicator) { + mmerror(PARSE_ERROR, ET_WARNING, "indicator struct \"%s\" has too many members", ind_name); } free(pbuf);