tweaks: normalize some whitespace and adjust several comments

master
Benno Schulenberg 2016-08-01 14:05:42 +02:00
parent 90a90365a8
commit 5806bf5249
1 changed files with 37 additions and 56 deletions

View File

@ -260,9 +260,9 @@ void unget_kbinput(int kbinput, bool metakey)
} }
} }
/* Try to read input_len characters from the keystroke buffer. If the /* Try to read input_len codes from the keystroke buffer. If the
* keystroke buffer is empty and win isn't NULL, try to read in more * keystroke buffer is empty and win isn't NULL, try to read in more
* characters from win and add them to the keystroke buffer before doing * codes from win and add them to the keystroke buffer before doing
* anything else. If the keystroke buffer is (still) empty, return NULL. */ * anything else. If the keystroke buffer is (still) empty, return NULL. */
int *get_input(WINDOW *win, size_t input_len) int *get_input(WINDOW *win, size_t input_len)
{ {
@ -274,29 +274,21 @@ int *get_input(WINDOW *win, size_t input_len)
if (key_buffer_len == 0) if (key_buffer_len == 0)
return NULL; return NULL;
/* If input_len is greater than the length of the keystroke buffer, /* Limit the request to the number of available codes in the buffer. */
* only read the number of characters in the keystroke buffer. */
if (input_len > key_buffer_len) if (input_len > key_buffer_len)
input_len = key_buffer_len; input_len = key_buffer_len;
/* Subtract input_len from the length of the keystroke buffer, and /* Copy input_len codes from the head of the keystroke buffer. */
* allocate input so that it has enough room for input_len
* keystrokes. */
key_buffer_len -= input_len;
input = (int *)nmalloc(input_len * sizeof(int)); input = (int *)nmalloc(input_len * sizeof(int));
/* Copy input_len keystrokes from the beginning of the keystroke
* buffer into input. */
memcpy(input, key_buffer, input_len * sizeof(int)); memcpy(input, key_buffer, input_len * sizeof(int));
key_buffer_len -= input_len;
/* If the keystroke buffer is empty, mark it as such. */ /* If the keystroke buffer is now empty, mark it as such. */
if (key_buffer_len == 0) { if (key_buffer_len == 0) {
free(key_buffer); free(key_buffer);
key_buffer = NULL; key_buffer = NULL;
/* If the keystroke buffer isn't empty, move its beginning forward
* far enough so that the keystrokes in input are no longer at its
* beginning. */
} else { } else {
/* Trim from the buffer the codes that were copied. */
memmove(key_buffer, key_buffer + input_len, key_buffer_len * memmove(key_buffer, key_buffer + input_len, key_buffer_len *
sizeof(int)); sizeof(int));
key_buffer = (int *)nrealloc(key_buffer, key_buffer_len * key_buffer = (int *)nrealloc(key_buffer, key_buffer_len *
@ -362,11 +354,11 @@ int parse_kbinput(WINDOW *win)
return ERR; return ERR;
if (keycode == ESC_CODE) { if (keycode == ESC_CODE) {
/* Increment the escape counter. */ /* Increment the escape counter, but trim an overabundance. */
escapes++; escapes++;
/* If there are four consecutive escapes, discard three of them. */
if (escapes > 3) if (escapes > 3)
escapes = 1; escapes = 1;
/* Take note when an Esc arrived by itself. */
solitary = (escapes == 1 && key_buffer_len == 0); solitary = (escapes == 1 && key_buffer_len == 0);
return ERR; return ERR;
} }
@ -377,8 +369,6 @@ int parse_kbinput(WINDOW *win)
retval = keycode; retval = keycode;
break; break;
case 1: case 1:
/* Reset the escape counter. */
escapes = 0;
if ((keycode != 'O' && keycode != 'o' && keycode != '[') || if ((keycode != 'O' && keycode != 'o' && keycode != '[') ||
key_buffer_len == 0 || *key_buffer == ESC_CODE) { key_buffer_len == 0 || *key_buffer == ESC_CODE) {
/* One escape followed by a single non-escape: /* One escape followed by a single non-escape:
@ -390,6 +380,7 @@ int parse_kbinput(WINDOW *win)
/* One escape followed by a non-escape, and there /* One escape followed by a non-escape, and there
* are more codes waiting: escape sequence mode. */ * are more codes waiting: escape sequence mode. */
retval = parse_escape_sequence(win, keycode); retval = parse_escape_sequence(win, keycode);
escapes = 0;
break; break;
case 2: case 2:
if (double_esc) { if (double_esc) {
@ -427,36 +418,30 @@ int parse_kbinput(WINDOW *win)
byte_digits++; byte_digits++;
byte = get_byte_kbinput(keycode); byte = get_byte_kbinput(keycode);
/* If we've read in a complete byte sequence, /* If the decimal byte value is complete, convert it and
* reset the escape counter and the byte sequence * put the obtained byte(s) back into the input buffer. */
* counter, and put the obtained byte value back
* into the key buffer. */
if (byte != ERR) { if (byte != ERR) {
char *byte_mb; char *byte_mb;
int byte_mb_len, *seq, i; int byte_mb_len, *seq, i;
escapes = 0; /* Convert the decimal code to one or two bytes. */
byte_digits = 0; byte_mb = make_mbchar((long)byte, &byte_mb_len);
/* Put back the multibyte equivalent of seq = (int *)nmalloc(byte_mb_len * sizeof(int));
* the byte value. */
byte_mb = make_mbchar((long)byte,
&byte_mb_len);
seq = (int *)nmalloc(byte_mb_len *
sizeof(int));
for (i = 0; i < byte_mb_len; i++) for (i = 0; i < byte_mb_len; i++)
seq[i] = (unsigned char)byte_mb[i]; seq[i] = (unsigned char)byte_mb[i];
/* Insert the byte(s) into the input buffer. */
unget_input(seq, byte_mb_len); unget_input(seq, byte_mb_len);
free(byte_mb); free(byte_mb);
free(seq); free(seq);
byte_digits = 0;
escapes = 0;
} }
} else { } else {
/* Reset the escape counter. */
escapes = 0;
if (byte_digits == 0) if (byte_digits == 0)
/* Two escapes followed by a non-decimal /* Two escapes followed by a non-decimal
* digit (or a decimal digit that would * digit (or a decimal digit that would
@ -471,6 +456,7 @@ int parse_kbinput(WINDOW *win)
byte_digits = 0; byte_digits = 0;
retval = keycode; retval = keycode;
} }
escapes = 0;
} }
} else if (keycode == '[' && key_buffer_len > 0 && } else if (keycode == '[' && key_buffer_len > 0 &&
'A' <= *key_buffer && *key_buffer <= 'D') { 'A' <= *key_buffer && *key_buffer <= 'D') {
@ -479,14 +465,12 @@ int parse_kbinput(WINDOW *win)
} else { } else {
/* Two escapes followed by a non-escape, and there are more /* Two escapes followed by a non-escape, and there are more
* codes waiting: combined meta and escape sequence mode. */ * codes waiting: combined meta and escape sequence mode. */
escapes = 0;
meta_key = TRUE;
retval = parse_escape_sequence(win, keycode); retval = parse_escape_sequence(win, keycode);
meta_key = TRUE;
escapes = 0;
} }
break; break;
case 3: case 3:
/* Reset the escape counter. */
escapes = 0;
if (key_buffer_len == 0) if (key_buffer_len == 0)
/* Three escapes followed by a non-escape, and no /* Three escapes followed by a non-escape, and no
* other codes are waiting: normal input mode. */ * other codes are waiting: normal input mode. */
@ -498,6 +482,7 @@ int parse_kbinput(WINDOW *win)
* sequence, then the result as a control sequence. */ * sequence, then the result as a control sequence. */
retval = get_control_kbinput( retval = get_control_kbinput(
parse_escape_sequence(win, keycode)); parse_escape_sequence(win, keycode));
escapes = 0;
break; break;
} }
@ -1351,7 +1336,7 @@ int *parse_verbatim_kbinput(WINDOW *win, size_t *kbinput_len)
{ {
int *kbinput, *retval; int *kbinput, *retval;
/* Read in the first keystroke. */ /* Read in the first code. */
while ((kbinput = get_input(win, 1)) == NULL) while ((kbinput = get_input(win, 1)) == NULL)
; ;
@ -1366,18 +1351,14 @@ int *parse_verbatim_kbinput(WINDOW *win, size_t *kbinput_len)
#ifdef ENABLE_UTF8 #ifdef ENABLE_UTF8
if (using_utf8()) { if (using_utf8()) {
/* Check whether the first keystroke is a valid hexadecimal /* Check whether the first code is a valid starter digit: 0 or 1. */
* digit. */
long uni = get_unicode_kbinput(win, *kbinput); long uni = get_unicode_kbinput(win, *kbinput);
/* If the first keystroke isn't a valid hexadecimal digit, put /* If the first code isn't the digit 0 nor 1, put it back. */
* back the first keystroke. */
if (uni != ERR) if (uni != ERR)
unget_input(kbinput, 1); unget_input(kbinput, 1);
/* Otherwise, continue reading in digits until we have a complete
/* Otherwise, read in keystrokes until we have a complete * Unicode value, and put back the corresponding byte(s). */
* Unicode sequence, and put back the corresponding Unicode
* value. */
else { else {
char *uni_mb; char *uni_mb;
int uni_mb_len, *seq, i; int uni_mb_len, *seq, i;
@ -1389,8 +1370,7 @@ int *parse_verbatim_kbinput(WINDOW *win, size_t *kbinput_len)
uni = get_unicode_kbinput(win, *kbinput); uni = get_unicode_kbinput(win, *kbinput);
} }
/* Put back the multibyte equivalent of the Unicode /* Convert the Unicode value to a multibyte sequence. */
* value. */
uni_mb = make_mbchar(uni, &uni_mb_len); uni_mb = make_mbchar(uni, &uni_mb_len);
seq = (int *)nmalloc(uni_mb_len * sizeof(int)); seq = (int *)nmalloc(uni_mb_len * sizeof(int));
@ -1398,6 +1378,7 @@ int *parse_verbatim_kbinput(WINDOW *win, size_t *kbinput_len)
for (i = 0; i < uni_mb_len; i++) for (i = 0; i < uni_mb_len; i++)
seq[i] = (unsigned char)uni_mb[i]; seq[i] = (unsigned char)uni_mb[i];
/* Insert the multibyte sequence into the input buffer. */
unget_input(seq, uni_mb_len); unget_input(seq, uni_mb_len);
free(seq); free(seq);
@ -1406,7 +1387,7 @@ int *parse_verbatim_kbinput(WINDOW *win, size_t *kbinput_len)
} else } else
#endif /* ENABLE_UTF8 */ #endif /* ENABLE_UTF8 */
/* Put back the first keystroke. */ /* Put back the first code. */
unget_input(kbinput, 1); unget_input(kbinput, 1);
free(kbinput); free(kbinput);