Added TERMKEY_FORMAT_WRAPBRACKET
This commit is contained in:
parent
5b24e42d90
commit
0b8680daa4
8
demo.c
8
demo.c
|
@ -10,14 +10,10 @@ int main(int argc, char *argv[]) {
|
||||||
termkey_key key;
|
termkey_key key;
|
||||||
|
|
||||||
while((ret = termkey_waitkey(tk, &key)) != TERMKEY_RES_EOF) {
|
while((ret = termkey_waitkey(tk, &key)) != TERMKEY_RES_EOF) {
|
||||||
if(key.type == TERMKEY_TYPE_UNICODE && !key.modifiers)
|
|
||||||
printf("%s\n", key.utf8);
|
|
||||||
else {
|
|
||||||
termkey_snprint_key(tk, buffer, sizeof buffer, &key, 0);
|
termkey_snprint_key(tk, buffer, sizeof buffer, &key, 0);
|
||||||
printf("<%s> or ", buffer);
|
printf("%s or ", buffer);
|
||||||
termkey_snprint_key(tk, buffer, sizeof buffer, &key, ~0);
|
termkey_snprint_key(tk, buffer, sizeof buffer, &key, ~0);
|
||||||
printf("<%s>\n", buffer);
|
printf("%s\n", buffer);
|
||||||
}
|
|
||||||
|
|
||||||
if(key.type == TERMKEY_TYPE_UNICODE &&
|
if(key.type == TERMKEY_TYPE_UNICODE &&
|
||||||
key.modifiers & TERMKEY_KEYMOD_CTRL &&
|
key.modifiers & TERMKEY_KEYMOD_CTRL &&
|
||||||
|
|
15
termkey.c
15
termkey.c
|
@ -863,6 +863,15 @@ size_t termkey_snprint_key(termkey_t *tk, char *buffer, size_t len, termkey_key
|
||||||
|
|
||||||
int longmod = format & TERMKEY_FORMAT_LONGMOD;
|
int longmod = format & TERMKEY_FORMAT_LONGMOD;
|
||||||
|
|
||||||
|
int wrapbracket = (format & TERMKEY_FORMAT_WRAPBRACKET) &&
|
||||||
|
(key->type != TERMKEY_TYPE_UNICODE || key->modifiers != 0);
|
||||||
|
|
||||||
|
if(wrapbracket) {
|
||||||
|
l = snprintf(buffer + pos, len - pos, "<");
|
||||||
|
if(l <= 0) return pos;
|
||||||
|
pos += l;
|
||||||
|
}
|
||||||
|
|
||||||
if(format & TERMKEY_FORMAT_CARETCTRL) {
|
if(format & TERMKEY_FORMAT_CARETCTRL) {
|
||||||
if(key->type == TERMKEY_TYPE_UNICODE &&
|
if(key->type == TERMKEY_TYPE_UNICODE &&
|
||||||
key->modifiers == TERMKEY_KEYMOD_CTRL &&
|
key->modifiers == TERMKEY_KEYMOD_CTRL &&
|
||||||
|
@ -913,5 +922,11 @@ do_codepoint:
|
||||||
if(l <= 0) return pos;
|
if(l <= 0) return pos;
|
||||||
pos += l;
|
pos += l;
|
||||||
|
|
||||||
|
if(wrapbracket) {
|
||||||
|
l = snprintf(buffer + pos, len - pos, ">");
|
||||||
|
if(l <= 0) return pos;
|
||||||
|
pos += l;
|
||||||
|
}
|
||||||
|
|
||||||
return pos;
|
return pos;
|
||||||
}
|
}
|
||||||
|
|
|
@ -136,6 +136,7 @@ typedef enum {
|
||||||
TERMKEY_FORMAT_LONGMOD = 1,
|
TERMKEY_FORMAT_LONGMOD = 1,
|
||||||
TERMKEY_FORMAT_CARETCTRL = 2,
|
TERMKEY_FORMAT_CARETCTRL = 2,
|
||||||
TERMKEY_FORMAT_ALTISMETA = 4,
|
TERMKEY_FORMAT_ALTISMETA = 4,
|
||||||
|
TERMKEY_FORMAT_WRAPBRACKET = 8,
|
||||||
} termkey_format;
|
} termkey_format;
|
||||||
|
|
||||||
size_t termkey_snprint_key(termkey_t *tk, char *buffer, size_t len, termkey_key *key, termkey_format format);
|
size_t termkey_snprint_key(termkey_t *tk, char *buffer, size_t len, termkey_key *key, termkey_format format);
|
||||||
|
|
Loading…
Reference in New Issue