From 507465525e8c3e4ebf0159ac07c915dd609cd6b3 Mon Sep 17 00:00:00 2001 From: Bruce Momjian <bruce@momjian.us> Date: Mon, 18 Jul 2005 20:57:53 +0000 Subject: [PATCH] \pset numericsep -> numericlocale. --- doc/src/sgml/ref/psql-ref.sgml | 4 +- src/bin/psql/command.c | 14 ++-- src/bin/psql/help.c | 4 +- src/bin/psql/print.c | 131 +++++++++++++++++---------------- src/bin/psql/print.h | 4 +- 5 files changed, 79 insertions(+), 78 deletions(-) diff --git a/doc/src/sgml/ref/psql-ref.sgml b/doc/src/sgml/ref/psql-ref.sgml index d5402bf90df..6ae788067ed 100644 --- a/doc/src/sgml/ref/psql-ref.sgml +++ b/doc/src/sgml/ref/psql-ref.sgml @@ -1,5 +1,5 @@ <!-- -$PostgreSQL: pgsql/doc/src/sgml/ref/psql-ref.sgml,v 1.147 2005/07/14 08:42:36 momjian Exp $ +$PostgreSQL: pgsql/doc/src/sgml/ref/psql-ref.sgml,v 1.148 2005/07/18 20:57:52 momjian Exp $ PostgreSQL documentation --> @@ -1493,7 +1493,7 @@ lo_import 152801 </varlistentry> <varlistentry> - <term><literal>numericsep</literal></term> + <term><literal>numericlocale</literal></term> <listitem> <para> Toggles the display of a locale-aware character to separate groups diff --git a/src/bin/psql/command.c b/src/bin/psql/command.c index 0c4db123db5..6e5730e4436 100644 --- a/src/bin/psql/command.c +++ b/src/bin/psql/command.c @@ -3,7 +3,7 @@ * * Copyright (c) 2000-2005, PostgreSQL Global Development Group * - * $PostgreSQL: pgsql/src/bin/psql/command.c,v 1.149 2005/07/14 08:42:37 momjian Exp $ + * $PostgreSQL: pgsql/src/bin/psql/command.c,v 1.150 2005/07/18 20:57:53 momjian Exp $ */ #include "postgres_fe.h" #include "command.h" @@ -1420,16 +1420,16 @@ do_pset(const char *param, const char *value, printQueryOpt *popt, bool quiet) : _("Expanded display is off.\n")); } - /* numeric separators */ - else if (strcmp(param, "numericsep") == 0) + /* locale-aware numeric output */ + else if (strcmp(param, "numericlocale") == 0) { - popt->topt.numericSep = !popt->topt.numericSep; + popt->topt.numericLocale = !popt->topt.numericLocale; if (!quiet) { - if (popt->topt.numericSep) - puts(_("Showing numeric separators.")); + if (popt->topt.numericLocale) + puts(_("Showing locale-adjusted numeric output.")); else - puts(_("Numeric separators are off.")); + puts(_("Locale-adjusted numeric output is off.")); } } diff --git a/src/bin/psql/help.c b/src/bin/psql/help.c index 1d24cffd02a..7d6cc7e4a08 100644 --- a/src/bin/psql/help.c +++ b/src/bin/psql/help.c @@ -3,7 +3,7 @@ * * Copyright (c) 2000-2005, PostgreSQL Global Development Group * - * $PostgreSQL: pgsql/src/bin/psql/help.c,v 1.104 2005/07/10 03:46:13 momjian Exp $ + * $PostgreSQL: pgsql/src/bin/psql/help.c,v 1.105 2005/07/18 20:57:53 momjian Exp $ */ #include "postgres_fe.h" #include "common.h" @@ -239,7 +239,7 @@ slashUsage(unsigned short int pager) fprintf(output, _(" \\pset NAME [VALUE]\n" " set table output option\n" " (NAME := {format|border|expanded|fieldsep|footer|null|\n" - " numericsep|recordsep|tuples_only|title|tableattr|pager})\n")); + " numericlocale|recordsep|tuples_only|title|tableattr|pager})\n")); fprintf(output, _(" \\t show only rows (currently %s)\n"), ON(pset.popt.topt.tuples_only)); fprintf(output, _(" \\T [STRING] set HTML <table> tag attributes, or unset if none\n")); diff --git a/src/bin/psql/print.c b/src/bin/psql/print.c index 25d08a81c03..9a1db45d5c3 100644 --- a/src/bin/psql/print.c +++ b/src/bin/psql/print.c @@ -3,7 +3,7 @@ * * Copyright (c) 2000-2005, PostgreSQL Global Development Group * - * $PostgreSQL: pgsql/src/bin/psql/print.c,v 1.71 2005/07/18 19:27:37 momjian Exp $ + * $PostgreSQL: pgsql/src/bin/psql/print.c,v 1.72 2005/07/18 20:57:53 momjian Exp $ */ #include "postgres_fe.h" #include "common.h" @@ -62,8 +62,9 @@ integer_digits(const char *my_str) return strlen(my_str) - frac_len; } +/* Return additional length required for locale-aware numeric output */ static int -len_numericseps(const char *my_str) +additional_numeric_locale_len(const char *my_str) { int int_len = integer_digits(my_str), len = 0; int groupdigits = atoi(grouping); @@ -80,13 +81,13 @@ len_numericseps(const char *my_str) } static int -len_with_numericsep(const char *my_str) +strlen_with_numeric_locale(const char *my_str) { - return strlen(my_str) + len_numericseps(my_str); + return strlen(my_str) + additional_numeric_locale_len(my_str); } static void -format_numericsep(char *my_str) +format_numeric_locale(char *my_str) { int i, j, int_len = integer_digits(my_str), leading_digits; int groupdigits = atoi(grouping); @@ -95,7 +96,7 @@ format_numericsep(char *my_str) if (my_str[0] == '-') my_str++; - new_str = pg_local_malloc(len_with_numericsep(my_str) + 1); + new_str = pg_local_malloc(strlen_with_numeric_locale(my_str) + 1); leading_digits = (int_len % groupdigits != 0) ? int_len % groupdigits : groupdigits; @@ -143,7 +144,7 @@ print_unaligned_text(const char *title, const char *const *headers, const char *const *cells, const char *const *footers, const char *opt_align, const char *opt_fieldsep, const char *opt_recordsep, bool opt_tuples_only, - bool opt_numericsep, FILE *fout) + bool opt_numeric_locale, FILE *fout) { unsigned int col_count = 0; unsigned int i; @@ -182,12 +183,12 @@ print_unaligned_text(const char *title, const char *const *headers, fputs(opt_recordsep, fout); need_recordsep = false; } - if (opt_align[i % col_count] == 'r' && opt_numericsep) + if (opt_align[i % col_count] == 'r' && opt_numeric_locale) { - char *my_cell = pg_local_malloc(len_with_numericsep(*ptr) + 1); + char *my_cell = pg_local_malloc(strlen_with_numeric_locale(*ptr) + 1); strcpy(my_cell, *ptr); - format_numericsep(my_cell); + format_numeric_locale(my_cell); fputs(my_cell, fout); free(my_cell); } @@ -227,7 +228,7 @@ print_unaligned_vertical(const char *title, const char *const *headers, const char *const *cells, const char *const *footers, const char *opt_align, const char *opt_fieldsep, const char *opt_recordsep, - bool opt_tuples_only, bool opt_numericsep, FILE *fout) + bool opt_tuples_only, bool opt_numeric_locale, FILE *fout) { unsigned int col_count = 0; unsigned int i; @@ -258,12 +259,12 @@ print_unaligned_vertical(const char *title, const char *const *headers, fputs(headers[i % col_count], fout); fputs(opt_fieldsep, fout); - if (opt_align[i % col_count] == 'r' && opt_numericsep) + if (opt_align[i % col_count] == 'r' && opt_numeric_locale) { - char *my_cell = pg_local_malloc(len_with_numericsep(*ptr) + 1); + char *my_cell = pg_local_malloc(strlen_with_numeric_locale(*ptr) + 1); strcpy(my_cell, *ptr); - format_numericsep(my_cell); + format_numeric_locale(my_cell); fputs(my_cell, fout); free(my_cell); } @@ -331,7 +332,7 @@ _print_horizontal_line(const unsigned int col_count, const unsigned int *widths, static void print_aligned_text(const char *title, const char *const *headers, const char *const *cells, const char *const *footers, - const char *opt_align, bool opt_tuples_only, bool opt_numericsep, + const char *opt_align, bool opt_tuples_only, bool opt_numeric_locale, unsigned short int opt_border, int encoding, FILE *fout) { @@ -398,14 +399,14 @@ print_aligned_text(const char *title, const char *const *headers, for (i = 0, ptr = cells; *ptr; ptr++, i++) { - int numericseps; + int numeric_locale_len; - if (opt_align[i % col_count] == 'r' && opt_numericsep) - numericseps = len_numericseps(*ptr); + if (opt_align[i % col_count] == 'r' && opt_numeric_locale) + numeric_locale_len = additional_numeric_locale_len(*ptr); else - numericseps = 0; + numeric_locale_len = 0; - tmp = pg_wcswidth((unsigned char *) *ptr, strlen(*ptr), encoding) + numericseps; + tmp = pg_wcswidth((unsigned char *) *ptr, strlen(*ptr), encoding) + numeric_locale_len; if (tmp > widths[i % col_count]) widths[i % col_count] = tmp; cell_w[i] = tmp; @@ -485,12 +486,12 @@ print_aligned_text(const char *title, const char *const *headers, /* content */ if (opt_align[i % col_count] == 'r') { - if (opt_numericsep) + if (opt_numeric_locale) { char *my_cell = pg_local_malloc(cell_w[i] + 1); strcpy(my_cell, *ptr); - format_numericsep(my_cell); + format_numeric_locale(my_cell); fprintf(fout, "%*s%s", widths[i % col_count] - cell_w[i], "", my_cell); free(my_cell); } @@ -552,7 +553,7 @@ static void print_aligned_vertical(const char *title, const char *const *headers, const char *const *cells, const char *const *footers, const char *opt_align, bool opt_tuples_only, - bool opt_numericsep, unsigned short int opt_border, + bool opt_numeric_locale, unsigned short int opt_border, int encoding, FILE *fout) { unsigned int col_count = 0; @@ -615,14 +616,14 @@ print_aligned_vertical(const char *title, const char *const *headers, /* find longest data cell */ for (i = 0, ptr = cells; *ptr; ptr++, i++) { - int numericseps; + int numeric_locale_len; - if (opt_align[i % col_count] == 'r' && opt_numericsep) - numericseps = len_numericseps(*ptr); + if (opt_align[i % col_count] == 'r' && opt_numeric_locale) + numeric_locale_len = additional_numeric_locale_len(*ptr); else - numericseps = 0; + numeric_locale_len = 0; - tmp = pg_wcswidth((unsigned char *) *ptr, strlen(*ptr), encoding) + numericseps; + tmp = pg_wcswidth((unsigned char *) *ptr, strlen(*ptr), encoding) + numeric_locale_len; if (tmp > dwidth) dwidth = tmp; cell_w[i] = tmp; @@ -700,8 +701,8 @@ print_aligned_vertical(const char *title, const char *const *headers, char *my_cell = pg_local_malloc(cell_w[i] + 1); strcpy(my_cell, *ptr); - if (opt_align[i % col_count] == 'r' && opt_numericsep) - format_numericsep(my_cell); + if (opt_align[i % col_count] == 'r' && opt_numeric_locale) + format_numeric_locale(my_cell); if (opt_border < 2) puts(my_cell); else @@ -788,7 +789,7 @@ static void print_html_text(const char *title, const char *const *headers, const char *const *cells, const char *const *footers, const char *opt_align, bool opt_tuples_only, - bool opt_numericsep, unsigned short int opt_border, + bool opt_numeric_locale, unsigned short int opt_border, const char *opt_table_attr, FILE *fout) { unsigned int col_count = 0; @@ -834,12 +835,12 @@ print_html_text(const char *title, const char *const *headers, /* is string only whitespace? */ if ((*ptr)[strspn(*ptr, " \t")] == '\0') fputs(" ", fout); - else if (opt_align[i % col_count] == 'r' && opt_numericsep) + else if (opt_align[i % col_count] == 'r' && opt_numeric_locale) { - char *my_cell = pg_local_malloc(len_with_numericsep(*ptr) + 1); + char *my_cell = pg_local_malloc(strlen_with_numeric_locale(*ptr) + 1); strcpy(my_cell, *ptr); - format_numericsep(my_cell); + format_numeric_locale(my_cell); html_escaped_print(my_cell, fout); free(my_cell); } @@ -875,7 +876,7 @@ static void print_html_vertical(const char *title, const char *const *headers, const char *const *cells, const char *const *footers, const char *opt_align, bool opt_tuples_only, - bool opt_numericsep, unsigned short int opt_border, + bool opt_numeric_locale, unsigned short int opt_border, const char *opt_table_attr, FILE *fout) { unsigned int col_count = 0; @@ -919,12 +920,12 @@ print_html_vertical(const char *title, const char *const *headers, /* is string only whitespace? */ if ((*ptr)[strspn(*ptr, " \t")] == '\0') fputs(" ", fout); - else if (opt_align[i % col_count] == 'r' && opt_numericsep) + else if (opt_align[i % col_count] == 'r' && opt_numeric_locale) { - char *my_cell = pg_local_malloc(len_with_numericsep(*ptr) + 1); + char *my_cell = pg_local_malloc(strlen_with_numeric_locale(*ptr) + 1); strcpy(my_cell, *ptr); - format_numericsep(my_cell); + format_numeric_locale(my_cell); html_escaped_print(my_cell, fout); free(my_cell); } @@ -1000,7 +1001,7 @@ static void print_latex_text(const char *title, const char *const *headers, const char *const *cells, const char *const *footers, const char *opt_align, bool opt_tuples_only, - bool opt_numericsep, unsigned short int opt_border, + bool opt_numeric_locale, unsigned short int opt_border, FILE *fout) { unsigned int col_count = 0; @@ -1061,12 +1062,12 @@ print_latex_text(const char *title, const char *const *headers, /* print cells */ for (i = 0, ptr = cells; *ptr; i++, ptr++) { - if (opt_numericsep) + if (opt_numeric_locale) { - char *my_cell = pg_local_malloc(len_with_numericsep(*ptr) + 1); + char *my_cell = pg_local_malloc(strlen_with_numeric_locale(*ptr) + 1); strcpy(my_cell, *ptr); - format_numericsep(my_cell); + format_numeric_locale(my_cell); latex_escaped_print(my_cell, fout); free(my_cell); } @@ -1103,7 +1104,7 @@ static void print_latex_vertical(const char *title, const char *const *headers, const char *const *cells, const char *const *footers, const char *opt_align, bool opt_tuples_only, - bool opt_numericsep, unsigned short int opt_border, + bool opt_numeric_locale, unsigned short int opt_border, FILE *fout) { unsigned int col_count = 0; @@ -1174,12 +1175,12 @@ print_latex_vertical(const char *title, const char *const *headers, if (footers && !opt_tuples_only) for (ptr = footers; *ptr; ptr++) { - if (opt_numericsep) + if (opt_numeric_locale) { - char *my_cell = pg_local_malloc(len_with_numericsep(*ptr) + 1); + char *my_cell = pg_local_malloc(strlen_with_numeric_locale(*ptr) + 1); strcpy(my_cell, *ptr); - format_numericsep(my_cell); + format_numeric_locale(my_cell); latex_escaped_print(my_cell, fout); free(my_cell); } @@ -1220,7 +1221,7 @@ static void print_troff_ms_text(const char *title, const char *const *headers, const char *const *cells, const char *const *footers, const char *opt_align, bool opt_tuples_only, - bool opt_numericsep, unsigned short int opt_border, + bool opt_numeric_locale, unsigned short int opt_border, FILE *fout) { unsigned int col_count = 0; @@ -1274,12 +1275,12 @@ print_troff_ms_text(const char *title, const char *const *headers, /* print cells */ for (i = 0, ptr = cells; *ptr; i++, ptr++) { - if (opt_numericsep) + if (opt_numeric_locale) { - char *my_cell = pg_local_malloc(len_with_numericsep(*ptr) + 1); + char *my_cell = pg_local_malloc(strlen_with_numeric_locale(*ptr) + 1); strcpy(my_cell, *ptr); - format_numericsep(my_cell); + format_numeric_locale(my_cell); troff_ms_escaped_print(my_cell, fout); free(my_cell); } @@ -1313,7 +1314,7 @@ static void print_troff_ms_vertical(const char *title, const char *const *headers, const char *const *cells, const char *const *footers, const char *opt_align, bool opt_tuples_only, - bool opt_numericsep, unsigned short int opt_border, + bool opt_numeric_locale, unsigned short int opt_border, FILE *fout) { unsigned int col_count = 0; @@ -1386,12 +1387,12 @@ print_troff_ms_vertical(const char *title, const char *const *headers, troff_ms_escaped_print(headers[i % col_count], fout); fputc('\t', fout); - if (opt_numericsep) + if (opt_numeric_locale) { - char *my_cell = pg_local_malloc(len_with_numericsep(*ptr) + 1); + char *my_cell = pg_local_malloc(strlen_with_numeric_locale(*ptr) + 1); strcpy(my_cell, *ptr); - format_numericsep(my_cell); + format_numeric_locale(my_cell); troff_ms_escaped_print(my_cell, fout); free(my_cell); } @@ -1533,7 +1534,7 @@ printTable(const char *title, /* print the stuff */ if (flog) - print_aligned_text(title, headers, cells, footers, align, opt->tuples_only, opt->numericSep, border, opt->encoding, flog); + print_aligned_text(title, headers, cells, footers, align, opt->tuples_only, opt->numericLocale, border, opt->encoding, flog); switch (opt->format) { @@ -1541,50 +1542,50 @@ printTable(const char *title, if (use_expanded) print_unaligned_vertical(title, headers, cells, footers, align, opt->fieldSep, opt->recordSep, - opt->tuples_only, opt->numericSep, output); + opt->tuples_only, opt->numericLocale, output); else print_unaligned_text(title, headers, cells, footers, align, opt->fieldSep, opt->recordSep, - opt->tuples_only, opt->numericSep, output); + opt->tuples_only, opt->numericLocale, output); break; case PRINT_ALIGNED: if (use_expanded) print_aligned_vertical(title, headers, cells, footers, align, - opt->tuples_only, opt->numericSep, border, + opt->tuples_only, opt->numericLocale, border, opt->encoding, output); else print_aligned_text(title, headers, cells, footers, align, - opt->tuples_only, opt->numericSep, + opt->tuples_only, opt->numericLocale, border, opt->encoding, output); break; case PRINT_HTML: if (use_expanded) print_html_vertical(title, headers, cells, footers, align, - opt->tuples_only, opt->numericSep, + opt->tuples_only, opt->numericLocale, border, opt->tableAttr, output); else print_html_text(title, headers, cells, footers, - align, opt->tuples_only, opt->numericSep, border, + align, opt->tuples_only, opt->numericLocale, border, opt->tableAttr, output); break; case PRINT_LATEX: if (use_expanded) print_latex_vertical(title, headers, cells, footers, align, - opt->tuples_only, opt->numericSep, + opt->tuples_only, opt->numericLocale, border, output); else print_latex_text(title, headers, cells, footers, align, - opt->tuples_only, opt->numericSep, + opt->tuples_only, opt->numericLocale, border, output); break; case PRINT_TROFF_MS: if (use_expanded) print_troff_ms_vertical(title, headers, cells, footers, align, - opt->tuples_only, opt->numericSep, + opt->tuples_only, opt->numericLocale, border, output); else print_troff_ms_text(title, headers, cells, footers, align, - opt->tuples_only, opt->numericSep, + opt->tuples_only, opt->numericLocale, border, output); break; default: diff --git a/src/bin/psql/print.h b/src/bin/psql/print.h index bb23b7c08c4..a5fd549aef9 100644 --- a/src/bin/psql/print.h +++ b/src/bin/psql/print.h @@ -3,7 +3,7 @@ * * Copyright (c) 2000-2005, PostgreSQL Global Development Group * - * $PostgreSQL: pgsql/src/bin/psql/print.h,v 1.27 2005/07/14 08:42:37 momjian Exp $ + * $PostgreSQL: pgsql/src/bin/psql/print.h,v 1.28 2005/07/18 20:57:53 momjian Exp $ */ #ifndef PRINT_H #define PRINT_H @@ -40,7 +40,7 @@ typedef struct _printTableOpt char *fieldSep; /* field separator for unaligned text mode */ char *recordSep; /* record separator for unaligned text * mode */ - bool numericSep; /* locale-aware numeric units separator and + bool numericLocale; /* locale-aware numeric units separator and * decimal marker */ char *tableAttr; /* attributes for HTML <table ...> */ int encoding; /* character encoding */ -- GitLab