# HG changeset patch # User Jason Rumney # Date 975101406 0 # Node ID e41a7b1e443f5d28eb6c0585b3cb593baef7e6d8 # Parent d77db72e017d80ff9c739b1bd79fb1fc8dec4858 (init_environment): Set LANG environment variable based on locale settings, if not set. diff -r d77db72e017d -r e41a7b1e443f src/w32.c --- a/src/w32.c Fri Nov 24 21:29:07 2000 +0000 +++ b/src/w32.c Fri Nov 24 21:30:06 2000 +0000 @@ -702,6 +702,7 @@ int i; LPBYTE lpval; DWORD dwType; + char locale_name[32]; static struct env_entry { @@ -721,9 +722,25 @@ is then ignored. */ /* {"INFOPATH", "%emacs_dir%/info"}, */ {"EMACSDOC", "%emacs_dir%/etc"}, - {"TERM", "cmd"} + {"TERM", "cmd"}, + {"LANG", NULL}, }; + /* Get default locale info and use it for LANG. */ + if (GetLocaleInfo (LOCALE_USER_DEFAULT, + LOCALE_SABBREVLANGNAME | LOCALE_USE_CP_ACP, + locale_name, sizeof (locale_name))) + { + for (i = 0; i < (sizeof (env_vars) / sizeof (env_vars[0])); i++) + { + if (strcmp (env_vars[i].name, "LANG") == 0) + { + env_vars[i].def_value = locale_name; + break; + } + } + } + #define SET_ENV_BUF_SIZE (4 * MAX_PATH) /* to cover EMACSLOADPATH */ /* Treat emacs_dir specially: set it unconditionally based on our @@ -752,7 +769,7 @@ } } - for (i = 0; i < (sizeof (env_vars) / sizeof (env_vars[0])); i++) + for (i = 0; i < (sizeof (env_vars) / sizeof (env_vars[0])); i++) { if (!getenv (env_vars[i].name)) {