From: | Jürgen Cappel <email(at)juergen-cappel(dot)de> |
---|---|
To: | <pgsql-interfaces(at)postgresql(dot)org> |
Subject: | ecpg with nested structure |
Date: | 2003-12-27 07:36:44 |
Message-ID: | JEEKIPNAKJNCFLMOBKHGEEALDCAA.email@juergen-cappel.de |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-interfaces |
Hello,
while porting an application from CA/Ingres to PostgreSQL
I came across a segmentation fault by ecpg. The code looks
something like this:
EXEC SQL BEGIN DECLARE SECTION;
struct bnd_a
{
struct bnd_b
{
char myvar[31];
} bnd_b[5];
} bnd_a[5];
EXEC SQL END DECLARE SECTION;
myfunction()
{
EXEC SQL DECLARE mycursor CURSOR FOR
SELECT mycolumn FROM mytable;
EXEC SQL OPEN mycursor;
EXEC SQL FETCH mycursor
INTO :bnd_a[0].bnd_b[0].myvar;
EXEC SQL CLOSE mycursor;
}
Versions are:
ecpg (PostgreSQL 7.4) 3.0.0
Linux scaleo 2.4.18-4GB #1 Wed Mar 27 13:57:05 UTC 2002 i686 unknown
Stack trace:
#0 0x40163a40 in strcmp () from /lib/libc.so.6
#1 0x080678d2 in find_struct_member (name=0x80c0f88 "bnd_a[0].bnd_b[0]",
str=0x80c0f97 "0]", members=0x80c1170, brace_level=0) at variable.c:37
#2 0x08067c1f in find_struct_member (name=0x80c0f88 "bnd_a[0].bnd_b[0]",
str=0x80c0f91 "bnd_b[0]", members=0x80c11a0, brace_level=0) at
variable.c:110
#3 0x08067ea6 in find_struct (name=0x80c0f88 "bnd_a[0].bnd_b[0]",
next=0x80c0f8d "[0].bnd_b[0]", end=0x80c0f90 ".bnd_b[0]") at
variable.c:185
#4 0x08067fb3 in find_variable (name=0x80c0f88 "bnd_a[0].bnd_b[0]")
at variable.c:238
#5 0x080604c0 in yyparse () at preproc.y:6152
#6 0x08066632 in main (argc=4, argv=0xbffff284) at ecpg.c:394
#7 0x401089ed in __libc_start_main () from /lib/libc.so.6
Are nested structures not supported by ecpg ?
Thanks for any information,
Jürgen
From | Date | Subject | |
---|---|---|---|
Next Message | Jürgen Cappel | 2003-12-27 14:18:45 | ecpg odd syntax error at array index |
Previous Message | mixo | 2003-12-24 09:13:41 | "unicode" warnings |