nano

nano with my custom patches
git clone git://bsandro.tech/nano
Log | Files | Refs | README | LICENSE

commit 9bedc4b71cb13a0a0a222cdc72c6e3200aa75176
parent 47b693e5823f9ef6d716b3c4f24a8d087bced321
Author: David Lawrence Ramsey <pooka109@gmail.com>
Date:   Wed,  9 Nov 2005 19:51:48 +0000

fix breakage in find_paragraph() and do_justify()


git-svn-id: svn://svn.savannah.gnu.org/nano/trunk/nano@3131 35c25a1d-7b9e-4130-9fde-d3aeb78583b8

Diffstat:
Msrc/text.c | 21++++++++++++---------
1 file changed, 12 insertions(+), 9 deletions(-)

diff --git a/src/text.c b/src/text.c @@ -1081,20 +1081,21 @@ bool find_paragraph(size_t *const quote, size_t *const par) /* Now current is the first line of the paragraph. Set quote_len to * the quotation length of that line, and set par_len to the number - * of lines in this paragraph by temporarily moving to the last line - * of it and saving the difference in line numbers. If, after - * moving, we end up on the same line and x-coordinate as before, it - * means that there aren't any paragraphs left, so get out. If we - * end up on the same line with a different x-coordinate from - * before, it means that the line is part of the paragraph. */ + * of lines in this paragraph. If, while calculating the latter, we + * end up at the end of the last line of the file, and we were there + * before moving, it means that there aren't any paragraphs left, so + * get out. If we weren't there before moving, it means that the + * line is part of the paragraph. */ quote_len = quote_length(openfile->current->data); current_save = openfile->current; current_x_save = openfile->current_x; current_y_save = openfile->current_y; do_para_end(FALSE); par_len = openfile->current->lineno - current_save->lineno; - if (openfile->current == current_save) { - if (openfile->current_x == current_x_save) + if (openfile->current == openfile->filebot && openfile->current_x == + strlen(openfile->current->data)) { + if (openfile->current == current_save && + openfile->current_x == current_x_save) return FALSE; else par_len++; @@ -1271,9 +1272,11 @@ void do_justify(bool full_justify) strcat(openfile->current->data, next_line->data + indent_len); - /* Don't destroy edittop! */ + /* Don't destroy edittop or filebot! */ if (next_line == openfile->edittop) openfile->edittop = openfile->current; + if (next_line == openfile->filebot) + openfile->filebot = openfile->current; #ifndef NANO_SMALL /* Adjust the mark coordinates to compensate for the change