diff options
author | Takashi Yano via Cygwin-patches <cygwin-patches@cygwin.com> | 2020-09-11 19:54:40 +0900 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2020-09-11 14:09:10 +0200 |
commit | 232fde0e76db14fc59912d0022b72c7739f1d598 (patch) | |
tree | f3610e7ea05de30721c1c486c131173b89d099b7 | |
parent | 09738c30627c20770d2a1cfa33aaf233bb77d035 (diff) | |
download | cygnal-232fde0e76db14fc59912d0022b72c7739f1d598.tar.gz cygnal-232fde0e76db14fc59912d0022b72c7739f1d598.tar.bz2 cygnal-232fde0e76db14fc59912d0022b72c7739f1d598.zip |
Cygwin: pty: Prevent garbled output for existing non-cygwin apps.
- If pseudo console is disabled, non-cygwin apps do not detect
console device. In this case, some apps output UTF-8 regardless
of the locale setting. At least git-for-windows, rust-based apps
and node.js do that. This patch provides backward compatibility
as default behaviour by setting console codepage to the charset of
the locale. Even in the cases above, garbled output is prevented
with this patch in most cases because mintty uses UTF-8 by default.
I beleave this is not really a problem in cygwin side but that in
app side, however, some users complain about garbled output with
existing apps in MSYS2 (which is based on cygwin) in which pseudo
console is disabled by default.
-rw-r--r-- | winsup/cygwin/fhandler_tty.cc | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/winsup/cygwin/fhandler_tty.cc b/winsup/cygwin/fhandler_tty.cc index 37d033bbe..95b28c3da 100644 --- a/winsup/cygwin/fhandler_tty.cc +++ b/winsup/cygwin/fhandler_tty.cc @@ -1830,7 +1830,11 @@ fhandler_pty_slave::setup_locale (void) extern UINT __eval_codepage_from_internal_charset (); if (!get_ttyp ()->term_code_page) - get_ttyp ()->term_code_page = __eval_codepage_from_internal_charset (); + { + get_ttyp ()->term_code_page = __eval_codepage_from_internal_charset (); + SetConsoleCP (get_ttyp ()->term_code_page); + SetConsoleOutputCP (get_ttyp ()->term_code_page); + } } void |