summaryrefslogtreecommitdiffstats
path: root/lib/libc/locale/collate.c
diff options
context:
space:
mode:
authorache <ache@FreeBSD.org>2002-08-13 14:55:17 +0000
committerache <ache@FreeBSD.org>2002-08-13 14:55:17 +0000
commiteb76ea8d875f46f9546dae27b5b8bd781848fe51 (patch)
tree0b1ea17dcf2cec12da873afe8fc5a0eb7f3f94d4 /lib/libc/locale/collate.c
parent506db62790db998ceb3c9393be835936e30103e3 (diff)
downloadFreeBSD-src-eb76ea8d875f46f9546dae27b5b8bd781848fe51.zip
FreeBSD-src-eb76ea8d875f46f9546dae27b5b8bd781848fe51.tar.gz
Reduce BSS size for programs which not load collate by eliminating
static buffer.
Diffstat (limited to 'lib/libc/locale/collate.c')
-rw-r--r--lib/libc/locale/collate.c20
1 files changed, 10 insertions, 10 deletions
diff --git a/lib/libc/locale/collate.c b/lib/libc/locale/collate.c
index 44c3eb7..45493d4 100644
--- a/lib/libc/locale/collate.c
+++ b/lib/libc/locale/collate.c
@@ -60,7 +60,7 @@ __collate_load_tables(const char *encoding)
int i, saverr;
char collate_version[STR_LEN];
char buf[PATH_MAX];
- char *TMP_substitute_table, *TMP_char_pri_table, *TMP_chain_pri_table;
+ void *TMP_substitute_table, *TMP_char_pri_table, *TMP_chain_pri_table;
static char collate_encoding[ENCODING_LEN + 1];
/* 'encoding' must be already checked. */
@@ -143,15 +143,15 @@ __collate_load_tables(const char *encoding)
(void)fclose(fp);
(void)strcpy(collate_encoding, encoding);
- (void)memcpy(__collate_substitute_table, TMP_substitute_table,
- sizeof(__collate_substitute_table));
- (void)memcpy(__collate_char_pri_table, TMP_char_pri_table,
- sizeof(__collate_char_pri_table));
- (void)memcpy(__collate_chain_pri_table, TMP_chain_pri_table,
- sizeof(__collate_chain_pri_table));
- free(TMP_substitute_table);
- free(TMP_char_pri_table);
- free(TMP_chain_pri_table);
+ if (__collate_substitute_table_ptr != NULL)
+ free(__collate_substitute_table_ptr);
+ __collate_substitute_table_ptr = TMP_substitute_table;
+ if (__collate_char_pri_table_ptr != NULL)
+ free(__collate_char_pri_table_ptr);
+ __collate_char_pri_table_ptr = TMP_char_pri_table;
+ if (__collate_chain_pri_table_ptr != NULL)
+ free(__collate_chain_pri_table_ptr);
+ __collate_chain_pri_table_ptr = TMP_chain_pri_table;
__collate_substitute_nontrivial = 0;
for (i = 0; i < UCHAR_MAX + 1; i++) {
OpenPOWER on IntegriCloud