tweaks: use a better symbol than 'ERR' to signify a valid hex digit
parent
b3d6c27502
commit
d3a8488b0e
20
src/winio.c
20
src/winio.c
|
@ -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)
|
||||||
;
|
;
|
||||||
|
|
Loading…
Reference in New Issue