diff --git a/src/interfaces/ecpg/ChangeLog b/src/interfaces/ecpg/ChangeLog index c42a6b2599f241aa405ed699b160124347c21888..93622d5142efab22a94a17196588451a8550dabc 100644 --- a/src/interfaces/ecpg/ChangeLog +++ b/src/interfaces/ecpg/ChangeLog @@ -1563,6 +1563,12 @@ Tue Jul 8 12:34:00 CEST 2003 - Made Informix decimal-ascii conversion honor Informix NULLs. - Informix variable handling didn't cope well with arrays. + +Wed Jul 9 11:45:02 CEST 2003 + + - Made all Informix functions honor Informix NULLs. + - Extended compatibility functions for INFORMIX handling of DECLARE + statement to work with indicators. - 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/compatlib/informix.c b/src/interfaces/ecpg/compatlib/informix.c index 985704393c9e27ccd9621e1c9fd29f6674fe87d3..d8bbd0d434e4bfc2195d2c9d93954bd7192bc37f 100644 --- a/src/interfaces/ecpg/compatlib/informix.c +++ b/src/interfaces/ecpg/compatlib/informix.c @@ -55,6 +55,12 @@ deccall3(Decimal *arg1, Decimal *arg2, Decimal *result, int (*ptr)(Numeric *, Nu Numeric *a1, *a2, *nres; int i; + if (risnull(CDECIMALTYPE, (char *)arg1) || risnull(CDECIMALTYPE, (char *)arg2)) + { + rsetnull(CDECIMALTYPE, (char *)result); + return 0; + } + if ((a1 = PGTYPESnumeric_new()) == NULL) return -1211; @@ -191,6 +197,12 @@ deccvdbl(double dbl, Decimal *np) Numeric *nres = PGTYPESnumeric_new(); int result = 1; + if (risnull(CDOUBLETYPE, (char *)&dbl)) + { + rsetnull(CDECIMALTYPE, (char *)np); + return 0; + } + if (nres == NULL) return -1211; @@ -208,6 +220,12 @@ deccvint(int in, Decimal *np) Numeric *nres = PGTYPESnumeric_new(); int result = 1; + if (risnull(CINTTYPE, (char *)&in)) + { + rsetnull(CDECIMALTYPE, (char *)np); + return 0; + } + if (nres == NULL) return -1211; @@ -225,6 +243,12 @@ deccvlong(long lng, Decimal *np) Numeric *nres = PGTYPESnumeric_new(); int result = 1; + if (risnull(CLONGTYPE, (char *)&lng)) + { + rsetnull(CDECIMALTYPE, (char *)np); + return 0; + } + if (nres == NULL) return -1211;