Fix indent regression issue with o, O
Indents were no longer respected with `o` and `O`. Using counts resulted
in multiple cursors in the same line instead of cursors on each line.
Introduced by 47d2e3ae
This commit is contained in:
parent
a3cb79ebaa
commit
b1cb98283d
1 changed files with 6 additions and 2 deletions
|
@ -1641,7 +1641,8 @@ fn open(cx: &mut Context, open: Open) {
|
|||
true,
|
||||
);
|
||||
let indent = doc.indent_unit().repeat(indent_level);
|
||||
let mut text = String::with_capacity(1 + indent.len());
|
||||
let indent_len = indent.len();
|
||||
let mut text = String::with_capacity(1 + indent_len);
|
||||
text.push('\n');
|
||||
text.push_str(&indent);
|
||||
let text = text.repeat(count);
|
||||
|
@ -1653,7 +1654,10 @@ fn open(cx: &mut Context, open: Open) {
|
|||
offs + linend_index + 1
|
||||
};
|
||||
for i in 0..count {
|
||||
ranges.push(Range::new(pos + i, pos + i));
|
||||
// pos -> beginning of reference line,
|
||||
// + (i * (1+indent_len)) -> beginning of i'th line from pos
|
||||
// + indent_len -> -> indent for i'th line
|
||||
ranges.push(Range::point(pos + (i * (1 + indent_len)) + indent_len));
|
||||
}
|
||||
|
||||
offs += text.chars().count();
|
||||
|
|
Loading…
Reference in a new issue