summaryrefslogtreecommitdiffstats
path: root/cmd-send-keys.c
diff options
context:
space:
mode:
authornicm <nicm>2016-12-08 22:15:37 +0000
committernicm <nicm>2016-12-08 22:15:37 +0000
commit2a7b4bb01710eab0b7819f3b80edaea636ada66f (patch)
tree8567aca93336bfab545407071c711b5444604d49 /cmd-send-keys.c
parent5819d2a9d75511c4ba7fd7adbeec6b778647e0d7 (diff)
Fix send-keys with UTF-8.
Diffstat (limited to 'cmd-send-keys.c')
-rw-r--r--cmd-send-keys.c11
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);
}
}