mirror of
https://github.com/postgres/postgres.git
synced 2025-10-24 01:29:19 +03:00
Return error if allocation of new element was not possible.
Found by Coverity.
This commit is contained in:
@@ -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);
|
||||||
@@ -1520,6 +1524,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);
|
||||||
|
Reference in New Issue
Block a user