diff options
| author | Dmitrij Tejblum <dt@FreeBSD.org> | 1999-09-12 19:42:38 +0000 |
|---|---|---|
| committer | Dmitrij Tejblum <dt@FreeBSD.org> | 1999-09-12 19:42:38 +0000 |
| commit | 03a7efc23434121a36ef935e1e41ab883dd6c642 (patch) | |
| tree | 2755b31e660242a51f885504e9c96c184436a69a /lib | |
| parent | 661d7edf84ea036f54a2dd76026cae6bcba7f326 (diff) | |
Notes
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/libc/locale/collate.c | 19 |
1 files changed, 11 insertions, 8 deletions
diff --git a/lib/libc/locale/collate.c b/lib/libc/locale/collate.c index f71870c9a34f..a73e4f1bcf53 100644 --- a/lib/libc/locale/collate.c +++ b/lib/libc/locale/collate.c @@ -102,23 +102,26 @@ u_char * __collate_substitute(s) const u_char *s; { - int dest_len = 0, len = 0; + int dest_len, len, nlen; int delta = strlen(s); u_char *dest_str = NULL; if(s == NULL || *s == '\0') return __collate_strdup(""); + delta += delta / 8; + dest_str = malloc(dest_len = delta); + if(dest_str == NULL) + __collate_err(EX_OSERR, __FUNCTION__); + len = 0; while(*s) { - len += strlen(__collate_substitute_table[*s]); - while(dest_len <= len) { - if(!dest_str) - dest_str = calloc(dest_len = delta, 1); - else - dest_str = reallocf(dest_str, dest_len += delta); + nlen = len + strlen(__collate_substitute_table[*s]); + if (dest_len <= nlen) { + dest_str = reallocf(dest_str, dest_len = nlen + delta); if(dest_str == NULL) __collate_err(EX_OSERR, __FUNCTION__); } - strcat(dest_str, __collate_substitute_table[*s++]); + strcpy(dest_str + len, __collate_substitute_table[*s++]); + len = nlen; } return dest_str; } |
