From 92eee0fac374408eb0d230581a8bd3aa044a614f Mon Sep 17 00:00:00 2001 From: robocop Date: Tue, 28 Apr 2009 17:15:00 +0000 Subject: [PATCH] Solve the display problem in Windows where select cot(0) + 1 from rdb$database; produces 1.#INF00000000000 Now it says Infinity but only Windows and Solaris are covered. --- src/isql/isql.epp | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/src/isql/isql.epp b/src/isql/isql.epp index 461eae835c..aff073ffdb 100644 --- a/src/isql/isql.epp +++ b/src/isql/isql.epp @@ -66,6 +66,8 @@ #ifdef SOLARIS #include +#elif defined(WIN_NT) +#include #endif #ifdef HAVE_UNISTD_H @@ -341,7 +343,7 @@ static processing_state newoutput(const TEXT*); static processing_state newsize(const TEXT*, const TEXT*); static processing_state newRowCount(const TEXT* newRowCountStr); static processing_state newtrans(const TEXT*); -static processing_state parse_arg(int, SCHAR**, SCHAR*, FILE**); +static processing_state parse_arg(int, SCHAR**, SCHAR*); //, FILE**); #ifdef DEV_BUILD static processing_state passthrough(const char* cmd); #endif @@ -587,7 +589,7 @@ int ISQL_main(int argc, isqlGlob.Out = stdout; isqlGlob.Errfp = stderr; - const processing_state ret = parse_arg(argc, argv, tabname, NULL); + const processing_state ret = parse_arg(argc, argv, tabname); // Can't do a simple assignment because parse_arg may set Interactive to false. if (stdin_redirected()) @@ -6720,7 +6722,8 @@ static processing_state newtrans(const TEXT* statement) } -static processing_state parse_arg(int argc, SCHAR** argv, SCHAR* tabname, FILE** sess) +static processing_state parse_arg(int argc, SCHAR** argv, SCHAR* tabname) +// , FILE** sess) Last param was for wisql { /************************************** * @@ -7143,6 +7146,11 @@ static bool checkSpecial(TEXT* const p, const int length, const double value) { t = IsINF(value) ? "Infinity" : "NaN"; } +#elif defined(WIN_NT) + if (!_finite(value)) + { + t = _isnan(value) ? "NaN" : "Infinity"; + } #endif if (! t) {