|  | """A minimal subset of the locale module used at interpreter startup | 
|  | (imported by the _io module), in order to reduce startup time. | 
|  |  | 
|  | Don't import directly from third-party code; use the `locale` module instead! | 
|  | """ | 
|  |  | 
|  | import sys | 
|  | import _locale | 
|  |  | 
|  | if sys.platform.startswith("win"): | 
|  | def getpreferredencoding(do_setlocale=True): | 
|  | return _locale._getdefaultlocale()[1] | 
|  | 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) | 
|  | else: | 
|  | def getpreferredencoding(do_setlocale=True): | 
|  | assert not do_setlocale | 
|  | result = _locale.nl_langinfo(_locale.CODESET) | 
|  | if not result and sys.platform == 'darwin': | 
|  | # nl_langinfo can return an empty string | 
|  | # when the setting has an invalid value. | 
|  | # Default to UTF-8 in that case because | 
|  | # UTF-8 is the default charset on OSX and | 
|  | # returning nothing will crash the | 
|  | # interpreter. | 
|  | result = 'UTF-8' | 
|  | return result |