mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-27 20:25:12 +00:00
Fix escape_string_var for UTF-16
We're now actually handling wchar_t here, so comparing the 0x80 bit would break for UTF-16, causing ASCII false-positives. Also simplifies a bit, since we no longer need a second variable.
This commit is contained in:
parent
b2b4ab4bab
commit
583d771b10
1 changed files with 4 additions and 6 deletions
|
@ -857,23 +857,21 @@ static bool unescape_string_url(const wchar_t *in, wcstring *out) {
|
||||||
static void escape_string_var(const wcstring &in, wcstring &out) {
|
static void escape_string_var(const wcstring &in, wcstring &out) {
|
||||||
bool prev_was_hex_encoded = false;
|
bool prev_was_hex_encoded = false;
|
||||||
for (auto c1 : in) {
|
for (auto c1 : in) {
|
||||||
// This silliness is so we get the correct result whether chars are signed or unsigned.
|
if (c1 >= 0 && c1 <= 127 && isalnum(c1) && (!prev_was_hex_encoded || !is_hex_digit(c1))) {
|
||||||
unsigned int c2 = (unsigned int)c1 & 0xFF;
|
|
||||||
if (!(c2 & 0x80) && isalnum(c2) && (!prev_was_hex_encoded || !is_hex_digit(c2))) {
|
|
||||||
// ASCII alphanumerics don't need to be encoded.
|
// ASCII alphanumerics don't need to be encoded.
|
||||||
if (prev_was_hex_encoded) {
|
if (prev_was_hex_encoded) {
|
||||||
out.push_back(L'_');
|
out.push_back(L'_');
|
||||||
prev_was_hex_encoded = false;
|
prev_was_hex_encoded = false;
|
||||||
}
|
}
|
||||||
out.push_back((wchar_t)c2);
|
out.push_back(c1);
|
||||||
} else if (c2 == '_') {
|
} else if (c1 == L'_') {
|
||||||
// Underscores are encoded by doubling them.
|
// Underscores are encoded by doubling them.
|
||||||
out.append(L"__");
|
out.append(L"__");
|
||||||
prev_was_hex_encoded = false;
|
prev_was_hex_encoded = false;
|
||||||
} else {
|
} else {
|
||||||
// All other chars need to have their UTF-8 representation encoded in hex.
|
// All other chars need to have their UTF-8 representation encoded in hex.
|
||||||
wchar_t buf[4];
|
wchar_t buf[4];
|
||||||
swprintf(buf, sizeof buf / sizeof buf[0], L"_%02X", c2);
|
swprintf(buf, sizeof buf / sizeof buf[0], L"_%02X", c1);
|
||||||
out.append(buf);
|
out.append(buf);
|
||||||
prev_was_hex_encoded = true;
|
prev_was_hex_encoded = true;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue