From 4505653e54eb768c2ec4777638cc900859f0175a Mon Sep 17 00:00:00 2001 From: Michael Meskes <meskes@postgresql.org> Date: Thu, 26 Jun 2003 11:37:05 +0000 Subject: [PATCH] Added just another compatibility level for Informix. --- src/interfaces/ecpg/ChangeLog | 10 ++++++++++ src/interfaces/ecpg/ecpglib/connect.c | 4 ++-- src/interfaces/ecpg/ecpglib/data.c | 4 ++-- src/interfaces/ecpg/ecpglib/execute.c | 8 +++++--- src/interfaces/ecpg/ecpglib/extern.h | 3 ++- src/interfaces/ecpg/ecpglib/prepare.c | 4 ++-- src/interfaces/ecpg/preproc/ecpg.c | 12 +++++++----- src/interfaces/ecpg/preproc/extern.h | 3 ++- src/interfaces/ecpg/preproc/pgc.l | 20 ++++++++++---------- src/interfaces/ecpg/preproc/preproc.y | 6 ++---- src/interfaces/ecpg/test/test_informix.pgc | 7 ++++++- 11 files changed, 50 insertions(+), 31 deletions(-) diff --git a/src/interfaces/ecpg/ChangeLog b/src/interfaces/ecpg/ChangeLog index a8daf97af74..67629d5bea9 100644 --- a/src/interfaces/ecpg/ChangeLog +++ b/src/interfaces/ecpg/ChangeLog @@ -1514,6 +1514,16 @@ Fri Jun 20 15:34:29 CEST 2003 Sun Jun 22 11:20:29 CEST 2003 - Fixed missing '\0' in output char pointer. + +Wed Jun 25 09:29:34 CEST 2003 + + - Synced keyword.x and preproc.y/gram.y. + - Implemented Informix special way to treat NULLs. + +Thu Jun 26 13:26:13 CEST 2003 + + - Added another compatibility level INFORMIX_SE. + - Synced again. - Set ecpg version to 3.0.0 - Set ecpg library to 4.0.0 - Set pgtypes library to 1.0.0 diff --git a/src/interfaces/ecpg/ecpglib/connect.c b/src/interfaces/ecpg/ecpglib/connect.c index cda4bbd15bf..77505f1184a 100644 --- a/src/interfaces/ecpg/ecpglib/connect.c +++ b/src/interfaces/ecpg/ecpglib/connect.c @@ -1,4 +1,4 @@ -/* $Header: /cvsroot/pgsql/src/interfaces/ecpg/ecpglib/connect.c,v 1.8 2003/06/25 10:44:21 meskes Exp $ */ +/* $Header: /cvsroot/pgsql/src/interfaces/ecpg/ecpglib/connect.c,v 1.9 2003/06/26 11:37:05 meskes Exp $ */ #define POSTGRES_ECPG_INTERNAL #include "postgres_fe.h" @@ -304,7 +304,7 @@ ECPGconnect(int lineno, int c, const char *name, const char *user, const char *p ECPGinit_sqlca(sqlca); - if (compat == ECPG_COMPAT_INFORMIX) + if (INFORMIX_MODE(compat)) { char *envname; diff --git a/src/interfaces/ecpg/ecpglib/data.c b/src/interfaces/ecpg/ecpglib/data.c index 8e0138d527d..77f35e639e0 100644 --- a/src/interfaces/ecpg/ecpglib/data.c +++ b/src/interfaces/ecpg/ecpglib/data.c @@ -1,4 +1,4 @@ -/* $Header: /cvsroot/pgsql/src/interfaces/ecpg/ecpglib/data.c,v 1.8 2003/06/25 10:44:21 meskes Exp $ */ +/* $Header: /cvsroot/pgsql/src/interfaces/ecpg/ecpglib/data.c,v 1.9 2003/06/26 11:37:05 meskes Exp $ */ #define POSTGRES_ECPG_INTERNAL #include "postgres_fe.h" @@ -78,7 +78,7 @@ ECPGget_data(const PGresult *results, int act_tuple, int act_field, int lineno, break; #endif /* HAVE_LONG_LONG_INT_64 */ case ECPGt_NO_INDICATOR: - if (force_indicator == false && compat == ECPG_COMPAT_INFORMIX) + if (force_indicator == false) { /* Informix has an additional way to specify NULLs * note that this uses special values to denote NULL */ diff --git a/src/interfaces/ecpg/ecpglib/execute.c b/src/interfaces/ecpg/ecpglib/execute.c index af4d23b7e79..ad5ab5d1f02 100644 --- a/src/interfaces/ecpg/ecpglib/execute.c +++ b/src/interfaces/ecpg/ecpglib/execute.c @@ -1,4 +1,4 @@ -/* $Header: /cvsroot/pgsql/src/interfaces/ecpg/ecpglib/execute.c,v 1.12 2003/06/25 10:44:21 meskes Exp $ */ +/* $Header: /cvsroot/pgsql/src/interfaces/ecpg/ecpglib/execute.c,v 1.13 2003/06/26 11:37:05 meskes Exp $ */ /* * The aim is to get a simpler inteface to the database routines. @@ -508,7 +508,7 @@ ECPGstore_input(const struct statement * stmt, const struct variable * var, break; #endif /* HAVE_LONG_LONG_INT_64 */ case ECPGt_NO_INDICATOR: - if (stmt->force_indicator == false && stmt->compat == ECPG_COMPAT_INFORMIX) + if (stmt->force_indicator == false) { if (ECPGis_informix_null(var->type, var->value)) *tobeinserted_p = "null"; @@ -1186,7 +1186,9 @@ ECPGexecute(struct statement * stmt) sqlca->sqlerrd[1] = PQoidValue(results); sqlca->sqlerrd[2] = atol(PQcmdTuples(results)); ECPGlog("ECPGexecute line %d Ok: %s\n", stmt->lineno, cmdstat); - if (!sqlca->sqlerrd[2] && ( !strncmp(cmdstat, "UPDATE", 6) + if (stmt->compat != ECPG_COMPAT_INFORMIX_SE && + !sqlca->sqlerrd[2] && + ( !strncmp(cmdstat, "UPDATE", 6) || !strncmp(cmdstat, "INSERT", 6) || !strncmp(cmdstat, "DELETE", 6))) ECPGraise(stmt->lineno, ECPG_NOT_FOUND, NULL); diff --git a/src/interfaces/ecpg/ecpglib/extern.h b/src/interfaces/ecpg/ecpglib/extern.h index a7f37491da8..b6b25b8328a 100644 --- a/src/interfaces/ecpg/ecpglib/extern.h +++ b/src/interfaces/ecpg/ecpglib/extern.h @@ -5,7 +5,8 @@ #include "libpq-fe.h" #include "sqlca.h" -enum COMPAT_MODE { ECPG_COMPAT_PGSQL = 0, ECPG_COMPAT_INFORMIX}; +enum COMPAT_MODE { ECPG_COMPAT_PGSQL = 0, ECPG_COMPAT_INFORMIX, ECPG_COMPAT_INFORMIX_SE}; +#define INFORMIX_MODE(X) ((X) == ECPG_COMPAT_INFORMIX || (X) == ECPG_COMPAT_INFORMIX_SE) /* Here are some methods used by the lib. */ diff --git a/src/interfaces/ecpg/ecpglib/prepare.c b/src/interfaces/ecpg/ecpglib/prepare.c index a10f386fc8c..63d7afac701 100644 --- a/src/interfaces/ecpg/ecpglib/prepare.c +++ b/src/interfaces/ecpg/ecpglib/prepare.c @@ -1,4 +1,4 @@ -/* $Header: /cvsroot/pgsql/src/interfaces/ecpg/ecpglib/prepare.c,v 1.4 2003/06/25 10:44:21 meskes Exp $ */ +/* $Header: /cvsroot/pgsql/src/interfaces/ecpg/ecpglib/prepare.c,v 1.5 2003/06/26 11:37:05 meskes Exp $ */ #define POSTGRES_ECPG_INTERNAL #include "postgres_fe.h" @@ -110,7 +110,7 @@ ECPGdeallocate(int lineno, int c, char *name) bool ret = ECPGdeallocate_one(lineno, name); enum COMPAT_MODE compat = c; - if (compat == ECPG_COMPAT_INFORMIX) + if (INFORMIX_MODE(compat)) { /* Just ignore all errors since we do not know the list of cursors we * are allowed to free. We have to trust that the software. */ diff --git a/src/interfaces/ecpg/preproc/ecpg.c b/src/interfaces/ecpg/preproc/ecpg.c index 0256080a50a..42f278057ce 100644 --- a/src/interfaces/ecpg/preproc/ecpg.c +++ b/src/interfaces/ecpg/preproc/ecpg.c @@ -1,4 +1,4 @@ -/* $Header: /cvsroot/pgsql/src/interfaces/ecpg/preproc/ecpg.c,v 1.74 2003/06/25 10:44:21 meskes Exp $ */ +/* $Header: /cvsroot/pgsql/src/interfaces/ecpg/preproc/ecpg.c,v 1.75 2003/06/26 11:37:05 meskes Exp $ */ /* New main for ecpg, the PostgreSQL embedded SQL precompiler. */ /* (C) Michael Meskes <meskes@postgresql.org> Feb 5th, 1998 */ @@ -45,7 +45,9 @@ help(const char *progname) printf(" -d generate parser debug output\n"); #endif printf(" -C <mode> set compatibility mode\n" - " mode may be \"INFORMIX\" only at the moment\n"); + " mode may be one of\n" + " \"INFORMIX\"\n" + " \"INFORMIX_SE\"\n"); printf(" -r <option> specify runtime behaviour\n" " option may be only \"no_indicator\" at the moment\n"); printf(" -D SYMBOL define SYMBOL\n"); @@ -165,9 +167,9 @@ main(int argc, char *const argv[]) system_includes = true; break; case 'C': - if (strcmp(optarg, "INFORMIX") == 0) + if (strncmp(optarg, "INFORMIX", strlen("INFORMIX")) == 0) { - compat = ECPG_COMPAT_INFORMIX; + compat = (strcmp(optarg, "INFORMIX") == 0) ? ECPG_COMPAT_INFORMIX : ECPG_COMPAT_INFORMIX_SE; /* system_includes = true; */ add_preprocessor_define("dec_t=Numeric"); add_preprocessor_define("intrvl_t=Interval"); @@ -383,7 +385,7 @@ main(int argc, char *const argv[]) fprintf(yyout, "/* Processed by ecpg (%d.%d.%d) */\n/* These four include files are added by the preprocessor */\n#include <ecpgtype.h>\n#include <ecpglib.h>\n#include <ecpgerrno.h>\n#include <sqlca.h>\n#line 1 \"%s\"\n", MAJOR_VERSION, MINOR_VERSION, PATCHLEVEL, input_filename); /* add some compatibility headers */ - if (compat == ECPG_COMPAT_INFORMIX) + if (INFORMIX_MODE) fprintf(yyout, "/* Needed for informix compatibility */\n#include <ecpg_informix.h>\n"); /* and parse the source */ diff --git a/src/interfaces/ecpg/preproc/extern.h b/src/interfaces/ecpg/preproc/extern.h index f38cb244ae9..aa76930e7c7 100644 --- a/src/interfaces/ecpg/preproc/extern.h +++ b/src/interfaces/ecpg/preproc/extern.h @@ -96,7 +96,8 @@ extern ScanKeyword *ScanKeywordLookup(char *text); #define INDICATOR_NOT_STRUCT 6 #define INDICATOR_NOT_SIMPLE 7 -enum COMPAT_MODE { ECPG_COMPAT_PGSQL = 0, ECPG_COMPAT_INFORMIX}; +enum COMPAT_MODE { ECPG_COMPAT_PGSQL = 0, ECPG_COMPAT_INFORMIX, ECPG_COMPAT_INFORMIX_SE}; extern enum COMPAT_MODE compat; +#define INFORMIX_MODE (compat == ECPG_COMPAT_INFORMIX || compat == ECPG_COMPAT_INFORMIX_SE) #endif /* _ECPG_PREPROC_EXTERN_H */ diff --git a/src/interfaces/ecpg/preproc/pgc.l b/src/interfaces/ecpg/preproc/pgc.l index f4a1f6cbfd0..57d201b798b 100644 --- a/src/interfaces/ecpg/preproc/pgc.l +++ b/src/interfaces/ecpg/preproc/pgc.l @@ -12,7 +12,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/interfaces/ecpg/preproc/pgc.l,v 1.117 2003/06/20 15:16:06 meskes Exp $ + * $Header: /cvsroot/pgsql/src/interfaces/ecpg/preproc/pgc.l,v 1.118 2003/06/26 11:37:05 meskes Exp $ * *------------------------------------------------------------------------- */ @@ -420,7 +420,7 @@ cppline {space}*#(.*\\{space})+.* <SQL>{typecast} { return TYPECAST; } <SQL>{informix_special} { /* are we simulating Informix? */ - if (compat == ECPG_COMPAT_INFORMIX) + if (INFORMIX_MODE) { unput(':'); } @@ -605,7 +605,7 @@ cppline {space}*#(.*\\{space})+.* <C>{exec_sql} { BEGIN SQL; return SQL_START; } <C>{informix_special} { /* are we simulating Informix? */ - if (compat == ECPG_COMPAT_INFORMIX) + if (INFORMIX_MODE) { BEGIN SQL; return SQL_START; @@ -715,7 +715,7 @@ cppline {space}*#(.*\\{space})+.* <C>{exec_sql}{define}{space}* { BEGIN(def_ident); } <C>{informix_special}{define}{space}* { /* are we simulating Informix? */ - if (compat == ECPG_COMPAT_INFORMIX) + if (INFORMIX_MODE) { BEGIN(def_ident); } @@ -730,7 +730,7 @@ cppline {space}*#(.*\\{space})+.* <C>{exec_sql}{include}{space}* { BEGIN(incl); } <C>{informix_special}{include}{space}* { /* are we simulating Informix? */ - if (compat == ECPG_COMPAT_INFORMIX) + if (INFORMIX_MODE) { BEGIN(incl); } @@ -745,7 +745,7 @@ cppline {space}*#(.*\\{space})+.* <C,xskip>{exec_sql}{ifdef}{space}* { ifcond = TRUE; BEGIN(xcond); } <C,xskip>{informix_special}{ifdef}{space}* { /* are we simulating Informix? */ - if (compat == ECPG_COMPAT_INFORMIX) + if (INFORMIX_MODE) { ifcond = TRUE; BEGIN(xcond); @@ -761,7 +761,7 @@ cppline {space}*#(.*\\{space})+.* <C,xskip>{exec_sql}{ifndef}{space}* { ifcond = FALSE; BEGIN(xcond); } <C,xskip>{informix_special}{ifndef}{space}* { /* are we simulating Informix? */ - if (compat == ECPG_COMPAT_INFORMIX) + if (INFORMIX_MODE) { ifcond = FALSE; BEGIN(xcond); @@ -787,7 +787,7 @@ cppline {space}*#(.*\\{space})+.* } <C,xskip>{informix_special}{elif}{space}* { /* are we simulating Informix? */ - if (compat == ECPG_COMPAT_INFORMIX) + if (INFORMIX_MODE) { if ( preproc_tos == 0 ) { mmerror(PARSE_ERROR, ET_FATAL, "Missing matching 'EXEC SQL IFDEF / EXEC SQL IFNDEF'"); @@ -826,7 +826,7 @@ cppline {space}*#(.*\\{space})+.* } <C,xskip>{informix_special}{else}{space}* { /* are we simulating Informix? */ - if (compat == ECPG_COMPAT_INFORMIX) + if (INFORMIX_MODE) { if ( stacked_if_value[preproc_tos].else_branch ) { mmerror(PARSE_ERROR, ET_FATAL, "Duplicated 'EXEC SQL ELSE;'"); @@ -864,7 +864,7 @@ cppline {space}*#(.*\\{space})+.* } <C,xskip>{informix_special}{endif}{space}*";" { /* are we simulating Informix? */ - if (compat == ECPG_COMPAT_INFORMIX) + if (INFORMIX_MODE) { if ( preproc_tos == 0 ) mmerror(PARSE_ERROR, ET_FATAL, "Unmatched 'EXEC SQL ENDIF;'"); diff --git a/src/interfaces/ecpg/preproc/preproc.y b/src/interfaces/ecpg/preproc/preproc.y index ffa849045a8..2d799705edc 100644 --- a/src/interfaces/ecpg/preproc/preproc.y +++ b/src/interfaces/ecpg/preproc/preproc.y @@ -1,4 +1,4 @@ -/* $Header: /cvsroot/pgsql/src/interfaces/ecpg/preproc/Attic/preproc.y,v 1.239 2003/06/25 21:30:33 momjian Exp $ */ +/* $Header: /cvsroot/pgsql/src/interfaces/ecpg/preproc/Attic/preproc.y,v 1.240 2003/06/26 11:37:05 meskes Exp $ */ /* Copyright comment */ %{ @@ -2674,7 +2674,7 @@ DeclareCursorStmt: DECLARE name cursor_options CURSOR opt_hold FOR SelectStmt argsinsert = argsresult = NULL; cur = this; - if (compat == ECPG_COMPAT_INFORMIX) + if (INFORMIX_MODE) $$ = cat_str(5, adjust_informix(this->argsinsert), adjust_informix(this->argsresult), make_str("/*"), mm_strdup(this->command), make_str("*/")); else $$ = cat_str(3, make_str("/*"), mm_strdup(this->command), make_str("*/")); @@ -3476,8 +3476,6 @@ a_expr: c_expr { $$ = cat_str(3, $1, make_str("not in"), $4); } | a_expr qual_all_Op sub_type select_with_parens %prec Op { $$ = cat_str(4, $1, $2, $3, $4); } - | a_expr qual_all_Op sub_type '(' a_expr ')' %prec Op - { $$ = cat_str(6, $1, $2, $3, make_str("("), $5, make_str(")")); } | UNIQUE select_with_parens %prec Op { $$ = cat2_str(make_str("unique"), $2); } | r_expr diff --git a/src/interfaces/ecpg/test/test_informix.pgc b/src/interfaces/ecpg/test/test_informix.pgc index fd0512c7cde..fdc9a97954f 100644 --- a/src/interfaces/ecpg/test/test_informix.pgc +++ b/src/interfaces/ecpg/test/test_informix.pgc @@ -34,8 +34,13 @@ int main() else printf("%d %d\n", i, j); } - + + $delete from test where i=87; + printf("delete: %ld\n", sqlca.sqlcode); + + $commit; $drop table test; + $commit; $disconnect; -- GitLab