diff --git a/crates/nu-command/src/strings/str_/substring.rs b/crates/nu-command/src/strings/str_/substring.rs index 9e06840ab..ec5df7ef4 100644 --- a/crates/nu-command/src/strings/str_/substring.rs +++ b/crates/nu-command/src/strings/str_/substring.rs @@ -157,12 +157,18 @@ fn action(input: &Value, options: &Substring, head: Span) -> Value { Ordering::Less => Value::String { val: { if end == isize::max_value() { - s.chars().skip(start as usize).collect::() + String::from_utf8_lossy( + &s.bytes().skip(start as usize).collect::>(), + ) + .to_string() } else { - s.chars() - .skip(start as usize) - .take((end - start) as usize) - .collect::() + String::from_utf8_lossy( + &s.bytes() + .skip(start as usize) + .take((end - start) as usize) + .collect::>(), + ) + .to_string() } }, span: head, diff --git a/src/tests.rs b/src/tests.rs index a87fed402..fc5bf3383 100644 --- a/src/tests.rs +++ b/src/tests.rs @@ -1316,3 +1316,11 @@ fn flatten_should_flatten_inner_table() -> TestResult { "123", ) } + +#[test] +fn cjk_in_substrings() -> TestResult { + run_test( + r#"let s = '[Rust 程序设计语言](title-page.md)'; let start = ($s | str index-of '('); let end = ($s | str index-of ')'); echo ($s | str substring $"($start + 1),($end)")"#, + "title-page.md", + ) +}