diff options
author | Xavier de Gaye <xdegaye@users.sourceforge.net> | 2016-12-17 09:19:11 +0100 |
---|---|---|
committer | Xavier de Gaye <xdegaye@users.sourceforge.net> | 2016-12-17 09:19:11 +0100 |
commit | 6c9dcda6b4e58367128726afc41fe05ee2f6388d (patch) | |
tree | 7e0636952cccad165fdf4b741a65d0a4cf046de5 /Lib/_bootlocale.py | |
parent | b06cde61a2105cf9e0ec52fd7e2c131ae0cd15fa (diff) | |
download | cpython-git-6c9dcda6b4e58367128726afc41fe05ee2f6388d.tar.gz |
Issue #28596: The preferred encoding is UTF-8 on Android.
Diffstat (limited to 'Lib/_bootlocale.py')
-rw-r--r-- | Lib/_bootlocale.py | 16 |
1 files changed, 11 insertions, 5 deletions
diff --git a/Lib/_bootlocale.py b/Lib/_bootlocale.py index 4bccac1139..0c61b0d3a0 100644 --- a/Lib/_bootlocale.py +++ b/Lib/_bootlocale.py @@ -14,11 +14,17 @@ else: try: _locale.CODESET except AttributeError: - def getpreferredencoding(do_setlocale=True): - # This path for legacy systems needs the more complex - # getdefaultlocale() function, import the full locale module. - import locale - return locale.getpreferredencoding(do_setlocale) + if hasattr(sys, 'getandroidapilevel'): + # On Android langinfo.h and CODESET are missing, and UTF-8 is + # always used in mbstowcs() and wcstombs(). + def getpreferredencoding(do_setlocale=True): + return 'UTF-8' + else: + def getpreferredencoding(do_setlocale=True): + # This path for legacy systems needs the more complex + # getdefaultlocale() function, import the full locale module. + import locale + return locale.getpreferredencoding(do_setlocale) else: def getpreferredencoding(do_setlocale=True): assert not do_setlocale |