tweaks: use a better symbol than 'ERR' to signify a valid hex digit

master
Benno Schulenberg 2020-07-11 18:58:12 +02:00
parent b3d6c27502
commit d3a8488b0e
1 changed files with 11 additions and 9 deletions

View File

@ -1351,8 +1351,10 @@ int get_byte_kbinput(int kbinput)
} }
#ifdef ENABLE_UTF8 #ifdef ENABLE_UTF8
#define PROCEED -4
/* If the character in kbinput is a valid hexadecimal digit, multiply it /* If the character in kbinput is a valid hexadecimal digit, multiply it
* by factor and add the result to uni, and return ERR to signify okay. */ * by factor and add the result to uni, and return PROCEED to signify okay. */
long add_unicode_digit(int kbinput, long factor, long *uni) long add_unicode_digit(int kbinput, long factor, long *uni)
{ {
if ('0' <= kbinput && kbinput <= '9') if ('0' <= kbinput && kbinput <= '9')
@ -1363,17 +1365,17 @@ long add_unicode_digit(int kbinput, long factor, long *uni)
/* The character isn't hexadecimal; give it as the result. */ /* The character isn't hexadecimal; give it as the result. */
return (long)kbinput; return (long)kbinput;
return ERR; return PROCEED;
} }
/* For each consecutive call, gather the given digit into a six-digit Unicode /* For each consecutive call, gather the given digit into a six-digit Unicode
* (from 000000 to 10FFFF, case-insensitive). When it is complete, return the * (from 000000 to 10FFFF, case-insensitive). When it is complete, return the
* assembled Unicode; until then, return ERR when the given digit is valid. */ * assembled Unicode; until then, return PROCEED when the given digit is valid. */
long assemble_unicode(int kbinput) long assemble_unicode(int kbinput)
{ {
static int uni_digits = 0; static int uni_digits = 0;
static long uni = 0; static long uni = 0;
long retval = ERR; long retval = PROCEED;
switch (++uni_digits) { switch (++uni_digits) {
case 1: case 1:
@ -1407,13 +1409,13 @@ long assemble_unicode(int kbinput)
retval = add_unicode_digit(kbinput, 0x1, &uni); retval = add_unicode_digit(kbinput, 0x1, &uni);
/* If also the sixth digit was a valid hexadecimal value, then /* If also the sixth digit was a valid hexadecimal value, then
* the Unicode sequence is complete, so return it. */ * the Unicode sequence is complete, so return it. */
if (retval == ERR) if (retval == PROCEED)
retval = uni; retval = uni;
break; break;
} }
/* Show feedback only when editing, not when at a prompt. */ /* Show feedback only when editing, not when at a prompt. */
if (retval == ERR && currmenu == MMAIN) { if (retval == PROCEED && currmenu == MMAIN) {
char partial[7] = "......"; char partial[7] = "......";
/* Construct the partial result, right-padding it with dots. */ /* Construct the partial result, right-padding it with dots. */
@ -1426,7 +1428,7 @@ long assemble_unicode(int kbinput)
} }
/* If we have an end result, reset the Unicode digit counter. */ /* If we have an end result, reset the Unicode digit counter. */
if (retval != ERR) if (retval != PROCEED)
uni_digits = 0; uni_digits = 0;
return retval; return retval;
@ -1491,7 +1493,7 @@ int *parse_verbatim_kbinput(WINDOW *win, size_t *count)
long unicode = assemble_unicode(*kbinput); long unicode = assemble_unicode(*kbinput);
/* If the first code isn't the digit 0 nor 1, put it back. */ /* If the first code isn't the digit 0 nor 1, put it back. */
if (unicode != ERR) if (unicode != PROCEED)
put_back(*kbinput); put_back(*kbinput);
/* Otherwise, continue reading in digits until we have a complete /* Otherwise, continue reading in digits until we have a complete
* Unicode value, and put back the corresponding byte(s). */ * Unicode value, and put back the corresponding byte(s). */
@ -1501,7 +1503,7 @@ int *parse_verbatim_kbinput(WINDOW *win, size_t *count)
reveal_cursor = FALSE; reveal_cursor = FALSE;
while (unicode == ERR) { while (unicode == PROCEED) {
free(kbinput); free(kbinput);
while ((kbinput = get_input(win, 1)) == NULL) while ((kbinput = get_input(win, 1)) == NULL)
; ;