softwrap: iterate through softwrapped chunks in edit_scroll()

Use go_back_chunks() and go_forward_chunks() to adjust edittop and to
move up or down to the scrolled region before updating the rows there.
Now softwrap mode and non-softwrap mode will behave the same way when
we can scroll the top line of the screen partially off the screen,
which is forthcoming.

(Note that the top line of the screen can't be partially scrolled yet,
so we have to work around that for now.)
master
David Lawrence Ramsey 2017-01-19 13:23:11 -06:00 committed by Benno Schulenberg
parent fa025f0ca3
commit ba4858de83
1 changed files with 18 additions and 22 deletions

View File

@ -2861,6 +2861,11 @@ void edit_scroll(scroll_dir direction, int nrows)
{ {
int i; int i;
filestruct *line; filestruct *line;
size_t leftedge;
/* FIXME: This should be replaced with openfile->firstcolumn when the
* latter is added. */
size_t firstcolumn = 0;
/* Part 1: nrows is the number of rows we're going to scroll the text of /* Part 1: nrows is the number of rows we're going to scroll the text of
* the edit window. */ * the edit window. */
@ -2868,27 +2873,19 @@ void edit_scroll(scroll_dir direction, int nrows)
/* Move the top line of the edit window up or down (depending on the value /* Move the top line of the edit window up or down (depending on the value
* of direction) nrows rows, or as many rows as we can if there are fewer * of direction) nrows rows, or as many rows as we can if there are fewer
* than nrows rows available. */ * than nrows rows available. */
for (i = nrows; i > 0; i--) { if (direction == UPWARD)
if (direction == UPWARD) { i = go_back_chunks(nrows, &openfile->edittop, &firstcolumn);
if (openfile->edittop == openfile->fileage) else
break; i = go_forward_chunks(nrows, &openfile->edittop, &firstcolumn);
openfile->edittop = openfile->edittop->prev;
} else {
if (openfile->edittop == openfile->filebot)
break;
openfile->edittop = openfile->edittop->next;
}
#ifndef NANO_TINY #ifndef NANO_TINY
/* Don't over-scroll on long lines. */ /* FIXME: nano currently can't handle a partially scrolled edittop,
if (ISSET(SOFTWRAP) && direction == UPWARD) { * so for now: move edittop back to a full line and refresh. */
ssize_t len = strlenpt(openfile->edittop->data) / editwincols; if (ISSET(SOFTWRAP) && firstcolumn > 0) {
i -= len; openfile->edittop = openfile->edittop->prev;
if (len > 0) refresh_needed = TRUE;
refresh_needed = TRUE;
}
#endif
} }
#endif
/* Limit nrows to the number of rows we could scroll. */ /* Limit nrows to the number of rows we could scroll. */
nrows -= i; nrows -= i;
@ -2921,12 +2918,11 @@ void edit_scroll(scroll_dir direction, int nrows)
/* If we scrolled up, we're on the line before the scrolled region. */ /* If we scrolled up, we're on the line before the scrolled region. */
line = openfile->edittop; line = openfile->edittop;
leftedge = firstcolumn;
/* If we scrolled down, move down to the line before the scrolled region. */ /* If we scrolled down, move down to the line before the scrolled region. */
if (direction == DOWNWARD) { if (direction == DOWNWARD)
for (i = editwinrows - nrows; i > 0 && line != NULL; i--) go_forward_chunks(editwinrows - nrows, &line, &leftedge);
line = line->next;
}
/* Draw new lines on any blank rows before or inside the scrolled region. /* Draw new lines on any blank rows before or inside the scrolled region.
* If we're not in softwrap mode, we can optimize one case: if we scrolled * If we're not in softwrap mode, we can optimize one case: if we scrolled