Commit 9c68834b authored by Michael Meskes's avatar Michael Meskes

Return error if allocation of new element was not possible.

Found by Coverity.
parent 579dae5b
...@@ -430,14 +430,18 @@ PGTYPESnumeric_to_asc(numeric *num, int dscale) ...@@ -430,14 +430,18 @@ PGTYPESnumeric_to_asc(numeric *num, int dscale)
numeric *numcopy = PGTYPESnumeric_new(); numeric *numcopy = PGTYPESnumeric_new();
char *s; char *s;
if (dscale < 0) if (numcopy == NULL)
dscale = num->dscale; return NULL;
if (PGTYPESnumeric_copy(num, numcopy) < 0) if (PGTYPESnumeric_copy(num, numcopy) < 0)
{ {
PGTYPESnumeric_free(numcopy); PGTYPESnumeric_free(numcopy);
return NULL; return NULL;
} }
if (dscale < 0)
dscale = num->dscale;
/* get_str_from_var may change its argument */ /* get_str_from_var may change its argument */
s = get_str_from_var(numcopy, dscale); s = get_str_from_var(numcopy, dscale);
PGTYPESnumeric_free(numcopy); PGTYPESnumeric_free(numcopy);
...@@ -1519,6 +1523,9 @@ numericvar_to_double(numeric *var, double *dp) ...@@ -1519,6 +1523,9 @@ numericvar_to_double(numeric *var, double *dp)
char *endptr; char *endptr;
numeric *varcopy = PGTYPESnumeric_new(); numeric *varcopy = PGTYPESnumeric_new();
if (varcopy == NULL)
return -1;
if (PGTYPESnumeric_copy(var, varcopy) < 0) if (PGTYPESnumeric_copy(var, varcopy) < 0)
{ {
PGTYPESnumeric_free(varcopy); PGTYPESnumeric_free(varcopy);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment