tweaks: use two extra variables to make it clearer what is being done

This addresses https://savannah.gnu.org/patch/?9215.
Inspired-by: David Lawrence Ramsey <pooka109@gmail.com>
master
Benno Schulenberg 2017-02-26 17:18:39 +01:00
parent 59e10bdef2
commit 2e53ed2928
1 changed files with 15 additions and 12 deletions

View File

@ -2266,33 +2266,36 @@ void onekey(const char *keystroke, const char *desc, int length)
} }
/* Redetermine current_y from the position of current relative to edittop, /* Redetermine current_y from the position of current relative to edittop,
* and put the cursor in the edit window at (current_y, current_x). */ * and put the cursor in the edit window at (current_y, "current_x"). */
void reset_cursor(void) void reset_cursor(void)
{ {
size_t xpt = xplustabs(); ssize_t row;
size_t col, xpt = xplustabs();
#ifndef NANO_TINY #ifndef NANO_TINY
if (ISSET(SOFTWRAP)) { if (ISSET(SOFTWRAP)) {
filestruct *line = openfile->edittop; filestruct *line = openfile->edittop;
openfile->current_y = 0;
/* Calculate how many rows the lines from edittop to current use. */
while (line != NULL && line != openfile->current) { while (line != NULL && line != openfile->current) {
openfile->current_y += strlenpt(line->data) / editwincols + 1; row += strlenpt(line->data) / editwincols + 1;
line = line->next; line = line->next;
} }
openfile->current_y += xpt / editwincols;
if (openfile->current_y < editwinrows) /* Add the number of wraps in the current line before the cursor. */
wmove(edit, openfile->current_y, xpt % editwincols + margin); row += xpt / editwincols;
col = xpt % editwincols;
} else } else
#endif #endif
{ {
openfile->current_y = openfile->current->lineno - row = openfile->current->lineno - openfile->edittop->lineno;
openfile->edittop->lineno; col = xpt - get_page_start(xpt);
if (openfile->current_y < editwinrows)
wmove(edit, openfile->current_y, xpt - get_page_start(xpt) + margin);
} }
if (row < editwinrows)
wmove(edit, row, margin + col);
openfile->current_y = row;
} }
/* edit_draw() takes care of the job of actually painting a line into /* edit_draw() takes care of the job of actually painting a line into