Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Commit f082ef8

Browse files
author
Michael Meskes
committed
Cope with indicator arrays that do not have the correct length.
Patch by: "Rader, David" <[email protected]>
1 parent c2a7044 commit f082ef8

File tree

1 file changed

+10
-0
lines changed
  • src/interfaces/ecpg/preproc

1 file changed

+10
-0
lines changed

src/interfaces/ecpg/preproc/type.c

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -609,7 +609,17 @@ ECPGdump_a_struct(FILE *o, const char *name, const char *ind_name, char *arrsiz,
609609
prefix, ind_prefix, arrsiz, type->struct_sizeof,
610610
(ind_p != NULL) ? ind_type->struct_sizeof : NULL);
611611
if (ind_p != NULL && ind_p != &struct_no_indicator)
612+
{
612613
ind_p = ind_p->next;
614+
if (ind_p == NULL && p->next != NULL) {
615+
mmerror(PARSE_ERROR, ET_WARNING, "indicator struct \"%s\" has too few members", ind_name);
616+
ind_p = &struct_no_indicator;
617+
}
618+
}
619+
}
620+
621+
if (ind_type != NULL && ind_p != NULL && ind_p != &struct_no_indicator) {
622+
mmerror(PARSE_ERROR, ET_WARNING, "indicator struct \"%s\" has too many members", ind_name);
613623
}
614624

615625
free(pbuf);

0 commit comments

Comments
 (0)