feat(commands): increment by range (#4418)

This commit is contained in:
Bruce Hopkins 2022-11-11 19:50:25 +01:00 committed by GitHub
parent 5b73c8c724
commit bc0a3037ea
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -4863,14 +4863,18 @@ fn add_newline_impl(cx: &mut Context, open: Open) {
apply_transaction(&transaction, doc, view); apply_transaction(&transaction, doc, view);
} }
enum IncrementDirection {
Increase,
Decrease,
}
/// Increment object under cursor by count. /// Increment object under cursor by count.
fn increment(cx: &mut Context) { fn increment(cx: &mut Context) {
increment_impl(cx, cx.count() as i64); increment_impl(cx, IncrementDirection::Increase);
} }
/// Decrement object under cursor by count. /// Decrement object under cursor by count.
fn decrement(cx: &mut Context) { 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 /// 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`. /// 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 // TODO: when incrementing or decrementing a number that gets a new digit or lose one, the
// selection is updated improperly. // selection is updated improperly.
find_char_impl( find_char_impl(
@ -4906,6 +4910,17 @@ fn increment_impl(cx: &mut Context, amount: i64) {
1, 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 (view, doc) = current!(cx.editor);
let selection = doc.selection(view.id); let selection = doc.selection(view.id);
let text = doc.text().slice(..); let text = doc.text().slice(..);
@ -4925,6 +4940,8 @@ fn increment_impl(cx: &mut Context, amount: i64) {
let (range, new_text) = incrementor.increment(amount); let (range, new_text) = incrementor.increment(amount);
amount += increase_by;
Some((range.from(), range.to(), Some(new_text))) Some((range.from(), range.to(), Some(new_text)))
}) })
.collect(); .collect();