]> granicus.if.org Git - postgresql/commitdiff
Use "g" not "f" format in ecpg's PGTYPESnumeric_from_double().
authorTom Lane <tgl@sss.pgh.pa.us>
Tue, 1 Dec 2015 16:42:25 +0000 (11:42 -0500)
committerTom Lane <tgl@sss.pgh.pa.us>
Tue, 1 Dec 2015 16:42:25 +0000 (11:42 -0500)
The previous coding could overrun the provided buffer size for a very large
input, or lose precision for a very small input.  Adopt the methodology
that's been in use in the equivalent backend code for a long time.

Per private report from Bas van Schaik.  Back-patch to all supported
branches.

src/interfaces/ecpg/pgtypeslib/numeric.c

index 0504f3cac8a632939a0a66ced9f38b77be16b79d..d061616787e970436e72ef959bd55f08e2944a6b 100644 (file)
@@ -2,6 +2,7 @@
 
 #include "postgres_fe.h"
 #include <ctype.h>
+#include <float.h>
 #include <limits.h>
 
 #include "extern.h"
@@ -1497,11 +1498,11 @@ PGTYPESnumeric_copy(numeric *src, numeric *dst)
 int
 PGTYPESnumeric_from_double(double d, numeric *dst)
 {
-       char            buffer[100];
+       char            buffer[DBL_DIG + 100];
        numeric    *tmp;
        int                     i;
 
-       if (sprintf(buffer, "%f", d) == 0)
+       if (sprintf(buffer, "%.*g", DBL_DIG, d) <= 0)
                return -1;
 
        if ((tmp = PGTYPESnumeric_from_asc(buffer, NULL)) == NULL)