aboutsummaryrefslogtreecommitdiff
path: root/lib/libc/locale/setlocale.c
diff options
context:
space:
mode:
authorAlexey Zelkin <phantom@FreeBSD.org>2003-06-25 22:42:33 +0000
committerAlexey Zelkin <phantom@FreeBSD.org>2003-06-25 22:42:33 +0000
commitfca2738d67e713599384b8a3faa49ae674d5801c (patch)
tree74ee561a7f7202eb14362249dc2a3ac92f0de6d4 /lib/libc/locale/setlocale.c
parent93c847344b3ed2121bfa8b2e630df2699025ce44 (diff)
downloadsrc-fca2738d67e713599384b8a3faa49ae674d5801c.tar.gz
src-fca2738d67e713599384b8a3faa49ae674d5801c.zip
Reduce code duplication by separating _PathLocle detection code into
internal helper function.
Notes
Notes: svn path=/head/; revision=116847
Diffstat (limited to 'lib/libc/locale/setlocale.c')
-rw-r--r--lib/libc/locale/setlocale.c53
1 files changed, 32 insertions, 21 deletions
diff --git a/lib/libc/locale/setlocale.c b/lib/libc/locale/setlocale.c
index 48c40bc91718..cea932689776 100644
--- a/lib/libc/locale/setlocale.c
+++ b/lib/libc/locale/setlocale.c
@@ -262,6 +262,7 @@ loadlocale(category)
char *new = new_categories[category];
char *old = current_categories[category];
int (*func)(const char *);
+ int saved_errno;
if ((new[0] == '.' &&
(new[1] == '\0' || (new[1] == '.' && new[2] == '\0'))) ||
@@ -270,27 +271,11 @@ loadlocale(category)
return (NULL);
}
- if (_PathLocale == NULL) {
- char *p = getenv("PATH_LOCALE");
-
- if (p != NULL
-#ifndef __NETBSD_SYSCALLS
- && !issetugid()
-#endif
- ) {
- if (strlen(p) + 1/*"/"*/ + ENCODING_LEN +
- 1/*"/"*/ + CATEGORY_LEN >= PATH_MAX) {
- errno = ENAMETOOLONG;
- return (NULL);
- }
- _PathLocale = strdup(p);
- if (_PathLocale == NULL) {
- errno = ENOMEM;
- return (NULL);
- }
- } else
- _PathLocale = _PATH_LOCALE;
- }
+ saved_errno = errno;
+ errno = __detect_path_locale();
+ if (errno != 0)
+ return (NULL);
+ errno = saved_errno;
switch (category) {
case LC_CTYPE:
@@ -327,3 +312,29 @@ loadlocale(category)
return (NULL);
}
+/*
+ * Detect locale storage location and store its value to _PathLocale variable
+ */
+int
+__detect_path_locale(void)
+{
+ if (_PathLocale == NULL) {
+ char *p = getenv("PATH_LOCALE");
+
+ if (p != NULL
+#ifndef __NETBSD_SYSCALLS
+ && !issetugid()
+#endif
+ ) {
+ if (strlen(p) + 1/*"/"*/ + ENCODING_LEN +
+ 1/*"/"*/ + CATEGORY_LEN >= PATH_MAX)
+ return (ENAMETOOLONG);
+ _PathLocale = strdup(p);
+ if (_PathLocale == NULL)
+ return (errno == 0 ? ENOMEM : errno);
+ } else
+ _PathLocale = _PATH_LOCALE;
+ }
+ return (0);
+}
+