diff --git a/src/backend/utils/adt/float.c b/src/backend/utils/adt/float.c index 82e95704fb1e05f2fa10413d89f7b7f90e3f83c2..f396b1d1cce5be2fbc1d664c260b8d2e1643c8a4 100644 --- a/src/backend/utils/adt/float.c +++ b/src/backend/utils/adt/float.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $PostgreSQL: pgsql/src/backend/utils/adt/float.c,v 1.165 2010/02/08 20:39:51 tgl Exp $ + * $PostgreSQL: pgsql/src/backend/utils/adt/float.c,v 1.166 2010/02/27 21:53:21 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -130,7 +130,8 @@ get_float4_infinity(void) double get_float8_nan(void) { -#ifdef NAN + /* (double) NAN doesn't work on some NetBSD/MIPS releases */ +#if defined(NAN) && !(defined(__NetBSD__) && defined(__mips__)) /* C99 standard way */ return (double) NAN; #else diff --git a/src/interfaces/ecpg/ecpglib/data.c b/src/interfaces/ecpg/ecpglib/data.c index f5190049e12e04375ba1885064aad291d8336c50..5035dbd705326f7ef4551384c39d23fc3a7c7f41 100644 --- a/src/interfaces/ecpg/ecpglib/data.c +++ b/src/interfaces/ecpg/ecpglib/data.c @@ -1,10 +1,11 @@ -/* $PostgreSQL: pgsql/src/interfaces/ecpg/ecpglib/data.c,v 1.50 2010/02/26 02:01:29 momjian Exp $ */ +/* $PostgreSQL: pgsql/src/interfaces/ecpg/ecpglib/data.c,v 1.51 2010/02/27 21:53:21 tgl Exp $ */ #define POSTGRES_ECPG_INTERNAL #include "postgres_fe.h" #include <stdlib.h> #include <string.h> +#include <float.h> #include <math.h> #include "ecpgtype.h" @@ -85,7 +86,8 @@ get_float8_infinity(void) static double get_float8_nan(void) { -#ifdef NAN + /* (double) NAN doesn't work on some NetBSD/MIPS releases */ +#if defined(NAN) && !(defined(__NetBSD__) && defined(__mips__)) return (double) NAN; #else return (double) (0.0 / 0.0); diff --git a/src/test/regress/expected/float4-exp-three-digits.out b/src/test/regress/expected/float4-exp-three-digits.out index b849910151da3cb40e79a954b0984bee3d6588f8..ff680f4792f4288db1a62024df8417bfb5b9f50b 100644 --- a/src/test/regress/expected/float4-exp-three-digits.out +++ b/src/test/regress/expected/float4-exp-three-digits.out @@ -119,6 +119,12 @@ SELECT 'nan'::float4 / 'nan'::float4; NaN (1 row) +SELECT 'nan'::numeric::float4; + float4 +-------- + NaN +(1 row) + SELECT '' AS five, * FROM FLOAT4_TBL; five | f1 ------+-------------- diff --git a/src/test/regress/expected/float4.out b/src/test/regress/expected/float4.out index 2c19e7eb086d02b83ac1b7d1b79afe8f6a9b802d..dd8066a79c385e29537116b55b3dcfe4faa95592 100644 --- a/src/test/regress/expected/float4.out +++ b/src/test/regress/expected/float4.out @@ -119,6 +119,12 @@ SELECT 'nan'::float4 / 'nan'::float4; NaN (1 row) +SELECT 'nan'::numeric::float4; + float4 +-------- + NaN +(1 row) + SELECT '' AS five, * FROM FLOAT4_TBL; five | f1 ------+------------- diff --git a/src/test/regress/expected/float8-exp-three-digits-win32.out b/src/test/regress/expected/float8-exp-three-digits-win32.out index 4d133b42dcdc704fc3d02407f72b8c7801215d30..a4b8b47badb525443801ce3dfe3e71ad64d297fb 100644 --- a/src/test/regress/expected/float8-exp-three-digits-win32.out +++ b/src/test/regress/expected/float8-exp-three-digits-win32.out @@ -119,6 +119,12 @@ SELECT 'nan'::float8 / 'nan'::float8; NaN (1 row) +SELECT 'nan'::numeric::float8; + float8 +-------- + NaN +(1 row) + SELECT '' AS five, * FROM FLOAT8_TBL; five | f1 ------+---------------------- diff --git a/src/test/regress/expected/float8-small-is-zero.out b/src/test/regress/expected/float8-small-is-zero.out index 6c756a6f8ee08b82c3ab9c991d1d4b342bc63d61..3037892ffe62f0c218b610a056f9334a14451e23 100644 --- a/src/test/regress/expected/float8-small-is-zero.out +++ b/src/test/regress/expected/float8-small-is-zero.out @@ -123,6 +123,12 @@ SELECT 'nan'::float8 / 'nan'::float8; NaN (1 row) +SELECT 'nan'::numeric::float8; + float8 +-------- + NaN +(1 row) + SELECT '' AS five, * FROM FLOAT8_TBL; five | f1 ------+---------------------- diff --git a/src/test/regress/expected/float8-small-is-zero_1.out b/src/test/regress/expected/float8-small-is-zero_1.out index 8b25f0955c2647f62ec4a803d4e5fec32ae2f174..c48bb538c4c73f637877fffc6810b802c4e9e5ec 100644 --- a/src/test/regress/expected/float8-small-is-zero_1.out +++ b/src/test/regress/expected/float8-small-is-zero_1.out @@ -123,6 +123,12 @@ SELECT 'nan'::float8 / 'nan'::float8; NaN (1 row) +SELECT 'nan'::numeric::float8; + float8 +-------- + NaN +(1 row) + SELECT '' AS five, * FROM FLOAT8_TBL; five | f1 ------+---------------------- diff --git a/src/test/regress/expected/float8.out b/src/test/regress/expected/float8.out index e9e71bb7aa10a957e77b3cfc48ff19f3a5e54351..d8350d100ec11fe0cee961ae09b5e0d2ef40c7a3 100644 --- a/src/test/regress/expected/float8.out +++ b/src/test/regress/expected/float8.out @@ -119,6 +119,12 @@ SELECT 'nan'::float8 / 'nan'::float8; NaN (1 row) +SELECT 'nan'::numeric::float8; + float8 +-------- + NaN +(1 row) + SELECT '' AS five, * FROM FLOAT8_TBL; five | f1 ------+---------------------- diff --git a/src/test/regress/sql/float4.sql b/src/test/regress/sql/float4.sql index 5944e2fc14902ba5bb7fb2f678a5acfc6392f39e..4cde9d742f31e3898539c00969eb1bcf9a719c0a 100644 --- a/src/test/regress/sql/float4.sql +++ b/src/test/regress/sql/float4.sql @@ -40,7 +40,7 @@ SELECT ' INFINITY x'::float4; SELECT 'Infinity'::float4 + 100.0; SELECT 'Infinity'::float4 / 'Infinity'::float4; SELECT 'nan'::float4 / 'nan'::float4; - +SELECT 'nan'::numeric::float4; SELECT '' AS five, * FROM FLOAT4_TBL; diff --git a/src/test/regress/sql/float8.sql b/src/test/regress/sql/float8.sql index 92b6b0d7b96edbab9fcfc93e240ef5b17b347123..142e6d7d737d0c4ee1d41a4a1fee4027aa151a07 100644 --- a/src/test/regress/sql/float8.sql +++ b/src/test/regress/sql/float8.sql @@ -40,6 +40,7 @@ SELECT ' INFINITY x'::float8; SELECT 'Infinity'::float8 + 100.0; SELECT 'Infinity'::float8 / 'Infinity'::float8; SELECT 'nan'::float8 / 'nan'::float8; +SELECT 'nan'::numeric::float8; SELECT '' AS five, * FROM FLOAT8_TBL;