diff options
author | nicm <nicm> | 2016-12-08 22:15:37 +0000 |
---|---|---|
committer | nicm <nicm> | 2016-12-08 22:15:37 +0000 |
commit | 2a7b4bb01710eab0b7819f3b80edaea636ada66f (patch) | |
tree | 8567aca93336bfab545407071c711b5444604d49 /cmd-send-keys.c | |
parent | 5819d2a9d75511c4ba7fd7adbeec6b778647e0d7 (diff) | |
download | rtmux-2a7b4bb01710eab0b7819f3b80edaea636ada66f.tar.gz rtmux-2a7b4bb01710eab0b7819f3b80edaea636ada66f.tar.bz2 rtmux-2a7b4bb01710eab0b7819f3b80edaea636ada66f.zip |
Fix send-keys with UTF-8.
Diffstat (limited to 'cmd-send-keys.c')
-rw-r--r-- | cmd-send-keys.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/cmd-send-keys.c b/cmd-send-keys.c index dff4f51e..3d63440e 100644 --- a/cmd-send-keys.c +++ b/cmd-send-keys.c @@ -63,7 +63,8 @@ cmd_send_keys_exec(struct cmd *self, struct cmdq_item *item) struct window_pane *wp = item->state.tflag.wp; struct session *s = item->state.tflag.s; struct mouse_event *m = &item->mouse; - const u_char *keystr; + struct utf8_data *ud, *uc; + wchar_t wc; int i, literal; key_code key; u_int np = 1; @@ -124,8 +125,12 @@ cmd_send_keys_exec(struct cmd *self, struct cmdq_item *item) literal = 1; } if (literal) { - for (keystr = args->argv[i]; *keystr != '\0'; keystr++) - window_pane_key(wp, NULL, s, *keystr, NULL); + ud = utf8_fromcstr(args->argv[i]); + for (uc = ud; uc->size != 0; uc++) { + if (utf8_combine(uc, &wc) == UTF8_DONE) + window_pane_key(wp, NULL, s, wc, NULL); + } + free(ud); } } |