mirror of
https://github.com/helix-editor/helix.git
synced 2024-11-25 02:46:17 +04:00
feat(commands): increment by range (#4418)
This commit is contained in:
parent
5b73c8c724
commit
bc0a3037ea
@ -4863,14 +4863,18 @@ fn add_newline_impl(cx: &mut Context, open: Open) {
|
||||
apply_transaction(&transaction, doc, view);
|
||||
}
|
||||
|
||||
enum IncrementDirection {
|
||||
Increase,
|
||||
Decrease,
|
||||
}
|
||||
/// Increment object under cursor by count.
|
||||
fn increment(cx: &mut Context) {
|
||||
increment_impl(cx, cx.count() as i64);
|
||||
increment_impl(cx, IncrementDirection::Increase);
|
||||
}
|
||||
|
||||
/// Decrement object under cursor by count.
|
||||
fn decrement(cx: &mut Context) {
|
||||
increment_impl(cx, -(cx.count() as i64));
|
||||
increment_impl(cx, IncrementDirection::Decrease);
|
||||
}
|
||||
|
||||
/// This function differs from find_next_char_impl in that it stops searching at the newline, but also
|
||||
@ -4894,7 +4898,7 @@ fn find_next_char_until_newline<M: CharMatcher>(
|
||||
}
|
||||
|
||||
/// Decrement object under cursor by `amount`.
|
||||
fn increment_impl(cx: &mut Context, amount: i64) {
|
||||
fn increment_impl(cx: &mut Context, increment_direction: IncrementDirection) {
|
||||
// TODO: when incrementing or decrementing a number that gets a new digit or lose one, the
|
||||
// selection is updated improperly.
|
||||
find_char_impl(
|
||||
@ -4906,6 +4910,17 @@ fn increment_impl(cx: &mut Context, amount: i64) {
|
||||
1,
|
||||
);
|
||||
|
||||
// Increase by 1 if `IncrementDirection` is `Increase`
|
||||
// Decrease by 1 if `IncrementDirection` is `Decrease`
|
||||
let sign = match increment_direction {
|
||||
IncrementDirection::Increase => 1,
|
||||
IncrementDirection::Decrease => -1,
|
||||
};
|
||||
let mut amount = sign * cx.count() as i64;
|
||||
|
||||
// If the register is `#` then increase or decrease the `amount` by 1 per element
|
||||
let increase_by = if cx.register == Some('#') { sign } else { 0 };
|
||||
|
||||
let (view, doc) = current!(cx.editor);
|
||||
let selection = doc.selection(view.id);
|
||||
let text = doc.text().slice(..);
|
||||
@ -4925,6 +4940,8 @@ fn increment_impl(cx: &mut Context, amount: i64) {
|
||||
|
||||
let (range, new_text) = incrementor.increment(amount);
|
||||
|
||||
amount += increase_by;
|
||||
|
||||
Some((range.from(), range.to(), Some(new_text)))
|
||||
})
|
||||
.collect();
|
||||
|
Loading…
Reference in New Issue
Block a user