Commit 8c9393c6 authored by Bruce Momjian's avatar Bruce Momjian

Use failure-safe pg_malloc consistently in psql/print.c.

parent 6e1004f0
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
* *
* Copyright (c) 2000-2005, PostgreSQL Global Development Group * Copyright (c) 2000-2005, PostgreSQL Global Development Group
* *
* $PostgreSQL: pgsql/src/bin/psql/print.c,v 1.61 2005/07/10 03:46:13 momjian Exp $ * $PostgreSQL: pgsql/src/bin/psql/print.c,v 1.62 2005/07/10 15:48:14 momjian Exp $
*/ */
#include "postgres_fe.h" #include "postgres_fe.h"
#include "common.h" #include "common.h"
...@@ -77,12 +77,7 @@ format_numericsep(char *my_str, char *numericsep) ...@@ -77,12 +77,7 @@ format_numericsep(char *my_str, char *numericsep)
if (digits_before_sep == 0) if (digits_before_sep == 0)
new_len--; /* no leading separator */ new_len--; /* no leading separator */
new_str = malloc(new_len); new_str = pg_malloc(new_len);
if (!new_str)
{
fprintf(stderr, _("out of memory\n"));
exit(EXIT_FAILURE);
}
for (i=0, j=0; ; i++, j++) for (i=0, j=0; ; i++, j++)
{ {
...@@ -167,13 +162,8 @@ print_unaligned_text(const char *title, const char *const *headers, ...@@ -167,13 +162,8 @@ print_unaligned_text(const char *title, const char *const *headers,
if ((opt_align[i % col_count] == 'r') && strlen(*ptr) > 0 && if ((opt_align[i % col_count] == 'r') && strlen(*ptr) > 0 &&
opt_numericsep != NULL && strlen(opt_numericsep) > 0) opt_numericsep != NULL && strlen(opt_numericsep) > 0)
{ {
char *my_cell = malloc(len_with_numericsep(*ptr)); char *my_cell = pg_malloc(len_with_numericsep(*ptr));
if (!my_cell)
{
fprintf(stderr, _("out of memory\n"));
exit(EXIT_FAILURE);
}
strcpy(my_cell, *ptr); strcpy(my_cell, *ptr);
format_numericsep(my_cell, opt_numericsep); format_numericsep(my_cell, opt_numericsep);
fputs(my_cell, fout); fputs(my_cell, fout);
...@@ -249,13 +239,8 @@ print_unaligned_vertical(const char *title, const char *const *headers, ...@@ -249,13 +239,8 @@ print_unaligned_vertical(const char *title, const char *const *headers,
if ((opt_align[i % col_count] == 'r') && strlen(*ptr) != 0 && if ((opt_align[i % col_count] == 'r') && strlen(*ptr) != 0 &&
opt_numericsep != NULL && strlen(opt_numericsep) > 0) opt_numericsep != NULL && strlen(opt_numericsep) > 0)
{ {
char *my_cell = malloc(len_with_numericsep(*ptr)); char *my_cell = pg_malloc(len_with_numericsep(*ptr));
if (!my_cell)
{
fprintf(stderr, _("out of memory\n"));
exit(EXIT_FAILURE);
}
strcpy(my_cell, *ptr); strcpy(my_cell, *ptr);
format_numericsep(my_cell, opt_numericsep); format_numericsep(my_cell, opt_numericsep);
fputs(my_cell, fout); fputs(my_cell, fout);
...@@ -482,13 +467,8 @@ print_aligned_text(const char *title, const char *const *headers, ...@@ -482,13 +467,8 @@ print_aligned_text(const char *title, const char *const *headers,
{ {
if (strlen(*ptr) > 0 && opt_numericsep != NULL && strlen(opt_numericsep) > 0) if (strlen(*ptr) > 0 && opt_numericsep != NULL && strlen(opt_numericsep) > 0)
{ {
char *my_cell = malloc(cell_w[i]); char *my_cell = pg_malloc(cell_w[i]);
if (!my_cell)
{
fprintf(stderr, _("out of memory\n"));
exit(EXIT_FAILURE);
}
strcpy(my_cell, *ptr); strcpy(my_cell, *ptr);
format_numericsep(my_cell, opt_numericsep); format_numericsep(my_cell, opt_numericsep);
fprintf(fout, "%*s%s", widths[i % col_count] - cell_w[i], "", my_cell); fprintf(fout, "%*s%s", widths[i % col_count] - cell_w[i], "", my_cell);
...@@ -634,12 +614,7 @@ print_aligned_vertical(const char *title, const char *const *headers, ...@@ -634,12 +614,7 @@ print_aligned_vertical(const char *title, const char *const *headers,
fprintf(fout, "%s\n", title); fprintf(fout, "%s\n", title);
/* make horizontal border */ /* make horizontal border */
divider = malloc(hwidth + dwidth + 10); divider = pg_malloc(hwidth + dwidth + 10);
if (!divider)
{
fprintf(stderr, _("out of memory\n"));
exit(EXIT_FAILURE);
}
divider[0] = '\0'; divider[0] = '\0';
if (opt_border == 2) if (opt_border == 2)
strcat(divider, "+-"); strcat(divider, "+-");
...@@ -661,15 +636,9 @@ print_aligned_vertical(const char *title, const char *const *headers, ...@@ -661,15 +636,9 @@ print_aligned_vertical(const char *title, const char *const *headers,
{ {
if (!opt_barebones) if (!opt_barebones)
{ {
char *record_str = malloc(32); char *record_str = pg_malloc(32);
size_t record_str_len; size_t record_str_len;
if (!record_str)
{
fprintf(stderr, _("out of memory\n"));
exit(EXIT_FAILURE);
}
if (opt_border == 0) if (opt_border == 0)
snprintf(record_str, 32, "* Record %d", record++); snprintf(record_str, 32, "* Record %d", record++);
else else
...@@ -709,13 +678,8 @@ print_aligned_vertical(const char *title, const char *const *headers, ...@@ -709,13 +678,8 @@ print_aligned_vertical(const char *title, const char *const *headers,
fputs(" ", fout); fputs(" ", fout);
{ {
char *my_cell = malloc(cell_w[i]); char *my_cell = pg_malloc(cell_w[i]);
if (!my_cell)
{
fprintf(stderr, _("out of memory\n"));
exit(EXIT_FAILURE);
}
strcpy(my_cell, *ptr); strcpy(my_cell, *ptr);
if ((opt_align[i % col_count] == 'r') && strlen(*ptr) != 0 && if ((opt_align[i % col_count] == 'r') && strlen(*ptr) != 0 &&
opt_numericsep != NULL && strlen(opt_numericsep) > 0) opt_numericsep != NULL && strlen(opt_numericsep) > 0)
...@@ -855,13 +819,8 @@ print_html_text(const char *title, const char *const *headers, ...@@ -855,13 +819,8 @@ print_html_text(const char *title, const char *const *headers,
else if ((opt_align[i % col_count] == 'r') && strlen(*ptr) != 0 && else if ((opt_align[i % col_count] == 'r') && strlen(*ptr) != 0 &&
opt_numericsep != NULL && strlen(opt_numericsep) > 0) opt_numericsep != NULL && strlen(opt_numericsep) > 0)
{ {
char *my_cell = malloc(len_with_numericsep(*ptr)); char *my_cell = pg_malloc(len_with_numericsep(*ptr));
if (!my_cell)
{
fprintf(stderr, _("out of memory\n"));
exit(EXIT_FAILURE);
}
strcpy(my_cell, *ptr); strcpy(my_cell, *ptr);
format_numericsep(my_cell, opt_numericsep); format_numericsep(my_cell, opt_numericsep);
html_escaped_print(my_cell, fout); html_escaped_print(my_cell, fout);
...@@ -946,13 +905,8 @@ print_html_vertical(const char *title, const char *const *headers, ...@@ -946,13 +905,8 @@ print_html_vertical(const char *title, const char *const *headers,
else if ((opt_align[i % col_count] == 'r') && strlen(*ptr) != 0 && else if ((opt_align[i % col_count] == 'r') && strlen(*ptr) != 0 &&
opt_numericsep != NULL && strlen(opt_numericsep) > 0) opt_numericsep != NULL && strlen(opt_numericsep) > 0)
{ {
char *my_cell = malloc(len_with_numericsep(*ptr)); char *my_cell = pg_malloc(len_with_numericsep(*ptr));
if (!my_cell)
{
fprintf(stderr, _("out of memory\n"));
exit(EXIT_FAILURE);
}
strcpy(my_cell, *ptr); strcpy(my_cell, *ptr);
format_numericsep(my_cell, opt_numericsep); format_numericsep(my_cell, opt_numericsep);
html_escaped_print(my_cell, fout); html_escaped_print(my_cell, fout);
...@@ -1646,12 +1600,7 @@ printQuery(const PGresult *result, const printQueryOpt *opt, FILE *fout, FILE *f ...@@ -1646,12 +1600,7 @@ printQuery(const PGresult *result, const printQueryOpt *opt, FILE *fout, FILE *f
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
footers[0] = malloc(100); footers[0] = pg_malloc(100);
if (!footers[0])
{
fprintf(stderr, _("out of memory\n"));
exit(EXIT_FAILURE);
}
if (PQntuples(result) == 1) if (PQntuples(result) == 1)
snprintf(footers[0], 100, _("(1 row)")); snprintf(footers[0], 100, _("(1 row)"));
else else
......
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