* cleanup
authorWilfried Göesgens <willi@citadel.org>
Thu, 26 Feb 2009 22:55:28 +0000 (22:55 +0000)
committerWilfried Göesgens <willi@citadel.org>
Thu, 26 Feb 2009 22:55:28 +0000 (22:55 +0000)
* fix BSD non-preset locale case to C

webcit/gettext.c
webcit/wc_gettext.h

index c921ffb12991742692d4c8226280f6de64b31d59..0fa2450946b835ee6a66070999c212410f6d4127 100644 (file)
@@ -237,19 +237,6 @@ void stop_selected_language(void) {
 #endif
 }
 
-void preset_locale(void)
-{
-#ifdef HAVE_GETTEXT
-       char *language;
-       
-       language = getenv("WEBCIT_LANG");
-       if ((language) && (!IsEmptyStr(language)) && (strcmp(language, "UNLIMITED") != 0)) {
-               lprintf(9, "Nailing locale to %s\n", language);
-               setlocale(LC_MESSAGES, language);
-       }
-#endif
-}
-
 #ifdef HAVE_USELOCALE
        locale_t Empty_Locale;
 #endif
@@ -265,8 +252,7 @@ void initialize_locales(void) {
        language = getenv("WEBCIT_LANG");
        if ((language) && (!IsEmptyStr(language)) && (strcmp(language, "UNLIMITED") != 0)) {
                lprintf(9, "Nailing locale to %s\n", language);
-               setlocale(LC_MESSAGES, language);
-       }
+       }
        else language = NULL;
 
 #ifdef HAVE_USELOCALE
@@ -304,9 +290,16 @@ void initialize_locales(void) {
                        nLocalesLoaded++;
                }
 #else
-               setenv("LANG", buf, 1);
-               AvailLangLoaded[nLocalesLoaded] = AvailLang[i];
-               nLocalesLoaded++;
+               if (language != NULL) {
+                       setenv("LANG", buf, 1);
+                       AvailLangLoaded[nLocalesLoaded] = AvailLang[i];
+                       nLocalesLoaded++;
+               }
+               else if (nLocalesLoaded == 0) {
+                       setenv("LANG", buf, 1);
+                       AvailLangLoaded[nLocalesLoaded] = AvailLang[i];
+                       nLocalesLoaded++;
+               }
 #endif
        }
        if ((language != NULL) && (nLocalesLoaded == 0)) {
@@ -317,6 +310,7 @@ void initialize_locales(void) {
                        AvailLang[0],
                        Empty_Locale);          
 #else
+               setlocale(LC_MESSAGES, AvailLang[0]);
                setenv("LANG", AvailLang[0], 1);
 #endif
                AvailLangLoaded[0] = AvailLang[0];
@@ -363,9 +357,6 @@ void go_selected_language(void) {
 void stop_selected_language(void) {
 }
 
-void preset_locale(void)
-{
-}
 #endif /* ENABLE_NLS */
 
 
index c976b8c2f9c2746ee67e81a7bd75f89da67e2166..e1f42796515b0bd6914de6e47afb64f9cbbfa0ae 100644 (file)
@@ -15,5 +15,4 @@ void offer_languages(StrBuf *Target, int nArgs, WCTemplateToken *Token, void *Co
 void set_selected_language(const char *);
 void go_selected_language(void);
 void stop_selected_language(void);
-void preset_locale(void);
 void httplang_to_locale(StrBuf *LocaleString);