summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBlaž Hrastnik2021-01-06 06:13:45 +0000
committerBlaž Hrastnik2021-01-06 06:13:45 +0000
commitb2800489dedb44cf030cd425d737ea14491518aa (patch)
treeed9dff554beb66994d4f7d8e4dda2e94189cbaea
parent8b95c3353b9e467dd094f737e56ebe40baffcd02 (diff)
open_below is now indentation-aware.
-rw-r--r--helix-term/src/commands.rs34
1 files changed, 27 insertions, 7 deletions
diff --git a/helix-term/src/commands.rs b/helix-term/src/commands.rs
index 5ced5ad0..4f250247 100644
--- a/helix-term/src/commands.rs
+++ b/helix-term/src/commands.rs
@@ -529,19 +529,39 @@ pub fn open_below(cx: &mut Context) {
})
.collect();
- // TODO: use same logic as insert_newline for indentation
- let changes = positions.iter().copied().map(|index|
+ let changes = positions.iter().copied().map(|index| {
+ // TODO: share logic with insert_newline for indentation
+ let indent_level = helix_core::indent::suggested_indent_for_pos(
+ cx.view.doc.syntax.as_ref(),
+ &cx.view.doc.state,
+ index,
+ );
+ let indent = " ".repeat(TAB_WIDTH).repeat(indent_level);
+ let mut text = String::with_capacity(1 + indent.len());
+ text.push_str(&indent);
+ text.push('\n');
+
+ // TODO: ideally we want to run a hook over the transactions to figure out and reindent all
+ // \n's as a post-processing step?
+ // behaviors:
+ // - on insert mode enter: we add newline + indent and position cursor at the end
+ // - on 3o/3O: we insert 3 newlines + indents each and position cursors at ends
+
// generate changes
- (index, index, Some(Tendril::from_char('\n'))));
+ (index, index, Some(text.into()))
+ });
// TODO: count actually inserts "n" new lines and starts editing on all of them.
// TODO: append "count" newlines and modify cursors to those lines
let selection = Selection::new(
- positions
- .iter()
- .copied()
- .map(|pos| Range::new(pos, pos))
+ changes
+ .clone()
+ .map(|(start, end, text): (usize, usize, Option<Tendril>)| {
+ let len = text.map(|text| text.len()).unwrap() - 1; // minus newline
+ let pos = start + len;
+ Range::new(pos, pos)
+ })
.collect(),
0,
);