mirror of
https://github.com/tmux/tmux.git
synced 2024-12-04 19:58:48 +00:00
Merge branch 'obsd-master'
This commit is contained in:
commit
d02254f754
1
tmux.h
1
tmux.h
@ -3316,6 +3316,7 @@ void session_renumber_windows(struct session *);
|
||||
|
||||
/* utf8.c */
|
||||
enum utf8_state utf8_towc (const struct utf8_data *, wchar_t *);
|
||||
enum utf8_state utf8_fromwc(wchar_t wc, struct utf8_data *);
|
||||
int utf8_in_table(wchar_t, const wchar_t *, u_int);
|
||||
utf8_char utf8_build_one(u_char);
|
||||
enum utf8_state utf8_from_data(const struct utf8_data *, utf8_char *);
|
||||
|
11
tty-keys.c
11
tty-keys.c
@ -911,6 +911,8 @@ tty_keys_extended_key(struct tty *tty, const char *buf, size_t len,
|
||||
cc_t bspace;
|
||||
key_code nkey;
|
||||
key_code onlykey;
|
||||
struct utf8_data ud;
|
||||
utf8_char uc;
|
||||
|
||||
*size = 0;
|
||||
|
||||
@ -960,6 +962,15 @@ tty_keys_extended_key(struct tty *tty, const char *buf, size_t len,
|
||||
else
|
||||
nkey = number;
|
||||
|
||||
/* Convert UTF-32 codepoint into internal representation. */
|
||||
if (nkey & ~0x7f) {
|
||||
if (utf8_fromwc(nkey, &ud) == UTF8_DONE &&
|
||||
utf8_from_data(&ud, &uc) == UTF8_DONE)
|
||||
nkey = uc;
|
||||
else
|
||||
return (-1);
|
||||
}
|
||||
|
||||
/* Update the modifiers. */
|
||||
if (modifiers > 0) {
|
||||
modifiers--;
|
||||
|
22
utf8.c
22
utf8.c
@ -449,6 +449,28 @@ utf8_towc(const struct utf8_data *ud, wchar_t *wc)
|
||||
return (UTF8_DONE);
|
||||
}
|
||||
|
||||
/* Convert wide character to UTF-8 character. */
|
||||
enum utf8_state
|
||||
utf8_fromwc(wchar_t wc, struct utf8_data *ud)
|
||||
{
|
||||
int size, width;
|
||||
|
||||
size = wctomb(ud->data, wc);
|
||||
if (size < 0) {
|
||||
log_debug("UTF-8 %d, wctomb() %d", wc, errno);
|
||||
wctomb(NULL, 0);
|
||||
return (UTF8_ERROR);
|
||||
}
|
||||
if (size == 0)
|
||||
return (UTF8_ERROR);
|
||||
ud->size = ud->have = size;
|
||||
if (utf8_width(ud, &width) == UTF8_DONE) {
|
||||
ud->width = width;
|
||||
return (UTF8_DONE);
|
||||
}
|
||||
return (UTF8_ERROR);
|
||||
}
|
||||
|
||||
/*
|
||||
* Open UTF-8 sequence.
|
||||
*
|
||||
|
Loading…
Reference in New Issue
Block a user