cutting: when deleting whole words, don't join lines unexpectedly
That is, wait with deleting words until they start under cursor, so the user can see which word is goin to be eaten, and join lines only when the cursor already sits at the edge of a line.master
parent
e6429e782a
commit
e21ce0db1f
22
src/text.c
22
src/text.c
|
@ -205,11 +205,27 @@ void do_cutword(bool backward)
|
||||||
cutbuffer = NULL;
|
cutbuffer = NULL;
|
||||||
cutbottom = NULL;
|
cutbottom = NULL;
|
||||||
|
|
||||||
/* Move the cursor to a word start, to the left or to the right. */
|
/* Move the cursor to a word start, to the left or to the right.
|
||||||
if (backward)
|
* If that word is on another line and the cursor was not already
|
||||||
|
* on the edge of the original line, then put the cursor on that
|
||||||
|
* edge instead, so that lines will not be joined unexpectedly. */
|
||||||
|
if (backward) {
|
||||||
do_prev_word(ISSET(WORD_BOUNDS), FALSE);
|
do_prev_word(ISSET(WORD_BOUNDS), FALSE);
|
||||||
else
|
if (openfile->current != is_current) {
|
||||||
|
if (is_current_x > 0) {
|
||||||
|
openfile->current = is_current;
|
||||||
|
openfile->current_x = 0;
|
||||||
|
} else
|
||||||
|
openfile->current_x = strlen(openfile->current->data);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
do_next_word(FALSE, ISSET(WORD_BOUNDS), FALSE);
|
do_next_word(FALSE, ISSET(WORD_BOUNDS), FALSE);
|
||||||
|
if (openfile->current != is_current &&
|
||||||
|
is_current->data[is_current_x] != '\0') {
|
||||||
|
openfile->current = is_current;
|
||||||
|
openfile->current_x = strlen(is_current->data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Set the mark at the start of that word. */
|
/* Set the mark at the start of that word. */
|
||||||
openfile->mark = openfile->current;
|
openfile->mark = openfile->current;
|
||||||
|
|
Loading…
Reference in New Issue