diff options
author | Nicholas Marriott <nicm@openbsd.org> | 2009-08-25 12:18:51 +0000 |
---|---|---|
committer | Nicholas Marriott <nicm@openbsd.org> | 2009-08-25 12:18:51 +0000 |
commit | 7b847ced4af09b7da66a7b0b59fbab68f07bcb50 (patch) | |
tree | 4f616b2184ffe0c246920882ab093fc44a71af94 /cmd.c | |
parent | 4f1d81c4ce89440bd2f155cbb8002b622f13ce0b (diff) | |
download | rtmux-7b847ced4af09b7da66a7b0b59fbab68f07bcb50.tar.gz rtmux-7b847ced4af09b7da66a7b0b59fbab68f07bcb50.tar.bz2 rtmux-7b847ced4af09b7da66a7b0b59fbab68f07bcb50.zip |
Add a choose-client command and extend choose-{session,window} to accept a
template. After a choice is made, %% (or %1) in the template is replaced by the
name of the session, window or client suitable for -t and the result executed
as a command. So, for example, "choose-window "killw -t '%%'"" will kill the
selected window.
The defaults if no template is given are (as now) select-window for
choose-window, switch-client for choose-session, and detach-client for
choose-client (now bound to D).
Diffstat (limited to 'cmd.c')
-rw-r--r-- | cmd.c | 42 |
1 files changed, 42 insertions, 0 deletions
@@ -31,6 +31,7 @@ const struct cmd_entry *cmd_table[] = { &cmd_attach_session_entry, &cmd_bind_key_entry, &cmd_break_pane_entry, + &cmd_choose_client_entry, &cmd_choose_session_entry, &cmd_choose_window_entry, &cmd_clear_history_entry, @@ -858,3 +859,44 @@ error: xfree(winptr); return (NULL); } + +/* Replace the first %% or %idx in template by s. */ +char * +cmd_template_replace(char *template, const char *s, int idx) +{ + char ch; + char *buf, *ptr; + int replaced; + size_t len; + + if (strstr(template, "%") == NULL) + return (xstrdup(template)); + + buf = xmalloc(1); + *buf = '\0'; + len = 0; + replaced = 0; + + ptr = template; + while (*ptr != '\0') { + switch (ch = *ptr++) { + case '%': + if (*ptr < '1' || *ptr > '9' || *ptr - '0' != idx) { + if (*ptr != '%' || replaced) + break; + replaced = 1; + } + ptr++; + + len += strlen(s); + buf = xrealloc(buf, 1, len + 1); + strlcat(buf, s, len + 1); + continue; + } + buf = xrealloc(buf, 1, len + 2); + buf[len++] = ch; + buf[len] = '\0'; + } + + return (buf); +} |