mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-14 14:03:58 +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 converted = [0_u8; AT_LEAST_MB_LEN_MAX];
|
||||
|
||||
let is_singlebyte_locale = MB_CUR_MAX() == 1;
|
||||
|
||||
for c in input.chars() {
|
||||
// TODO: this doesn't seem sound.
|
||||
if c == INTERNAL_SEPARATOR {
|
||||
|
@ -274,7 +276,7 @@ pub fn wcs2string_callback(input: &wstr, mut func: impl FnMut(&[u8]) -> bool) ->
|
|||
if !func(&converted[..1]) {
|
||||
return false;
|
||||
}
|
||||
} else if MB_CUR_MAX() == 1 {
|
||||
} else if is_singlebyte_locale {
|
||||
// single-byte locale (C/POSIX/ISO-8859)
|
||||
// If `c` contains a wide character we emit a question-mark.
|
||||
converted[0] = u8::try_from(u32::from(c)).unwrap_or(b'?');
|
||||
|
|
Loading…
Reference in a new issue