diff options
author | Brad King <brad.king@kitware.com> | 2022-05-27 16:01:41 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2022-05-27 16:01:41 (GMT) |
commit | a539aed6bf0261e1bbeaa06c6d43d78f5140cd5f (patch) | |
tree | e0354bdae0d9b206ad8ad46527b103a91d33a259 | |
parent | d6bfce26ad59086282c27b090cefa00ccdeed7e7 (diff) | |
parent | ae13524e3bc116d38fb54770a40e89ae7274540f (diff) | |
download | CMake-a539aed6bf0261e1bbeaa06c6d43d78f5140cd5f.zip CMake-a539aed6bf0261e1bbeaa06c6d43d78f5140cd5f.tar.gz CMake-a539aed6bf0261e1bbeaa06c6d43d78f5140cd5f.tar.bz2 |
Merge branch 'cmake-gui-locale' into release-3.20
Merge-request: !7303
-rw-r--r-- | Source/QtDialog/CMakeSetup.cxx | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/Source/QtDialog/CMakeSetup.cxx b/Source/QtDialog/CMakeSetup.cxx index 5debdb8..b041de9 100644 --- a/Source/QtDialog/CMakeSetup.cxx +++ b/Source/QtDialog/CMakeSetup.cxx @@ -10,6 +10,15 @@ #include <QTranslator> #include <QtPlugin> +// FIXME(#23565): Qt6 has QTextCodec in Core5Compat, but using its +// `setCodecForLocale` does not make cmake-gui support non-ASCII chars +// on Windows. For now we only support them with Qt5. How do we support +// them with Qt6, preferably without Core5Compat? +#if defined(Q_OS_WIN) && (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) +# include <QTextCodec> +# define CMAKE_HAVE_QTEXTCODEC +#endif + #include "cmsys/CommandLineArguments.hxx" #include "cmsys/Encoding.hxx" #include "cmsys/SystemTools.hxx" @@ -121,6 +130,11 @@ int main(int argc, char** argv) setlocale(LC_NUMERIC, "C"); +#ifdef CMAKE_HAVE_QTEXTCODEC + QTextCodec* utf8_codec = QTextCodec::codecForName("UTF-8"); + QTextCodec::setCodecForLocale(utf8_codec); +#endif + // tell the cmake library where cmake is QDir cmExecDir(QApplication::applicationDirPath()); #if defined(Q_OS_MAC) |