mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-27 14:57:09 -05:00
Set console code page to CP_UTF8 on Windows if supported. (#3050)
Previously, we enforced code page 850 for all console input and output, which breaks with non-western scripts. Since more recent Windows shells are able to display Unicode properly, this patch now enforces UTF-8 and falls back to code page 850 only if UTF-8 is unsupported. Non-Windows systems default to UTF-8, but can override the codec by setting the LANG environment variable to something other than C. Resolves #3049.
This commit is contained in:
parent
13eb1c0bbd
commit
d3a53a702e
@ -19,6 +19,9 @@
|
|||||||
|
|
||||||
#include <QProcessEnvironment>
|
#include <QProcessEnvironment>
|
||||||
#include <QTextCodec>
|
#include <QTextCodec>
|
||||||
|
#ifdef Q_OS_WIN
|
||||||
|
#include <windows.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
TextStream::TextStream()
|
TextStream::TextStream()
|
||||||
{
|
{
|
||||||
@ -59,12 +62,26 @@ void TextStream::detectCodec()
|
|||||||
{
|
{
|
||||||
QString codecName = "UTF-8";
|
QString codecName = "UTF-8";
|
||||||
auto env = QProcessEnvironment::systemEnvironment();
|
auto env = QProcessEnvironment::systemEnvironment();
|
||||||
|
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
if (!env.contains("SHELL")) {
|
WINBOOL success = false;
|
||||||
// native shell (no Msys or cygwin)
|
#ifdef CP_UTF8
|
||||||
|
success = SetConsoleOutputCP(CP_UTF8);
|
||||||
|
#endif
|
||||||
|
if (!success && !env.contains("SHELL")) {
|
||||||
|
// Fall back to cp850 if this is Windows without CP_UTF8 and we
|
||||||
|
// are running in a native shell (i.e., no Msys or Cygwin).
|
||||||
codecName = "Windows-850";
|
codecName = "Windows-850";
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
if (env.contains("LANG") && !env.value("LANG").isEmpty() && env.value("LANG") != "C") {
|
||||||
|
// Only override codec if LANG is set, otherwise Qt will assume
|
||||||
|
// US-ASCII, which is almost always wrong and results in
|
||||||
|
// Unicode passwords being displayed as question marks.
|
||||||
|
codecName = QTextCodec::codecForLocale()->name();
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
codecName = env.value("ENCODING_OVERRIDE", codecName);
|
codecName = env.value("ENCODING_OVERRIDE", codecName);
|
||||||
auto* codec = QTextCodec::codecForName(codecName.toLatin1());
|
auto* codec = QTextCodec::codecForName(codecName.toLatin1());
|
||||||
if (codec) {
|
if (codec) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user