mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-14 14:03:58 +00:00
Fix arithmetic overflow in up-line
The C++ code implicitly relied on wrapping behavior. There are probably more cases like this. Maybe we should disable "overflow-checks" in release mode.
This commit is contained in:
parent
114ebe3b8f
commit
e84d110995
3 changed files with 16 additions and 4 deletions
|
@ -528,10 +528,11 @@ pub fn parse_util_get_offset_from_line(s: &wstr, line: i32) -> Option<usize> {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Return the total offset of the buffer for the cursor position nearest to the specified position.
|
/// Return the total offset of the buffer for the cursor position nearest to the specified position.
|
||||||
pub fn parse_util_get_offset(s: &wstr, line: i32, mut line_offset: usize) -> Option<usize> {
|
pub fn parse_util_get_offset(s: &wstr, line: i32, line_offset: isize) -> Option<usize> {
|
||||||
let off = parse_util_get_offset_from_line(s, line)?;
|
let off = parse_util_get_offset_from_line(s, line)?;
|
||||||
let off2 = parse_util_get_offset_from_line(s, line + 1).unwrap_or(s.len() + 1);
|
let off2 = parse_util_get_offset_from_line(s, line + 1).unwrap_or(s.len() + 1);
|
||||||
|
|
||||||
|
let mut line_offset = line_offset as usize;
|
||||||
if line_offset >= off2 - off - 1 {
|
if line_offset >= off2 - off - 1 {
|
||||||
line_offset = off2 - off - 1;
|
line_offset = off2 - off - 1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -2648,10 +2648,11 @@ impl ReaderData {
|
||||||
|
|
||||||
let indent_old = indents[std::cmp::min(indents.len() - 1, base_pos_old)];
|
let indent_old = indents[std::cmp::min(indents.len() - 1, base_pos_old)];
|
||||||
let indent_new = indents[std::cmp::min(indents.len() - 1, base_pos_new)];
|
let indent_new = indents[std::cmp::min(indents.len() - 1, base_pos_new)];
|
||||||
let indent_old = usize::try_from(indent_old).unwrap();
|
let indent_old = isize::try_from(indent_old).unwrap();
|
||||||
let indent_new = usize::try_from(indent_new).unwrap();
|
let indent_new = isize::try_from(indent_new).unwrap();
|
||||||
|
|
||||||
let line_offset_old = el.position() - base_pos_old;
|
let line_offset_old =
|
||||||
|
isize::try_from(el.position() - base_pos_old).unwrap();
|
||||||
let total_offset_new = parse_util_get_offset(
|
let total_offset_new = parse_util_get_offset(
|
||||||
el.text(),
|
el.text(),
|
||||||
line_new,
|
line_new,
|
||||||
|
|
|
@ -9,3 +9,13 @@ tmux-sleep
|
||||||
isolated-tmux capture-pane -p
|
isolated-tmux capture-pane -p
|
||||||
# CHECK: prompt 0> echo 12345
|
# CHECK: prompt 0> echo 12345
|
||||||
# CHECK: echo abcde
|
# CHECK: echo abcde
|
||||||
|
|
||||||
|
isolated-tmux send-keys C-c
|
||||||
|
tmux-sleep
|
||||||
|
isolated-tmux send-keys C-l
|
||||||
|
isolated-tmux send-keys begin Enter 'echo 1' Enter e n d C-p 23
|
||||||
|
tmux-sleep
|
||||||
|
isolated-tmux capture-pane -p
|
||||||
|
# CHECK: prompt 0> begin
|
||||||
|
# CHECK: echo 123
|
||||||
|
# CHECK: end
|
||||||
|
|
Loading…
Reference in a new issue