verbatim: show an error message when an invalid Unicode code is entered
The codes from (for example) U+D800 to U+DFFF are invalid. If any
such invalid code is entered at the Unicode Input prompt, nano should
not act as if the code was accepted and inserted into the buffer, and
should certainly not mark the buffer as Modified.
This fixes https://savannah.gnu.org/bugs/?58714.
Bug existed since version 4.9, commit b3faf353
.
master
parent
a2fdf6c486
commit
5899181a31
|
@ -200,7 +200,10 @@ void do_statusbar_verbatim_input(void)
|
||||||
|
|
||||||
bytes = get_verbatim_kbinput(bottomwin, &count);
|
bytes = get_verbatim_kbinput(bottomwin, &count);
|
||||||
|
|
||||||
|
if (count > 0)
|
||||||
inject_into_answer(bytes, count);
|
inject_into_answer(bytes, count);
|
||||||
|
else
|
||||||
|
beep();
|
||||||
|
|
||||||
free(bytes);
|
free(bytes);
|
||||||
}
|
}
|
||||||
|
|
|
@ -3016,6 +3016,7 @@ void do_verbatim_input(void)
|
||||||
/* Read in the first one or two bytes of the next keystroke. */
|
/* Read in the first one or two bytes of the next keystroke. */
|
||||||
bytes = get_verbatim_kbinput(edit, &count);
|
bytes = get_verbatim_kbinput(edit, &count);
|
||||||
|
|
||||||
|
if (count > 0) {
|
||||||
/* Unsuppress cursor-position display or blank the status bar. */
|
/* Unsuppress cursor-position display or blank the status bar. */
|
||||||
if (ISSET(CONSTANT_SHOW))
|
if (ISSET(CONSTANT_SHOW))
|
||||||
lastmessage = VACUUM;
|
lastmessage = VACUUM;
|
||||||
|
@ -3024,6 +3025,8 @@ void do_verbatim_input(void)
|
||||||
|
|
||||||
/* Insert the bytes into the edit buffer. */
|
/* Insert the bytes into the edit buffer. */
|
||||||
inject(bytes, count);
|
inject(bytes, count);
|
||||||
|
} else
|
||||||
|
statusline(ALERT, _("Invalid code"));
|
||||||
|
|
||||||
free(bytes);
|
free(bytes);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue