tweaks: trim some excessive error checking and key-name frobbing
Also, it is clearer to say that "key name %s is invalid" than it is to say that some unspecified key name is too short.master
parent
998992ddcb
commit
077d307b30
24
src/rcfile.c
24
src/rcfile.c
|
@ -719,28 +719,12 @@ void parse_binding(char *ptr, bool dobind)
|
||||||
ptr = parse_next_word(ptr);
|
ptr = parse_next_word(ptr);
|
||||||
keycopy = copy_of(keyptr);
|
keycopy = copy_of(keyptr);
|
||||||
|
|
||||||
if (keycopy[1] == '\0') {
|
/* Force the first character of the key name to uppercase. */
|
||||||
jot_error(N_("Key name is too short"));
|
|
||||||
goto free_things;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Uppercase only the first two or three characters of the key name. */
|
|
||||||
keycopy[0] = toupper((unsigned char)keycopy[0]);
|
keycopy[0] = toupper((unsigned char)keycopy[0]);
|
||||||
keycopy[1] = toupper((unsigned char)keycopy[1]);
|
|
||||||
if (keycopy[0] == 'M' && keycopy[1] == '-') {
|
|
||||||
if (keycopy[2] == '\0') {
|
|
||||||
jot_error(N_("Key name is too short"));
|
|
||||||
goto free_things;
|
|
||||||
} else
|
|
||||||
keycopy[2] = toupper((unsigned char)keycopy[2]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Allow the codes for Insert and Delete to be rebound, but apart
|
/* Verify that the key name is not too short, to allow the next call. */
|
||||||
* from those two only Control, Meta and Function sequences. */
|
if (keycopy[1] == '\0' || (keycopy[0] == 'M' && keycopy[2] == '\0')) {
|
||||||
if (!strcasecmp(keycopy, "Ins") || !strcasecmp(keycopy, "Del"))
|
jot_error(N_("Key name %s is invalid"), keycopy);
|
||||||
keycopy[1] = tolower((unsigned char)keycopy[1]);
|
|
||||||
else if (keycopy[0] != '^' && keycopy[0] != 'M' && keycopy[0] != 'F') {
|
|
||||||
jot_error(N_("Key name must begin with \"^\", \"M\", or \"F\""));
|
|
||||||
goto free_things;
|
goto free_things;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue