tweaks: rearrange some code to separate softwrap and normal mode more

(Ignore the indentation for the moment.)
master
Benno Schulenberg 2017-01-13 19:11:11 +01:00
parent 9bb64fccef
commit 980e334e37
1 changed files with 10 additions and 9 deletions

View File

@ -2688,11 +2688,13 @@ int update_line(filestruct *fileptr, size_t index)
if (row < 0 || row >= editwinrows) if (row < 0 || row >= editwinrows)
return 0; return 0;
#ifndef NANO_TINY
if (!ISSET(SOFTWRAP)) {
#endif
/* First, blank out the row. */ /* First, blank out the row. */
blank_row(edit, row, 0, COLS); blank_row(edit, row, 0, COLS);
/* Next, find out from which column to start displaying the line. */ /* Next, find out from which column to start displaying the line. */
if (!ISSET(SOFTWRAP))
from_col = get_page_start(strnlenpt(fileptr->data, index)); from_col = get_page_start(strnlenpt(fileptr->data, index));
/* Expand the line, replacing tabs with spaces, and control /* Expand the line, replacing tabs with spaces, and control
@ -2703,9 +2705,6 @@ int update_line(filestruct *fileptr, size_t index)
edit_draw(fileptr, converted, row, from_col); edit_draw(fileptr, converted, row, from_col);
free(converted); free(converted);
#ifndef NANO_TINY
if (!ISSET(SOFTWRAP)) {
#endif
if (from_col > 0) if (from_col > 0)
mvwaddch(edit, row, margin, '$'); mvwaddch(edit, row, margin, '$');
if (strlenpt(fileptr->data) > from_col + editwincols) if (strlenpt(fileptr->data) > from_col + editwincols)
@ -2714,25 +2713,27 @@ int update_line(filestruct *fileptr, size_t index)
} else { } else {
size_t full_length = strlenpt(fileptr->data); size_t full_length = strlenpt(fileptr->data);
for (from_col += editwincols; from_col <= full_length && for (from_col = 0; from_col <= full_length &&
row < editwinrows - 1; from_col += editwincols) { row < editwinrows; from_col += editwincols) {
/* First, blank out the row. */ /* First, blank out the row. */
blank_row(edit, ++row, 0, COLS); blank_row(edit, row, 0, COLS);
/* Expand the line, replacing tabs with spaces, and control /* Expand the line, replacing tabs with spaces, and control
* characters with their displayed forms. */ * characters with their displayed forms. */
converted = display_string(fileptr->data, from_col, editwincols, TRUE); converted = display_string(fileptr->data, from_col, editwincols, TRUE);
/* Draw the line. */ /* Draw the line. */
edit_draw(fileptr, converted, row, from_col); edit_draw(fileptr, converted, row++, from_col);
free(converted); free(converted);
extra_rows++; extra_rows++;
} }
return --extra_rows;
} }
#endif #endif
return extra_rows; return 0;
} }
/* Check whether old_column and new_column are on different "pages" (or that /* Check whether old_column and new_column are on different "pages" (or that