diff options
author | ache <ache@FreeBSD.org> | 1995-10-23 20:08:24 +0000 |
---|---|---|
committer | ache <ache@FreeBSD.org> | 1995-10-23 20:08:24 +0000 |
commit | 83a985d5f21f89bc4c3d8e73e11e93dc3a90f529 (patch) | |
tree | 75c52a698485e36ebea2e296bbf3f037b39b8f84 /lib/libc/locale/collate.c | |
parent | 14ac5aba33457166a17bbba2619b9c2f85531cda (diff) | |
download | FreeBSD-src-83a985d5f21f89bc4c3d8e73e11e93dc3a90f529.zip FreeBSD-src-83a985d5f21f89bc4c3d8e73e11e93dc3a90f529.tar.gz |
Optimize PathLocale handling.
Handle C/POSIX/"" properly.
Don't reset collate to C when it is unnecessary
Diffstat (limited to 'lib/libc/locale/collate.c')
-rw-r--r-- | lib/libc/locale/collate.c | 22 |
1 files changed, 15 insertions, 7 deletions
diff --git a/lib/libc/locale/collate.c b/lib/libc/locale/collate.c index bdcf6a4..ef73cef 100644 --- a/lib/libc/locale/collate.c +++ b/lib/libc/locale/collate.c @@ -24,7 +24,7 @@ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * - * $Id: collate.c,v 1.3 1995/02/18 01:42:02 ache Exp $ + * $Id: collate.c,v 1.4 1995/05/30 05:40:40 rgrimes Exp $ */ #include <rune.h> @@ -36,6 +36,7 @@ #include <sysexits.h> #include "collate.h" +char *_PathLocale; int __collate_load_error = 1; u_char __collate_charmap_table[UCHAR_MAX + 1][STR_LEN]; u_char __collate_substitute_table[UCHAR_MAX + 1][STR_LEN]; @@ -58,20 +59,27 @@ __collate_load_tables(encoding) char *encoding; { char buf[PATH_MAX]; - static char *path_locale; FILE *fp; + int save_load_error; + save_load_error = __collate_load_error; __collate_load_error = 1; - if (!encoding) + if (!encoding) { + __collate_load_error = save_load_error; return -1; - if (!path_locale && !(path_locale = getenv("PATH_LOCALE"))) - path_locale = _PATH_LOCALE; - strcpy(buf, path_locale); + } + if (!*encoding || !strcmp(encoding, "C") || !strcmp(encoding, "POSIX")) + return 0; + if (!_PathLocale && !(_PathLocale = getenv("PATH_LOCALE"))) + _PathLocale = _PATH_LOCALE; + strcpy(buf, _PathLocale); strcat(buf, "/"); strcat(buf, encoding); strcat(buf, "/LC_COLLATE"); - if ((fp = fopen(buf, "r")) == NULL) + if ((fp = fopen(buf, "r")) == NULL) { + __collate_load_error = save_load_error; return -1; + } FREAD(__collate_charmap_table, sizeof(__collate_charmap_table), 1, fp); FREAD(__collate_substitute_table, sizeof(__collate_substitute_table), 1, fp); |