softwrap: improve Left and Right's behavior with softwrapped chunks
Use the new "unclever" functionality of Home and End to make do_left() and do_right() move properly to the end of the previous chunk or to the start of the next chunk in softwrap mode when crossing a line boundary. (Furthermore, doing Up plus End, or Down plus Home, does all needed screen updates, which simplifies the code.) The do_left() and do_right() functions don't yet properly move vertically at line boundaries, but that will be fixed once do_up() and do_down() are updated for softwrap mode, which is forthcoming. This fixes https://savannah.gnu.org/bugs/?49384.master
parent
a5e106d764
commit
56402e7589
48
src/move.c
48
src/move.c
|
@ -592,17 +592,34 @@ void do_scroll_down(void)
|
||||||
void do_left(void)
|
void do_left(void)
|
||||||
{
|
{
|
||||||
size_t was_column = xplustabs();
|
size_t was_column = xplustabs();
|
||||||
|
#ifndef NANO_TINY
|
||||||
|
size_t was_chunk = (was_column / editwincols);
|
||||||
|
filestruct *was_current = openfile->current;
|
||||||
|
#endif
|
||||||
|
|
||||||
if (openfile->current_x > 0)
|
if (openfile->current_x > 0)
|
||||||
openfile->current_x = move_mbleft(openfile->current->data,
|
openfile->current_x = move_mbleft(openfile->current->data,
|
||||||
openfile->current_x);
|
openfile->current_x);
|
||||||
else if (openfile->current != openfile->fileage) {
|
else if (openfile->current != openfile->fileage) {
|
||||||
do_up_void();
|
do_up_void();
|
||||||
openfile->current_x = strlen(openfile->current->data);
|
do_end(FALSE);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
openfile->placewewant = xplustabs();
|
openfile->placewewant = xplustabs();
|
||||||
|
|
||||||
|
#ifndef NANO_TINY
|
||||||
|
/* If we were on the first line of the edit window, and we changed chunk,
|
||||||
|
* we're now above the first line of the edit window, so scroll up. */
|
||||||
|
if (ISSET(SOFTWRAP) && openfile->current_y == 0 &&
|
||||||
|
openfile->current == was_current &&
|
||||||
|
(openfile->placewewant / editwincols) != was_chunk) {
|
||||||
|
edit_scroll(UPWARD, ISSET(SMOOTH_SCROLL) ? 1 : editwinrows / 2 + 1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Update current if the mark is on or it has changed "page". */
|
||||||
if (line_needs_update(was_column, openfile->placewewant))
|
if (line_needs_update(was_column, openfile->placewewant))
|
||||||
update_line(openfile->current, openfile->current_x);
|
update_line(openfile->current, openfile->current_x);
|
||||||
}
|
}
|
||||||
|
@ -611,25 +628,34 @@ void do_left(void)
|
||||||
void do_right(void)
|
void do_right(void)
|
||||||
{
|
{
|
||||||
size_t was_column = xplustabs();
|
size_t was_column = xplustabs();
|
||||||
|
#ifndef NANO_TINY
|
||||||
|
size_t was_chunk = (was_column / editwincols);
|
||||||
|
filestruct *was_current = openfile->current;
|
||||||
|
#endif
|
||||||
|
|
||||||
if (openfile->current->data[openfile->current_x] != '\0')
|
if (openfile->current->data[openfile->current_x] != '\0')
|
||||||
openfile->current_x = move_mbright(openfile->current->data,
|
openfile->current_x = move_mbright(openfile->current->data,
|
||||||
openfile->current_x);
|
openfile->current_x);
|
||||||
else if (openfile->current != openfile->filebot) {
|
else if (openfile->current != openfile->filebot) {
|
||||||
openfile->current_x = 0;
|
do_home(FALSE);
|
||||||
#ifndef NANO_TINY
|
do_down_void();
|
||||||
if (ISSET(SOFTWRAP))
|
return;
|
||||||
openfile->current_y -= strlenpt(openfile->current->data) / editwincols;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
openfile->placewewant = xplustabs();
|
openfile->placewewant = xplustabs();
|
||||||
|
|
||||||
|
#ifndef NANO_TINY
|
||||||
|
/* If we were on the last line of the edit window, and we changed chunk,
|
||||||
|
* we're now below the first line of the edit window, so scroll down. */
|
||||||
|
if (ISSET(SOFTWRAP) && openfile->current_y == editwinrows - 1 &&
|
||||||
|
openfile->current == was_current &&
|
||||||
|
openfile->placewewant / editwincols != was_chunk) {
|
||||||
|
edit_scroll(DOWNWARD, ISSET(SMOOTH_SCROLL) ? 1 : editwinrows / 2 + 1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Update current if the mark is on or it has changed "page". */
|
||||||
if (line_needs_update(was_column, openfile->placewewant))
|
if (line_needs_update(was_column, openfile->placewewant))
|
||||||
update_line(openfile->current, openfile->current_x);
|
update_line(openfile->current, openfile->current_x);
|
||||||
|
|
||||||
if (openfile->current_x == 0)
|
|
||||||
do_down_void();
|
|
||||||
else
|
|
||||||
ensure_line_is_visible();
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue