Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
Postgres FD Implementation
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Abuhujair Javed
Postgres FD Implementation
Commits
cf37d684
Commit
cf37d684
authored
Aug 14, 2009
by
Michael Meskes
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Made sure sqlca is reset for declare cursor in Informix mode as pointed out by
Böszörményi Zoltán <zb@cybertec.at>.
parent
c74d8a77
Changes
12
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
132 additions
and
70 deletions
+132
-70
src/interfaces/ecpg/ChangeLog
src/interfaces/ecpg/ChangeLog
+6
-0
src/interfaces/ecpg/compatlib/Makefile
src/interfaces/ecpg/compatlib/Makefile
+2
-2
src/interfaces/ecpg/compatlib/exports.txt
src/interfaces/ecpg/compatlib/exports.txt
+2
-1
src/interfaces/ecpg/compatlib/informix.c
src/interfaces/ecpg/compatlib/informix.c
+37
-1
src/interfaces/ecpg/include/ecpg_informix.h
src/interfaces/ecpg/include/ecpg_informix.h
+4
-3
src/interfaces/ecpg/preproc/ecpg.addons
src/interfaces/ecpg/preproc/ecpg.addons
+13
-3
src/interfaces/ecpg/preproc/ecpg.trailer
src/interfaces/ecpg/preproc/ecpg.trailer
+5
-2
src/interfaces/ecpg/test/compat_informix/test_informix.pgc
src/interfaces/ecpg/test/compat_informix/test_informix.pgc
+2
-0
src/interfaces/ecpg/test/expected/compat_informix-test_informix.c
...rfaces/ecpg/test/expected/compat_informix-test_informix.c
+22
-20
src/interfaces/ecpg/test/expected/compat_informix-test_informix.stderr
...s/ecpg/test/expected/compat_informix-test_informix.stderr
+37
-37
src/interfaces/ecpg/test/expected/compat_informix-test_informix.stdout
...s/ecpg/test/expected/compat_informix-test_informix.stdout
+1
-0
src/interfaces/ecpg/test/expected/connect-test1.stderr
src/interfaces/ecpg/test/expected/connect-test1.stderr
+1
-1
No files found.
src/interfaces/ecpg/ChangeLog
View file @
cf37d684
...
@@ -2419,5 +2419,11 @@ Fri, 07 Aug 2009 10:41:28 +0200
...
@@ -2419,5 +2419,11 @@ Fri, 07 Aug 2009 10:41:28 +0200
- Added STRING datatype for Informix compatibility mode. This work is
- Added STRING datatype for Informix compatibility mode. This work is
based on a patch send in by Böszörményi Zoltán <zb@cybertec.at>.
based on a patch send in by Böszörményi Zoltán <zb@cybertec.at>.
Fri, 14 Aug 2009 14:45:02 +0200
- Made sure sqlca is reset for declare cursor in Informix mode as
pointed out by Böszörményi Zoltán <zb@cybertec.at>.
- Set ecpg library version to 6.2.
- Set ecpg library version to 6.2.
- Set compat library version to 3.2.
- Set ecpg version to 4.6.
- Set ecpg version to 4.6.
src/interfaces/ecpg/compatlib/Makefile
View file @
cf37d684
...
@@ -5,7 +5,7 @@
...
@@ -5,7 +5,7 @@
# Portions Copyright (c) 1996-2009, PostgreSQL Global Development Group
# Portions Copyright (c) 1996-2009, PostgreSQL Global Development Group
# Portions Copyright (c) 1994, Regents of the University of California
# Portions Copyright (c) 1994, Regents of the University of California
#
#
# $PostgreSQL: pgsql/src/interfaces/ecpg/compatlib/Makefile,v 1.4
4 2009/08/07 10:51:20
meskes Exp $
# $PostgreSQL: pgsql/src/interfaces/ecpg/compatlib/Makefile,v 1.4
5 2009/08/14 13:28:22
meskes Exp $
#
#
#-------------------------------------------------------------------------
#-------------------------------------------------------------------------
...
@@ -15,7 +15,7 @@ include $(top_builddir)/src/Makefile.global
...
@@ -15,7 +15,7 @@ include $(top_builddir)/src/Makefile.global
NAME
=
ecpg_compat
NAME
=
ecpg_compat
SO_MAJOR_VERSION
=
3
SO_MAJOR_VERSION
=
3
SO_MINOR_VERSION
=
1
SO_MINOR_VERSION
=
2
override CPPFLAGS
:
= -I../include -I$(top_srcdir)/src/interfaces/ecpg/include
\
override CPPFLAGS
:
= -I../include -I$(top_srcdir)/src/interfaces/ecpg/include
\
-I$(libpq_srcdir) -I$(top_srcdir)/src/include/utils $(CPPFLAGS)
-I$(libpq_srcdir) -I$(top_srcdir)/src/include/utils $(CPPFLAGS)
...
...
src/interfaces/ecpg/compatlib/exports.txt
View file @
cf37d684
# $PostgreSQL: pgsql/src/interfaces/ecpg/compatlib/exports.txt,v 1.
4 2007/10/04 17:49:31
meskes Exp $
# $PostgreSQL: pgsql/src/interfaces/ecpg/compatlib/exports.txt,v 1.
5 2009/08/14 13:28:22
meskes Exp $
# Functions to be exported by ecpg_compatlib DLL
# Functions to be exported by ecpg_compatlib DLL
ECPG_informix_get_var 1
ECPG_informix_get_var 1
ECPG_informix_set_var 2
ECPG_informix_set_var 2
...
@@ -41,3 +41,4 @@ rtypwidth 38
...
@@ -41,3 +41,4 @@ rtypwidth 38
rupshift 39
rupshift 39
ldchar 40
ldchar 40
byleng 41
byleng 41
ECPG_informix_reset_sqlca 42
src/interfaces/ecpg/compatlib/informix.c
View file @
cf37d684
/* $PostgreSQL: pgsql/src/interfaces/ecpg/compatlib/informix.c,v 1.
59 2009/06/11 14:49:13 momjian
Exp $ */
/* $PostgreSQL: pgsql/src/interfaces/ecpg/compatlib/informix.c,v 1.
60 2009/08/14 13:28:22 meskes
Exp $ */
#define POSTGRES_ECPG_INTERNAL
#define POSTGRES_ECPG_INTERNAL
#include "postgres_fe.h"
#include "postgres_fe.h"
...
@@ -16,6 +16,34 @@
...
@@ -16,6 +16,34 @@
#include <sqlca.h>
#include <sqlca.h>
#include <ecpgerrno.h>
#include <ecpgerrno.h>
/* this is also defined in ecpglib/misc.c, by defining it twice we don't have to export the symbol */
static
struct
sqlca_t
sqlca_init
=
{
{
'S'
,
'Q'
,
'L'
,
'C'
,
'A'
,
' '
,
' '
,
' '
},
sizeof
(
struct
sqlca_t
),
0
,
{
0
,
{
0
}
},
{
'N'
,
'O'
,
'T'
,
' '
,
'S'
,
'E'
,
'T'
,
' '
},
{
0
,
0
,
0
,
0
,
0
,
0
},
{
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
},
{
'0'
,
'0'
,
'0'
,
'0'
,
'0'
}
};
static
int
static
int
deccall2
(
decimal
*
arg1
,
decimal
*
arg2
,
int
(
*
ptr
)
(
numeric
*
,
numeric
*
))
deccall2
(
decimal
*
arg1
,
decimal
*
arg2
,
int
(
*
ptr
)
(
numeric
*
,
numeric
*
))
{
{
...
@@ -1033,6 +1061,14 @@ ECPG_informix_get_var(int number)
...
@@ -1033,6 +1061,14 @@ ECPG_informix_get_var(int number)
return
(
ptr
)
?
ptr
->
pointer
:
NULL
;
return
(
ptr
)
?
ptr
->
pointer
:
NULL
;
}
}
void
ECPG_informix_reset_sqlca
(
void
)
{
struct
sqlca_t
*
sqlca
=
ECPGget_sqlca
();
memcpy
((
char
*
)
sqlca
,
(
char
*
)
&
sqlca_init
,
sizeof
(
struct
sqlca_t
));
}
int
int
rsetnull
(
int
t
,
char
*
ptr
)
rsetnull
(
int
t
,
char
*
ptr
)
{
{
...
...
src/interfaces/ecpg/include/ecpg_informix.h
View file @
cf37d684
/*
/*
* This file contains stuff needed to be as compatible to Informix as possible.
* This file contains stuff needed to be as compatible to Informix as possible.
* $PostgreSQL: pgsql/src/interfaces/ecpg/include/ecpg_informix.h,v 1.2
2 2008/02/17 18:14:29
meskes Exp $
* $PostgreSQL: pgsql/src/interfaces/ecpg/include/ecpg_informix.h,v 1.2
3 2009/08/14 13:28:22
meskes Exp $
*/
*/
#ifndef _ECPG_INFORMIX_H
#ifndef _ECPG_INFORMIX_H
#define _ECPG_INFORMIX_H
#define _ECPG_INFORMIX_H
...
@@ -34,7 +34,7 @@ extern "C"
...
@@ -34,7 +34,7 @@ extern "C"
#endif
#endif
extern
int
rdatestr
(
date
,
char
*
);
extern
int
rdatestr
(
date
,
char
*
);
extern
void
rtoday
(
date
*
);
extern
void
rtoday
(
date
*
);
extern
int
rjulmdy
(
date
,
short
*
);
extern
int
rjulmdy
(
date
,
short
*
);
extern
int
rdefmtdate
(
date
*
,
char
*
,
char
*
);
extern
int
rdefmtdate
(
date
*
,
char
*
,
char
*
);
extern
int
rfmtdate
(
date
,
char
*
,
char
*
);
extern
int
rfmtdate
(
date
,
char
*
,
char
*
);
...
@@ -49,13 +49,14 @@ extern int rsetnull(int, char *);
...
@@ -49,13 +49,14 @@ extern int rsetnull(int, char *);
extern
int
rtypalign
(
int
,
int
);
extern
int
rtypalign
(
int
,
int
);
extern
int
rtypmsize
(
int
,
int
);
extern
int
rtypmsize
(
int
,
int
);
extern
int
rtypwidth
(
int
,
int
);
extern
int
rtypwidth
(
int
,
int
);
extern
void
rupshift
(
char
*
);
extern
void
rupshift
(
char
*
);
extern
int
byleng
(
char
*
,
int
);
extern
int
byleng
(
char
*
,
int
);
extern
void
ldchar
(
char
*
,
int
,
char
*
);
extern
void
ldchar
(
char
*
,
int
,
char
*
);
extern
void
ECPG_informix_set_var
(
int
,
void
*
,
int
);
extern
void
ECPG_informix_set_var
(
int
,
void
*
,
int
);
extern
void
*
ECPG_informix_get_var
(
int
);
extern
void
*
ECPG_informix_get_var
(
int
);
extern
void
ECPG_informix_reset_sqlca
(
void
);
/* Informix defines these in decimal.h */
/* Informix defines these in decimal.h */
int
decadd
(
decimal
*
,
decimal
*
,
decimal
*
);
int
decadd
(
decimal
*
,
decimal
*
,
decimal
*
);
...
...
src/interfaces/ecpg/preproc/ecpg.addons
View file @
cf37d684
/* $PostgreSQL: pgsql/src/interfaces/ecpg/preproc/ecpg.addons,v 1.
4 2009/01/30 12:53:43 petere
Exp $ */
/* $PostgreSQL: pgsql/src/interfaces/ecpg/preproc/ecpg.addons,v 1.
5 2009/08/14 13:28:22 meskes
Exp $ */
ECPG: stmtClosePortalStmt block
ECPG: stmtClosePortalStmt block
{
{
...
@@ -238,6 +238,7 @@ ECPG: ExecuteStmtEXECUTEprepared_nameexecute_param_clauseexecute_rest block
...
@@ -238,6 +238,7 @@ ECPG: ExecuteStmtEXECUTEprepared_nameexecute_param_clauseexecute_rest block
ECPG: DeclareCursorStmtDECLAREnamecursor_optionsCURSORopt_holdFORSelectStmt block
ECPG: DeclareCursorStmtDECLAREnamecursor_optionsCURSORopt_holdFORSelectStmt block
{
{
struct cursor *ptr, *this;
struct cursor *ptr, *this;
char *comment;
for (ptr = cur; ptr != NULL; ptr = ptr->next)
for (ptr = cur; ptr != NULL; ptr = ptr->next)
{
{
...
@@ -257,10 +258,19 @@ ECPG: DeclareCursorStmtDECLAREnamecursor_optionsCURSORopt_holdFORSelectStmt bloc
...
@@ -257,10 +258,19 @@ ECPG: DeclareCursorStmtDECLAREnamecursor_optionsCURSORopt_holdFORSelectStmt bloc
argsinsert = argsresult = NULL;
argsinsert = argsresult = NULL;
cur = this;
cur = this;
comment = cat_str(3, make_str("/*"), mm_strdup(this->command), make_str("*/"));
if (INFORMIX_MODE)
if (INFORMIX_MODE)
$$ = cat_str(5, adjust_informix(this->argsinsert), adjust_informix(this->argsresult), make_str("/*"), mm_strdup(this->command), make_str("*/"));
{
if (braces_open > 0) /* we're in a function */
{
$$ = cat_str(4, adjust_informix(this->argsinsert), adjust_informix(this->argsresult), make_str("ECPG_informix_reset_sqlca();"), comment);
}
else
$$ = cat_str(3, adjust_informix(this->argsinsert), adjust_informix(this->argsresult), comment);
}
else
else
$$ = c
at_str(3, make_str("/*"), mm_strdup(this->command), make_str("*/"))
;
$$ = c
omment
;
}
}
ECPG: opt_hold block
ECPG: opt_hold block
{
{
...
...
src/interfaces/ecpg/preproc/ecpg.trailer
View file @
cf37d684
/* $PostgreSQL: pgsql/src/interfaces/ecpg/preproc/ecpg.trailer,v 1.1
0 2009/08/07 10:51:20
meskes Exp $ */
/* $PostgreSQL: pgsql/src/interfaces/ecpg/preproc/ecpg.trailer,v 1.1
1 2009/08/14 13:28:22
meskes Exp $ */
statements: /*EMPTY*/
statements: /*EMPTY*/
| statements statement
| statements statement
...
@@ -318,7 +318,10 @@ ECPGCursorStmt: DECLARE name cursor_options CURSOR opt_hold FOR prepared_name
...
@@ -318,7 +318,10 @@ ECPGCursorStmt: DECLARE name cursor_options CURSOR opt_hold FOR prepared_name
cur = this;
cur = this;
$$ = cat_str(3, make_str("/*"), mm_strdup(this->command), make_str("*/"));
if (INFORMIX_MODE && braces_open > 0) /* we're in a function */
$$ = cat_str(4, make_str("ECPG_informix_reset_sqlca();"), make_str("/*"), mm_strdup(this->command), make_str("*/"));
else
$$ = cat_str(3, make_str("/*"), mm_strdup(this->command), make_str("*/"));
}
}
;
;
...
...
src/interfaces/ecpg/test/compat_informix/test_informix.pgc
View file @
cf37d684
...
@@ -45,7 +45,9 @@ int main(void)
...
@@ -45,7 +45,9 @@ int main(void)
printf("SELECT: %ld=%s\n", sqlca.sqlcode, sqlca.sqlerrm.sqlerrmc);
printf("SELECT: %ld=%s\n", sqlca.sqlcode, sqlca.sqlerrm.sqlerrmc);
if (sqlca.sqlcode != 0) $rollback;
if (sqlca.sqlcode != 0) $rollback;
sqlca.sqlcode = 100;
$declare c cursor for select * from test where i <= :i;
$declare c cursor for select * from test where i <= :i;
printf ("%ld\n", sqlca.sqlcode);
openit();
openit();
deccvint(0, &j);
deccvint(0, &j);
...
...
src/interfaces/ecpg/test/expected/compat_informix-test_informix.c
View file @
cf37d684
...
@@ -146,10 +146,12 @@ if (sqlca.sqlcode < 0) dosqlprint ( );}
...
@@ -146,10 +146,12 @@ if (sqlca.sqlcode < 0) dosqlprint ( );}
#line 46 "test_informix.pgc"
#line 46 "test_informix.pgc"
sqlca
.
sqlcode
=
100
;
ECPG_informix_set_var
(
0
,
&
(
i
),
__LINE__
);
\
ECPG_informix_set_var
(
0
,
&
(
i
),
__LINE__
);
\
/* declare c cursor for select * from test where i <= $1 */
ECPG_informix_reset_sqlca
();
/* declare c cursor for select * from test where i <= $1 */
#line 4
8
"test_informix.pgc"
#line 4
9
"test_informix.pgc"
printf
(
"%ld
\n
"
,
sqlca
.
sqlcode
);
openit
();
openit
();
deccvint
(
0
,
&
j
);
deccvint
(
0
,
&
j
);
...
@@ -163,10 +165,10 @@ if (sqlca.sqlcode < 0) dosqlprint ( );}
...
@@ -163,10 +165,10 @@ if (sqlca.sqlcode < 0) dosqlprint ( );}
ECPGt_NO_INDICATOR
,
NULL
,
0L
,
0L
,
0L
,
ECPGt_NO_INDICATOR
,
NULL
,
0L
,
0L
,
0L
,
ECPGt_string
,(
c
),(
long
)
10
,(
long
)
1
,(
10
)
*
sizeof
(
char
),
ECPGt_string
,(
c
),(
long
)
10
,(
long
)
1
,(
10
)
*
sizeof
(
char
),
ECPGt_NO_INDICATOR
,
NULL
,
0L
,
0L
,
0L
,
ECPGt_EORT
);
ECPGt_NO_INDICATOR
,
NULL
,
0L
,
0L
,
0L
,
ECPGt_EORT
);
#line 5
5
"test_informix.pgc"
#line 5
7
"test_informix.pgc"
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
#line 5
5
"test_informix.pgc"
#line 5
7
"test_informix.pgc"
if
(
sqlca
.
sqlcode
==
100
)
break
;
if
(
sqlca
.
sqlcode
==
100
)
break
;
else
if
(
sqlca
.
sqlcode
!=
0
)
printf
(
"Error: %ld
\n
"
,
sqlca
.
sqlcode
);
else
if
(
sqlca
.
sqlcode
!=
0
)
printf
(
"Error: %ld
\n
"
,
sqlca
.
sqlcode
);
...
@@ -188,53 +190,53 @@ if (sqlca.sqlcode < 0) dosqlprint ( );}
...
@@ -188,53 +190,53 @@ if (sqlca.sqlcode < 0) dosqlprint ( );}
{
ECPGdo
(
__LINE__
,
1
,
1
,
NULL
,
0
,
ECPGst_normal
,
"delete from test where i = $1 :: decimal"
,
{
ECPGdo
(
__LINE__
,
1
,
1
,
NULL
,
0
,
ECPGst_normal
,
"delete from test where i = $1 :: decimal"
,
ECPGt_decimal
,
&
(
n
),(
long
)
1
,(
long
)
1
,
sizeof
(
decimal
),
ECPGt_decimal
,
&
(
n
),(
long
)
1
,(
long
)
1
,
sizeof
(
decimal
),
ECPGt_NO_INDICATOR
,
NULL
,
0L
,
0L
,
0L
,
ECPGt_EOIT
,
ECPGt_EORT
);
ECPGt_NO_INDICATOR
,
NULL
,
0L
,
0L
,
0L
,
ECPGt_EOIT
,
ECPGt_EORT
);
#line 7
3
"test_informix.pgc"
#line 7
5
"test_informix.pgc"
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
#line 7
3
"test_informix.pgc"
#line 7
5
"test_informix.pgc"
printf
(
"DELETE: %ld
\n
"
,
sqlca
.
sqlcode
);
printf
(
"DELETE: %ld
\n
"
,
sqlca
.
sqlcode
);
{
ECPGdo
(
__LINE__
,
1
,
1
,
NULL
,
0
,
ECPGst_normal
,
"select 1 from test where i = 14"
,
ECPGt_EOIT
,
ECPGt_EORT
);
{
ECPGdo
(
__LINE__
,
1
,
1
,
NULL
,
0
,
ECPGst_normal
,
"select 1 from test where i = 14"
,
ECPGt_EOIT
,
ECPGt_EORT
);
#line 7
6
"test_informix.pgc"
#line 7
8
"test_informix.pgc"
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
#line 7
6
"test_informix.pgc"
#line 7
8
"test_informix.pgc"
printf
(
"Exists: %ld
\n
"
,
sqlca
.
sqlcode
);
printf
(
"Exists: %ld
\n
"
,
sqlca
.
sqlcode
);
{
ECPGdo
(
__LINE__
,
1
,
1
,
NULL
,
0
,
ECPGst_normal
,
"select 1 from test where i = 147"
,
ECPGt_EOIT
,
ECPGt_EORT
);
{
ECPGdo
(
__LINE__
,
1
,
1
,
NULL
,
0
,
ECPGst_normal
,
"select 1 from test where i = 147"
,
ECPGt_EOIT
,
ECPGt_EORT
);
#line
79
"test_informix.pgc"
#line
81
"test_informix.pgc"
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
#line
79
"test_informix.pgc"
#line
81
"test_informix.pgc"
printf
(
"Does not exist: %ld
\n
"
,
sqlca
.
sqlcode
);
printf
(
"Does not exist: %ld
\n
"
,
sqlca
.
sqlcode
);
{
ECPGtrans
(
__LINE__
,
NULL
,
"commit"
);
{
ECPGtrans
(
__LINE__
,
NULL
,
"commit"
);
#line 8
2
"test_informix.pgc"
#line 8
4
"test_informix.pgc"
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
#line 8
2
"test_informix.pgc"
#line 8
4
"test_informix.pgc"
{
ECPGdo
(
__LINE__
,
1
,
1
,
NULL
,
0
,
ECPGst_normal
,
"drop table test"
,
ECPGt_EOIT
,
ECPGt_EORT
);
{
ECPGdo
(
__LINE__
,
1
,
1
,
NULL
,
0
,
ECPGst_normal
,
"drop table test"
,
ECPGt_EOIT
,
ECPGt_EORT
);
#line 8
3
"test_informix.pgc"
#line 8
5
"test_informix.pgc"
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
#line 8
3
"test_informix.pgc"
#line 8
5
"test_informix.pgc"
{
ECPGtrans
(
__LINE__
,
NULL
,
"commit"
);
{
ECPGtrans
(
__LINE__
,
NULL
,
"commit"
);
#line 8
4
"test_informix.pgc"
#line 8
6
"test_informix.pgc"
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
#line 8
4
"test_informix.pgc"
#line 8
6
"test_informix.pgc"
{
ECPGdisconnect
(
__LINE__
,
"CURRENT"
);
{
ECPGdisconnect
(
__LINE__
,
"CURRENT"
);
#line 8
6
"test_informix.pgc"
#line 8
8
"test_informix.pgc"
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
#line 8
6
"test_informix.pgc"
#line 8
8
"test_informix.pgc"
return
0
;
return
0
;
...
@@ -245,10 +247,10 @@ static void openit(void)
...
@@ -245,10 +247,10 @@ static void openit(void)
{
ECPGdo
(
__LINE__
,
1
,
1
,
NULL
,
0
,
ECPGst_normal
,
"declare c cursor for select * from test where i <= $1 "
,
{
ECPGdo
(
__LINE__
,
1
,
1
,
NULL
,
0
,
ECPGst_normal
,
"declare c cursor for select * from test where i <= $1 "
,
ECPGt_int
,
&
(
*
(
int
*
)(
ECPG_informix_get_var
(
0
))),(
long
)
1
,(
long
)
1
,
sizeof
(
int
),
ECPGt_int
,
&
(
*
(
int
*
)(
ECPG_informix_get_var
(
0
))),(
long
)
1
,(
long
)
1
,
sizeof
(
int
),
ECPGt_NO_INDICATOR
,
NULL
,
0L
,
0L
,
0L
,
ECPGt_EOIT
,
ECPGt_EORT
);
ECPGt_NO_INDICATOR
,
NULL
,
0L
,
0L
,
0L
,
ECPGt_EOIT
,
ECPGt_EORT
);
#line 9
3
"test_informix.pgc"
#line 9
5
"test_informix.pgc"
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
if
(
sqlca
.
sqlcode
<
0
)
dosqlprint
(
);}
#line 9
3
"test_informix.pgc"
#line 9
5
"test_informix.pgc"
}
}
src/interfaces/ecpg/test/expected/compat_informix-test_informix.stderr
View file @
cf37d684
...
@@ -55,79 +55,79 @@ DETAIL: Key (i)=(7) already exists.
...
@@ -55,79 +55,79 @@ DETAIL: Key (i)=(7) already exists.
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 44: correctly got 1 tuples with 1 fields
[NO_PID]: ecpg_execute on line 44: correctly got 1 tuples with 1 fields
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 9
3
: query: declare c cursor for select * from test where i <= $1 ; with 1 parameter(s) on connection regress1
[NO_PID]: ecpg_execute on line 9
5
: query: declare c cursor for select * from test where i <= $1 ; with 1 parameter(s) on connection regress1
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 9
3
: using PQexecParams
[NO_PID]: ecpg_execute on line 9
5
: using PQexecParams
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: free_params on line 9
3
: parameter 1 = 14
[NO_PID]: free_params on line 9
5
: parameter 1 = 14
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 9
3
: OK: DECLARE CURSOR
[NO_PID]: ecpg_execute on line 9
5
: OK: DECLARE CURSOR
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 5
5
: query: fetch forward from c; with 0 parameter(s) on connection regress1
[NO_PID]: ecpg_execute on line 5
7
: query: fetch forward from c; with 0 parameter(s) on connection regress1
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 5
5
: using PQexec
[NO_PID]: ecpg_execute on line 5
7
: using PQexec
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 5
5
: correctly got 1 tuples with 3 fields
[NO_PID]: ecpg_execute on line 5
7
: correctly got 1 tuples with 3 fields
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_get_data on line 5
5
: RESULT: 7 offset: -1; array: yes
[NO_PID]: ecpg_get_data on line 5
7
: RESULT: 7 offset: -1; array: yes
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_get_data on line 5
5
: RESULT: 0 offset: -1; array: yes
[NO_PID]: ecpg_get_data on line 5
7
: RESULT: 0 offset: -1; array: yes
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_get_data on line 5
5
: RESULT: test offset: -1; array: yes
[NO_PID]: ecpg_get_data on line 5
7
: RESULT: test offset: -1; array: yes
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 5
5
: query: fetch forward from c; with 0 parameter(s) on connection regress1
[NO_PID]: ecpg_execute on line 5
7
: query: fetch forward from c; with 0 parameter(s) on connection regress1
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 5
5
: using PQexec
[NO_PID]: ecpg_execute on line 5
7
: using PQexec
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 5
5
: correctly got 1 tuples with 3 fields
[NO_PID]: ecpg_execute on line 5
7
: correctly got 1 tuples with 3 fields
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_get_data on line 5
5
: RESULT: 14 offset: -1; array: yes
[NO_PID]: ecpg_get_data on line 5
7
: RESULT: 14 offset: -1; array: yes
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_get_data on line 5
5
: RESULT: 1 offset: -1; array: yes
[NO_PID]: ecpg_get_data on line 5
7
: RESULT: 1 offset: -1; array: yes
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_get_data on line 5
5
: RESULT: a offset: -1; array: yes
[NO_PID]: ecpg_get_data on line 5
7
: RESULT: a offset: -1; array: yes
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 5
5
: query: fetch forward from c; with 0 parameter(s) on connection regress1
[NO_PID]: ecpg_execute on line 5
7
: query: fetch forward from c; with 0 parameter(s) on connection regress1
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 5
5
: using PQexec
[NO_PID]: ecpg_execute on line 5
7
: using PQexec
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 5
5
: correctly got 0 tuples with 3 fields
[NO_PID]: ecpg_execute on line 5
7
: correctly got 0 tuples with 3 fields
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: raising sqlcode 100 on line 5
5: no data found on line 55
[NO_PID]: raising sqlcode 100 on line 5
7: no data found on line 57
[NO_PID]: sqlca: code: 100, state: 02000
[NO_PID]: sqlca: code: 100, state: 02000
[NO_PID]: ecpg_execute on line 7
3
: query: delete from test where i = $1 :: decimal; with 1 parameter(s) on connection regress1
[NO_PID]: ecpg_execute on line 7
5
: query: delete from test where i = $1 :: decimal; with 1 parameter(s) on connection regress1
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 7
3
: using PQexecParams
[NO_PID]: ecpg_execute on line 7
5
: using PQexecParams
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: free_params on line 7
3
: parameter 1 = 21.0
[NO_PID]: free_params on line 7
5
: parameter 1 = 21.0
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 7
3
: OK: DELETE 0
[NO_PID]: ecpg_execute on line 7
5
: OK: DELETE 0
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: raising sqlcode 100 on line 7
3: no data found on line 73
[NO_PID]: raising sqlcode 100 on line 7
5: no data found on line 75
[NO_PID]: sqlca: code: 100, state: 02000
[NO_PID]: sqlca: code: 100, state: 02000
[NO_PID]: ecpg_execute on line 7
6
: query: select 1 from test where i = 14; with 0 parameter(s) on connection regress1
[NO_PID]: ecpg_execute on line 7
8
: query: select 1 from test where i = 14; with 0 parameter(s) on connection regress1
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 7
6
: using PQexec
[NO_PID]: ecpg_execute on line 7
8
: using PQexec
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 7
6
: correctly got 1 tuples with 1 fields
[NO_PID]: ecpg_execute on line 7
8
: correctly got 1 tuples with 1 fields
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line
79
: query: select 1 from test where i = 147; with 0 parameter(s) on connection regress1
[NO_PID]: ecpg_execute on line
81
: query: select 1 from test where i = 147; with 0 parameter(s) on connection regress1
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line
79
: using PQexec
[NO_PID]: ecpg_execute on line
81
: using PQexec
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line
79
: correctly got 0 tuples with 1 fields
[NO_PID]: ecpg_execute on line
81
: correctly got 0 tuples with 1 fields
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: raising sqlcode 100 on line
79: no data found on line 79
[NO_PID]: raising sqlcode 100 on line
81: no data found on line 81
[NO_PID]: sqlca: code: 100, state: 02000
[NO_PID]: sqlca: code: 100, state: 02000
[NO_PID]: ECPGtrans on line 8
2
: action "commit"; connection "regress1"
[NO_PID]: ECPGtrans on line 8
4
: action "commit"; connection "regress1"
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 8
3
: query: drop table test; with 0 parameter(s) on connection regress1
[NO_PID]: ecpg_execute on line 8
5
: query: drop table test; with 0 parameter(s) on connection regress1
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 8
3
: using PQexec
[NO_PID]: ecpg_execute on line 8
5
: using PQexec
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_execute on line 8
3
: OK: DROP TABLE
[NO_PID]: ecpg_execute on line 8
5
: OK: DROP TABLE
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ECPGtrans on line 8
4
: action "commit"; connection "regress1"
[NO_PID]: ECPGtrans on line 8
6
: action "commit"; connection "regress1"
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: ecpg_finish: connection regress1 closed
[NO_PID]: ecpg_finish: connection regress1 closed
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
src/interfaces/ecpg/test/expected/compat_informix-test_informix.stdout
View file @
cf37d684
...
@@ -2,6 +2,7 @@ doSQLprint: Error: duplicate key value violates unique constraint "test_pkey" on
...
@@ -2,6 +2,7 @@ doSQLprint: Error: duplicate key value violates unique constraint "test_pkey" on
INSERT: -239=duplicate key value violates unique constraint "test_pkey" on line 32
INSERT: -239=duplicate key value violates unique constraint "test_pkey" on line 32
doSQLprint: Error: more than one row returned by a subquery used as an expression on line 40
doSQLprint: Error: more than one row returned by a subquery used as an expression on line 40
SELECT: 0=
SELECT: 0=
0
7 0 "test"
7 0 "test"
14 1 "a"
14 1 "a"
DELETE: 100
DELETE: 100
...
...
src/interfaces/ecpg/test/expected/connect-test1.stderr
View file @
cf37d684
...
@@ -47,7 +47,7 @@
...
@@ -47,7 +47,7 @@
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: raising sqlcode -402 on line 53: could not connect to database "nonexistant" on line 53
[NO_PID]: raising sqlcode -402 on line 53: could not connect to database "nonexistant" on line 53
[NO_PID]: sqlca: code: -402, state: 08001
[NO_PID]: sqlca: code: -402, state: 08001
[NO_PID]: raising sqlcode -220 on line 54:
no such connection CURRENT
on line 54
[NO_PID]: raising sqlcode -220 on line 54:
connection "CURRENT" does not exist
on line 54
[NO_PID]: sqlca: code: -220, state: 08003
[NO_PID]: sqlca: code: -220, state: 08003
[NO_PID]: ECPGconnect: opening database connectdb on localhost port <REGRESSION_PORT> for user connectuser
[NO_PID]: ECPGconnect: opening database connectdb on localhost port <REGRESSION_PORT> for user connectuser
[NO_PID]: sqlca: code: 0, state: 00000
[NO_PID]: sqlca: code: 0, state: 00000
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment