#ifdef ENABLE_NLS
-#define NUM_LANGS 6 /**< how many different locales do we know? */
+#define NUM_LANGS 9 /**< how many different locales do we know? */
#define SEARCH_LANG 20 /**< how many langs should we parse? */
/** actual supported locales */
"de_DE",
"it_IT",
"es_ES",
- "en_GB"
+ "en_GB",
+ "da_DK",
+ "fr_FR",
+ "nl_NL"
};
locale_t wc_locales[NUM_LANGS]; /**< here we keep the parsed stuff */
int i = 0;
int j = 0;
- size_t len = strlen(LocaleString);
+ /* size_t len = strlen(LocaleString); */
long prio;
int av;
int nBest;
int nParts;
- char *search = (char *) malloc(len);
+ char search[1024];
- memcpy(search, LocaleString, len);
- search[len] = '\0';
+ safestrncpy(search, LocaleString, sizeof search);
nParts=num_tokens(search,',');
for (i=0; ((i<nParts)&&(i<SEARCH_LANG)); i++)
{
prio=0;
av=-1000;
nBest=-1;
- for (i=0; ((i<nParts)&&(i<SEARCH_LANG)); i++)
- {
- ls=&wanted_locales[i];
- if ((ls->availability<=0)&&
- (av<ls->availability)&&
- (prio<ls->priority)&&
- (ls->selectedlang!=-1)){
- nBest=ls->selectedlang;
- av=ls->availability;
- prio=ls->priority;
- }
+ for (i=0; ((i<nParts)&&(i<SEARCH_LANG)); i++) {
+ ls=&wanted_locales[i];
+ if ((ls->availability<=0)&&
+ (av<ls->availability)&&
+ (prio<ls->priority)&&
+ (ls->selectedlang!=-1)) {
+ nBest=ls->selectedlang;
+ av=ls->availability;
+ prio=ls->priority;
}
- if (nBest==-1) /** fall back to C */
+ }
+ if (nBest == -1) {
+ /** fall back to C */
nBest=0;
+ }
WC->selected_language=nBest;
lprintf(9, "language found: %s\n", AvailLang[WC->selected_language]);
- if (search != NULL) {
- free(search);
- }
}
-/* TODO: we skip the language weightening so far. */
+/* TODO: we skip the language weighting so far. */
/* Accept-Language: 'de-de,en-us;q=0.7,en;q=0.3' */
/* Accept-Language: de,en-ph;q=0.8,en-us;q=0.5,de-at;q=0.3 */
//void httplang_to_locale(char *LocaleString)
void offer_languages(void) {
int i;
- wprintf("<select name=\"language\" size=\"1\">\n");
+ wprintf("<select name=\"language\" id=\"lname\" size=\"1\">\n");
for (i=0; i < NUM_LANGS; ++i) {
wprintf("<option %s value=%s>%s</option>\n",
* \brief Activate the selected language for this session.
*/
void go_selected_language(void) {
+#ifdef HAVE_USELOCALE
if (WC->selected_language < 0) return;
uselocale(wc_locales[WC->selected_language]); /** switch locales */
textdomain(textdomain(NULL)); /** clear the cache */
+#endif
}
/**
* \brief Deactivate the selected language for this session.
*/
void stop_selected_language(void) {
+#ifdef HAVE_USELOCALE
uselocale(LC_GLOBAL_LOCALE); /** switch locales */
textdomain(textdomain(NULL)); /** clear the cache */
+#endif
}
-
+void preset_locale(void)
+{
+#ifndef HAVE_USELOCALE
+#ifdef HAVE_GETTEXT
+ char *language;
+
+ language = getenv("LANG");
+ setlocale(LC_MESSAGES, language);
+#endif
+#endif
+}
/**
* \brief Create a locale_t for each available language
*/
void stop_selected_language(void) {
}
+void preset_locale(void)
+{
+}
#endif /* ENABLE_NLS */