From: Michael Meskes Date: Thu, 29 Nov 2012 16:12:00 +0000 (+0100) Subject: When processing nested structure pointer variables ecpg always expected an X-Git-Tag: REL9_0_11~18 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=3dfdf28152eb2df7cb4d4e43f461903fcc09e1d2;p=postgresql When processing nested structure pointer variables ecpg always expected an array datatype which of course is wrong. Applied patch by Muhammad Usama to fix this. --- diff --git a/src/interfaces/ecpg/preproc/variable.c b/src/interfaces/ecpg/preproc/variable.c index dbde1141ab..00517df412 100644 --- a/src/interfaces/ecpg/preproc/variable.c +++ b/src/interfaces/ecpg/preproc/variable.c @@ -100,7 +100,11 @@ find_struct_member(char *name, char *str, struct ECPGstruct_member * members, in } break; case '-': - return (find_struct_member(name, end, members->type->u.element->u.members, brace_level)); + if (members->type->type == ECPGt_array) + return (find_struct_member(name, ++end, members->type->u.element->u.members, brace_level)); + else + return (find_struct_member(name, ++end, members->type->u.members, brace_level)); + break; break; case '.': if (members->type->type == ECPGt_array)