aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Meskes <meskes@postgresql.org>2013-09-08 12:59:43 +0200
committerMichael Meskes <meskes@postgresql.org>2013-09-08 13:13:03 +0200
commit1eea0ebddcea776ec771f9a3a62feb83a68b54ea (patch)
tree7456b2025332aa3e372ab6c0135480e4f759e1ce
parent3560dbcaac2f0ccb796512d6daf7ff3ea5bab5f0 (diff)
downloadpostgresql-1eea0ebddcea776ec771f9a3a62feb83a68b54ea.tar.gz
postgresql-1eea0ebddcea776ec771f9a3a62feb83a68b54ea.zip
Return error if allocation of new element was not possible.
Found by Coverity.
-rw-r--r--src/interfaces/ecpg/pgtypeslib/numeric.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/src/interfaces/ecpg/pgtypeslib/numeric.c b/src/interfaces/ecpg/pgtypeslib/numeric.c
index c56dda026ac..9ae975ecde0 100644
--- a/src/interfaces/ecpg/pgtypeslib/numeric.c
+++ b/src/interfaces/ecpg/pgtypeslib/numeric.c
@@ -430,14 +430,18 @@ PGTYPESnumeric_to_asc(numeric *num, int dscale)
numeric *numcopy = PGTYPESnumeric_new();
char *s;
- if (dscale < 0)
- dscale = num->dscale;
+ if (numcopy == NULL)
+ return NULL;
if (PGTYPESnumeric_copy(num, numcopy) < 0)
{
PGTYPESnumeric_free(numcopy);
return NULL;
}
+
+ if (dscale < 0)
+ dscale = num->dscale;
+
/* get_str_from_var may change its argument */
s = get_str_from_var(numcopy, dscale);
PGTYPESnumeric_free(numcopy);
@@ -1519,6 +1523,9 @@ numericvar_to_double(numeric *var, double *dp)
char *endptr;
numeric *varcopy = PGTYPESnumeric_new();
+ if (varcopy == NULL)
+ return -1;
+
if (PGTYPESnumeric_copy(var, varcopy) < 0)
{
PGTYPESnumeric_free(varcopy);