summaryrefslogtreecommitdiff
path: root/Python
diff options
context:
space:
mode:
Diffstat (limited to 'Python')
-rw-r--r--Python/pylifecycle.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/Python/pylifecycle.c b/Python/pylifecycle.c
index 953bc90a45..3953fec0f5 100644
--- a/Python/pylifecycle.c
+++ b/Python/pylifecycle.c
@@ -399,17 +399,10 @@ typedef struct _CandidateLocale {
static _LocaleCoercionTarget _TARGET_LOCALES[] = {
{"C.UTF-8"},
{"C.utf8"},
- /* {"UTF-8"}, */
+ {"UTF-8"},
{NULL}
};
-/* XXX (ncoghlan): Using UTF-8 as a target locale is currently disabled due to
- * problems encountered on *BSD systems with those test cases
- * For additional details see:
- * nl_langinfo CODESET error: https://bugs.python.org/issue30647
- * locale handling differences: https://bugs.python.org/issue30672
- */
-
static char *
get_default_standard_stream_error_handler(void)
{
@@ -490,6 +483,16 @@ _Py_CoerceLegacyLocale(void)
const char *new_locale = setlocale(LC_CTYPE,
target->locale_name);
if (new_locale != NULL) {
+#if !defined(__APPLE__) && defined(HAVE_LANGINFO_H) && defined(CODESET)
+ /* Also ensure that nl_langinfo works in this locale */
+ char *codeset = nl_langinfo(CODESET);
+ if (!codeset || *codeset == '\0') {
+ /* CODESET is not set or empty, so skip coercion */
+ new_locale = NULL;
+ setlocale(LC_CTYPE, "");
+ continue;
+ }
+#endif
/* Successfully configured locale, so make it the default */
_coerce_default_locale_settings(target);
return;