Commit fae7ce83 authored by Tom Lane's avatar Tom Lane

Make locale_messages_assign() really work on Windows; the prior hack

only covered the case of assigning "", and failed to recognize that
actually setlocale(LC_MESSAGES,...) does not work at all on this platform.
Magnus Hagander, some code prettification by Tom Lane.
parent cc6a90e4
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
* *
* Portions Copyright (c) 2002-2004, PostgreSQL Global Development Group * Portions Copyright (c) 2002-2004, PostgreSQL Global Development Group
* *
* $PostgreSQL: pgsql/src/backend/utils/adt/pg_locale.c,v 1.28 2004/08/29 05:06:49 momjian Exp $ * $PostgreSQL: pgsql/src/backend/utils/adt/pg_locale.c,v 1.29 2004/10/17 20:02:26 tgl Exp $
* *
*----------------------------------------------------------------------- *-----------------------------------------------------------------------
*/ */
...@@ -123,6 +123,7 @@ locale_time_assign(const char *value, bool doit, GucSource source) ...@@ -123,6 +123,7 @@ locale_time_assign(const char *value, bool doit, GucSource source)
const char * const char *
locale_messages_assign(const char *value, bool doit, GucSource source) locale_messages_assign(const char *value, bool doit, GucSource source)
{ {
#ifndef WIN32
/* /*
* LC_MESSAGES category does not exist everywhere, but accept it * LC_MESSAGES category does not exist everywhere, but accept it
* anyway * anyway
...@@ -131,25 +132,40 @@ locale_messages_assign(const char *value, bool doit, GucSource source) ...@@ -131,25 +132,40 @@ locale_messages_assign(const char *value, bool doit, GucSource source)
if (doit) if (doit)
{ {
if (!setlocale(LC_MESSAGES, value)) if (!setlocale(LC_MESSAGES, value))
{ return NULL;
#ifdef WIN32 }
else
value = locale_xxx_assign(LC_MESSAGES, value, false, source);
#endif /* LC_MESSAGES */
return value;
#else /* WIN32 */
/* /*
* Win32 returns NULL when you set LC_MESSAGES to "". So * Win32 does not have working setlocale() for LC_MESSAGES. We can only
* don't complain unless we're trying to set it to something * use environment variables to change it (per gettext FAQ). This
* else. * means we can't actually check the supplied value, so always assume
* it's good. Also, ignore attempts to set to "", which really means
* "keep using the old value". (Actually it means "use the environment
* value", but we are too lazy to try to implement that exactly.)
*/ */
if (value[0]) if (doit && value[0])
{
/*
* We need to modify both the process environment and the cached
* version in msvcrt
*/
static char env[128];
if (!SetEnvironmentVariable("LC_MESSAGES", value))
return NULL; return NULL;
#else
snprintf(env, sizeof(env)-1, "LC_MESSAGES=%s", value);
if (_putenv(env))
return NULL; return NULL;
#endif
} }
}
else
value = locale_xxx_assign(LC_MESSAGES, value, false, source);
#endif /* LC_MESSAGES */
return value; return value;
#endif /* WIN32 */
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment