diff options
| author | Jos van den Oever <jos@vandenoever.info> | 2018-12-29 18:27:13 +0100 | 
|---|---|---|
| committer | Jos van den Oever <jos@vandenoever.info> | 2018-12-30 13:17:49 +0100 | 
| commit | f403d09d0b4958d151790f312ec998ef39632b1a (patch) | |
| tree | a26b23b1c26efb831107334fedf77f4fbe955a07 | |
| parent | d90a37b5a1d892d7b0ff7cc3b56c8a6e8c4bfe1a (diff) | |
| download | kconfig-f403d09d0b4958d151790f312ec998ef39632b1a.tar.gz kconfig-f403d09d0b4958d151790f312ec998ef39632b1a.tar.bz2 | |
Fix a regression introduced in 6a1852
Summary:
Bytes from 'Strings' of type GroupString and KeyString should not be
escaped because they are valid UTF-8. Only instances of ValueString
should be escaped.
This fixes the failing test KConfigTest::testEncoding
Test Plan: Ran `ninja test` and found no errors.
Reviewers: dfaure, arichardson, apol, aacid, ngraham
Reviewed By: apol
Subscribers: kde-frameworks-devel
Tags: #frameworks
Differential Revision: https://phabricator.kde.org/D17856
| -rw-r--r-- | src/core/kconfigini.cpp | 7 | 
1 files changed, 6 insertions, 1 deletions
| diff --git a/src/core/kconfigini.cpp b/src/core/kconfigini.cpp index 39e59364..b6749731 100644 --- a/src/core/kconfigini.cpp +++ b/src/core/kconfigini.cpp @@ -673,7 +673,12 @@ QByteArray KConfigIniBackend::stringToPrintable(const QByteArray &aString, Strin          switch (s[i]) {          default:              // The \n, \t, \r cases (all < 32) are handled below; we can ignore them here -            if (((unsigned char)s[i]) < 32 || ((unsigned char)s[i]) >= 127) { +            if (((unsigned char)s[i]) < 32) { +                goto doEscape; +            } +            // GroupString and KeyString should be valid UTF-8, but ValueString +            // can be a bytearray with non-UTF-8 bytes that should be escaped. +            if (type == ValueString && ((unsigned char)s[i]) >= 127) {                  goto doEscape;              }              *data++ = s[i]; | 
