Bug 360364 - Kleopatra displays an error report received from gpg in gibberish after clicking "refresh OpenPGP certificates". .
Summary: Kleopatra displays an error report received from gpg in gibberish after click...
Status: RESOLVED FIXED
Alias: None
Product: kleopatra
Classification: Applications
Component: general (show other bugs)
Version: 3.0.0
Platform: Microsoft Windows Microsoft Windows
: NOR grave
Target Milestone: ---
Assignee: Andre Heinecke
URL: http://i.imgur.com/LYpH90d.png
Keywords:
Depends on:
Blocks:
 
Reported: 2016-03-10 15:50 UTC by lockywolf
Modified: 2018-07-21 04:00 UTC (History)
2 users (show)

See Also:
Latest Commit:
Version Fixed In:
Sentry Crash Report:


Attachments
New screenshot 1 (93.93 KB, image/png)
2017-11-08 01:10 UTC, lockywolf
Details
New screenshot 2 (54.71 KB, image/png)
2017-11-08 01:11 UTC, lockywolf
Details

Note You need to log in before you can comment on or make changes to this bug.
Description lockywolf 2016-03-10 15:50:46 UTC
That's it. I was doing everything as it was described in the compendium. I registered at CAcert, generated a certificate, imported it into Kleopatra. 

Then I clicked Tools-Refresh OpenPGP certificates, and got this error.


Reproducible: Always

Steps to Reproduce:
1.Install CAcert openpgp certificate.
2.Click "Tools-Refresh OpenPGP Cretificates"
3.See the result.

Actual Results:  
I saw an error message in broken encoding.

Expected Results:  
To see the real description of an error.
Comment 1 Andre Heinecke 2016-04-08 15:50:33 UTC
This looks like a nasty mismatch between console OEM charset and gui ANSI charset.

I've looked at it and Kleopatra takes the error from GnuPG and converts it with QString::fromLocal8Bit and this uses the ANSI charset while GnuPG uses the OEM charset. *sigh*

I'll add some conversion code to handle this properly.
Comment 2 lockywolf 2017-11-08 01:10:51 UTC
Created attachment 108735 [details]
New screenshot 1
Comment 3 lockywolf 2017-11-08 01:11:19 UTC
Created attachment 108736 [details]
New screenshot 2
Comment 4 lockywolf 2017-11-08 01:18:04 UTC
The bug is still there :-).

One of the problems here may be the historical disparity and hassle with Cyrillic encodings. Nearly everywhere MS Windows uses cp1251, their own development. In all strings, in Notepad-created text files, etc.

But cmd.exe console uses cp866, inherited from IBM DOS.

(In fact, both encodings are non-standard, but that's a different story.)
Comment 5 Andre Heinecke 2018-07-18 09:26:35 UTC
Git commit 289efa360f6b15a3389ea2f2efede352711e7d7e by Andre Heinecke.
Committed on 18/07/2018 at 09:26.
Pushed by aheinecke into branch 'master'.

Another try to fix windows encoding mess

We now put GnuPG's output through a central conversion
function so that we have a place to modify when things
change.

The Problem is that on my western windows system GnuPG
gets CP 437 as GetConsoleOutputCP and prints in that codepage.
We get 0 as GetConsoleOutputCP and 1252 with GetACP.

The only thing that seemed to somehow match was GetOEMCP but
that might just be luck and it might still be broken in
other windows languages.

Using --display-charset utf8 does not work (even when fixing
the argument order) and is also not available for GPGSM.

M  +1    -1    src/commands/dumpcertificatecommand.cpp
M  +5    -4    src/commands/gnupgprocesscommand.cpp
M  +51   -0    src/utils/gnupg-helper.cpp
M  +6    -1    src/utils/gnupg-helper.h

https://commits.kde.org/kleopatra/289efa360f6b15a3389ea2f2efede352711e7d7e
Comment 6 Andre Heinecke 2018-07-18 09:27:34 UTC
I hope that it will be fixed with Gpg4win-3.1.3

At least for my windows test system it works now. But the encoding is so messy that it might still be broken in other situations.
Comment 7 lockywolf 2018-07-21 04:00:43 UTC
I don't have Windows at the moment to test the issue, but thanks for your work!
Windows character encoding system is unbelievably messy.