mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-12 18:34:36 +08:00
Fix potential buffer overrun in cube_out(), per report from
Bruno Wolff.
This commit is contained in:
parent
22bfa72068
commit
e1b040a7c3
@ -10,6 +10,7 @@
|
||||
|
||||
#include "access/gist.h"
|
||||
#include "access/rtree.h"
|
||||
#include "lib/stringinfo.h"
|
||||
#include "utils/elog.h"
|
||||
#include "utils/palloc.h"
|
||||
#include "utils/builtins.h"
|
||||
@ -109,45 +110,41 @@ cube_in(char *str)
|
||||
char *
|
||||
cube_out(NDBOX *cube)
|
||||
{
|
||||
char *result;
|
||||
char *p;
|
||||
int equal = 1;
|
||||
StringInfoData buf;
|
||||
bool equal = true;
|
||||
int dim = cube->dim;
|
||||
int i;
|
||||
|
||||
if (cube == NULL)
|
||||
return (NULL);
|
||||
|
||||
p = result = (char *) palloc(100);
|
||||
initStringInfo(&buf);
|
||||
|
||||
/*
|
||||
* while printing the first (LL) corner, check if it is equal to the
|
||||
* scond one
|
||||
* second one
|
||||
*/
|
||||
p += sprintf(p, "(");
|
||||
appendStringInfoChar(&buf, '(');
|
||||
for (i = 0; i < dim; i++)
|
||||
{
|
||||
p += sprintf(p, "%g", cube->x[i]);
|
||||
p += sprintf(p, ", ");
|
||||
if (i > 0)
|
||||
appendStringInfo(&buf, ", ");
|
||||
appendStringInfo(&buf, "%g", cube->x[i]);
|
||||
if (cube->x[i] != cube->x[i + dim])
|
||||
equal = 0;
|
||||
equal = false;
|
||||
}
|
||||
p -= 2; /* get rid of the last ", " */
|
||||
p += sprintf(p, ")");
|
||||
appendStringInfoChar(&buf, ')');
|
||||
|
||||
if (!equal)
|
||||
{
|
||||
p += sprintf(p, ",(");
|
||||
for (i = dim; i < dim * 2; i++)
|
||||
appendStringInfo(&buf, ",(");
|
||||
for (i = 0; i < dim; i++)
|
||||
{
|
||||
p += sprintf(p, "%g", cube->x[i]);
|
||||
p += sprintf(p, ", ");
|
||||
if (i > 0)
|
||||
appendStringInfo(&buf, ", ");
|
||||
appendStringInfo(&buf, "%g", cube->x[i + dim]);
|
||||
}
|
||||
p -= 2;
|
||||
p += sprintf(p, ")");
|
||||
appendStringInfoChar(&buf, ')');
|
||||
}
|
||||
|
||||
return (result);
|
||||
return buf.data;
|
||||
}
|
||||
|
||||
|
||||
|
@ -8,12 +8,12 @@ SET search_path = public;
|
||||
CREATE FUNCTION cube_in(opaque)
|
||||
RETURNS opaque
|
||||
AS 'MODULE_PATHNAME'
|
||||
LANGUAGE 'c';
|
||||
LANGUAGE 'c' WITH (isStrict);
|
||||
|
||||
CREATE FUNCTION cube_out(opaque)
|
||||
RETURNS opaque
|
||||
AS 'MODULE_PATHNAME'
|
||||
LANGUAGE 'c';
|
||||
LANGUAGE 'c' WITH (isStrict);
|
||||
|
||||
CREATE TYPE cube (
|
||||
internallength = variable,
|
||||
|
Loading…
Reference in New Issue
Block a user