1
1

speller: don't add an extra newline when saving the text to a tempfile

Set the NO_NEWLINES flag to achieve this.  And move the saving and
restoring of the global flags to the main speller routine, so the
flags aren't saved and restored for each internal spell fix.

This fixes https://savannah.gnu.org/bugs/?53742.

Acked-by: David Lawrence Ramsey <pooka109@gmail.com>
Этот коммит содержится в:
Benno Schulenberg 2018-04-25 11:33:22 +02:00
родитель f54cd02652
Коммит faa0eb991e

Просмотреть файл

@ -2536,8 +2536,6 @@ bool fix_spello(const char *word)
/* The return value of this function. */ /* The return value of this function. */
bool result; bool result;
/* The return value of searching for a misspelled word. */ /* The return value of searching for a misspelled word. */
unsigned stash[sizeof(flags) / sizeof(flags[0])];
/* A storage place for the current flag settings. */
#ifndef NANO_TINY #ifndef NANO_TINY
bool right_side_up = FALSE; bool right_side_up = FALSE;
/* TRUE if (mark_begin, mark_begin_x) is the top of the mark, /* TRUE if (mark_begin, mark_begin_x) is the top of the mark,
@ -2546,9 +2544,6 @@ bool fix_spello(const char *word)
size_t top_x, bot_x; size_t top_x, bot_x;
#endif #endif
/* Save the settings of the global flags. */
memcpy(stash, flags, sizeof(flags));
/* Do the spell checking case sensitive, forward, and without regexes. */ /* Do the spell checking case sensitive, forward, and without regexes. */
SET(CASE_SENSITIVE); SET(CASE_SENSITIVE);
UNSET(BACKWARDS_SEARCH); UNSET(BACKWARDS_SEARCH);
@ -2645,9 +2640,6 @@ bool fix_spello(const char *word)
openfile->edittop = edittop_save; openfile->edittop = edittop_save;
openfile->firstcolumn = firstcolumn_save; openfile->firstcolumn = firstcolumn_save;
/* Restore the settings of the global flags. */
memcpy(flags, stash, sizeof(flags));
return proceed; return proceed;
} }
@ -2944,6 +2936,8 @@ void do_spell(void)
bool status; bool status;
FILE *temp_file; FILE *temp_file;
char *temp; char *temp;
unsigned stash[sizeof(flags) / sizeof(flags[0])];
/* A storage place for the current flag settings. */
const char *spell_msg; const char *spell_msg;
if (ISSET(RESTRICTED)) { if (ISSET(RESTRICTED)) {
@ -2958,6 +2952,12 @@ void do_spell(void)
return; return;
} }
/* Save the settings of the global flags. */
memcpy(stash, flags, sizeof(flags));
/* Don't add an extra newline when writing out the (selected) text. */
SET(NO_NEWLINES);
#ifndef NANO_TINY #ifndef NANO_TINY
if (openfile->mark) if (openfile->mark)
status = write_marked_file(temp, temp_file, TRUE, OVERWRITE); status = write_marked_file(temp, temp_file, TRUE, OVERWRITE);
@ -2979,6 +2979,9 @@ void do_spell(void)
unlink(temp); unlink(temp);
free(temp); free(temp);
/* Restore the settings of the global flags. */
memcpy(flags, stash, sizeof(flags));
/* If the spell-checker printed any error messages onscreen, make /* If the spell-checker printed any error messages onscreen, make
* sure that they're cleared off. */ * sure that they're cleared off. */
total_refresh(); total_refresh();