Fix one-byte buffer overrun in PQprintTuples().

This bug goes back to the original Postgres95 sources.  Its significance
to modern PG versions is marginal, since we have not used PQprintTuples()
internally in a very long time, and it doesn't seem to have ever been
documented either.  Still, it *is* exposed to client apps, so somebody
out there might possibly be using it.

Xi Wang
pull/3/head
Tom Lane 13 years ago
parent 535e69a43f
commit 8f0d8f481e
  1. 7
      src/interfaces/libpq/fe-print.c

@ -681,7 +681,6 @@ PQprintTuples(const PGresult *res,
int i,
j;
char formatString[80];
char *tborder = NULL;
nFields = PQnfields(res);
@ -700,15 +699,15 @@ PQprintTuples(const PGresult *res,
int width;
width = nFields * 14;
tborder = malloc(width + 1);
tborder = (char *) malloc(width + 1);
if (!tborder)
{
fprintf(stderr, libpq_gettext("out of memory\n"));
abort();
}
for (i = 0; i <= width; i++)
for (i = 0; i < width; i++)
tborder[i] = '-';
tborder[i] = '\0';
tborder[width] = '\0';
fprintf(fout, "%s\n", tborder);
}

Loading…
Cancel
Save