mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-28 04:35:09 +00:00
Check MB_CUR_MAX() outside of loop
This is more correct - we don't want to change how we encode this string in the middle of encoding it, and also happens to be a bit faster in my benchmarks because this is actually a function call according to valgrind.
This commit is contained in:
parent
ae24d98356
commit
0d6c6b2c8a
1 changed files with 3 additions and 1 deletions
|
@ -265,6 +265,8 @@ pub fn wcs2string_callback(input: &wstr, mut func: impl FnMut(&[u8]) -> bool) ->
|
||||||
let mut state = zero_mbstate();
|
let mut state = zero_mbstate();
|
||||||
let mut converted = [0_u8; AT_LEAST_MB_LEN_MAX];
|
let mut converted = [0_u8; AT_LEAST_MB_LEN_MAX];
|
||||||
|
|
||||||
|
let is_singlebyte_locale = MB_CUR_MAX() == 1;
|
||||||
|
|
||||||
for c in input.chars() {
|
for c in input.chars() {
|
||||||
// TODO: this doesn't seem sound.
|
// TODO: this doesn't seem sound.
|
||||||
if c == INTERNAL_SEPARATOR {
|
if c == INTERNAL_SEPARATOR {
|
||||||
|
@ -274,7 +276,7 @@ pub fn wcs2string_callback(input: &wstr, mut func: impl FnMut(&[u8]) -> bool) ->
|
||||||
if !func(&converted[..1]) {
|
if !func(&converted[..1]) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
} else if MB_CUR_MAX() == 1 {
|
} else if is_singlebyte_locale {
|
||||||
// single-byte locale (C/POSIX/ISO-8859)
|
// single-byte locale (C/POSIX/ISO-8859)
|
||||||
// If `c` contains a wide character we emit a question-mark.
|
// If `c` contains a wide character we emit a question-mark.
|
||||||
converted[0] = u8::try_from(u32::from(c)).unwrap_or(b'?');
|
converted[0] = u8::try_from(u32::from(c)).unwrap_or(b'?');
|
||||||
|
|
Loading…
Reference in a new issue