mirror of
https://github.com/tmux/tmux.git
synced 2025-01-15 05:09:04 +00:00
Merge branch 'obsd-master'
This commit is contained in:
commit
98ef369b27
14
arguments.c
14
arguments.c
@ -37,6 +37,7 @@ TAILQ_HEAD(args_values, args_value);
|
|||||||
struct args_entry {
|
struct args_entry {
|
||||||
u_char flag;
|
u_char flag;
|
||||||
struct args_values values;
|
struct args_values values;
|
||||||
|
u_int count;
|
||||||
RB_ENTRY(args_entry) entry;
|
RB_ENTRY(args_entry) entry;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -173,6 +174,7 @@ args_print(struct args *args)
|
|||||||
size_t len;
|
size_t len;
|
||||||
char *buf;
|
char *buf;
|
||||||
int i;
|
int i;
|
||||||
|
u_int j;
|
||||||
struct args_entry *entry;
|
struct args_entry *entry;
|
||||||
struct args_value *value;
|
struct args_value *value;
|
||||||
|
|
||||||
@ -186,6 +188,7 @@ args_print(struct args *args)
|
|||||||
|
|
||||||
if (*buf == '\0')
|
if (*buf == '\0')
|
||||||
args_print_add(&buf, &len, "-");
|
args_print_add(&buf, &len, "-");
|
||||||
|
for (j = 0; j < entry->count; j++)
|
||||||
args_print_add(&buf, &len, "%c", entry->flag);
|
args_print_add(&buf, &len, "%c", entry->flag);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -243,7 +246,12 @@ args_escape(const char *s)
|
|||||||
int
|
int
|
||||||
args_has(struct args *args, u_char ch)
|
args_has(struct args *args, u_char ch)
|
||||||
{
|
{
|
||||||
return (args_find(args, ch) != NULL);
|
struct args_entry *entry;
|
||||||
|
|
||||||
|
entry = args_find(args, ch);
|
||||||
|
if (entry == NULL)
|
||||||
|
return (0);
|
||||||
|
return (entry->count);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Set argument value in the arguments tree. */
|
/* Set argument value in the arguments tree. */
|
||||||
@ -257,9 +265,11 @@ args_set(struct args *args, u_char ch, const char *s)
|
|||||||
if (entry == NULL) {
|
if (entry == NULL) {
|
||||||
entry = xcalloc(1, sizeof *entry);
|
entry = xcalloc(1, sizeof *entry);
|
||||||
entry->flag = ch;
|
entry->flag = ch;
|
||||||
|
entry->count = 1;
|
||||||
TAILQ_INIT(&entry->values);
|
TAILQ_INIT(&entry->values);
|
||||||
RB_INSERT(args_tree, &args->tree, entry);
|
RB_INSERT(args_tree, &args->tree, entry);
|
||||||
}
|
} else
|
||||||
|
entry->count++;
|
||||||
|
|
||||||
if (s != NULL) {
|
if (s != NULL) {
|
||||||
value = xcalloc(1, sizeof *value);
|
value = xcalloc(1, sizeof *value);
|
||||||
|
@ -33,8 +33,8 @@ const struct cmd_entry cmd_send_keys_entry = {
|
|||||||
.name = "send-keys",
|
.name = "send-keys",
|
||||||
.alias = "send",
|
.alias = "send",
|
||||||
|
|
||||||
.args = { "lXRMN:t:", 0, -1 },
|
.args = { "HlXRMN:t:", 0, -1 },
|
||||||
.usage = "[-lXRM] [-N repeat-count] " CMD_TARGET_PANE_USAGE " key ...",
|
.usage = "[-HlXRM] [-N repeat-count] " CMD_TARGET_PANE_USAGE " key ...",
|
||||||
|
|
||||||
.target = { 't', CMD_FIND_PANE, 0 },
|
.target = { 't', CMD_FIND_PANE, 0 },
|
||||||
|
|
||||||
@ -56,9 +56,9 @@ const struct cmd_entry cmd_send_prefix_entry = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static struct cmdq_item *
|
static struct cmdq_item *
|
||||||
cmd_send_keys_inject(struct client *c, struct cmd_find_state *fs,
|
cmd_send_keys_inject_key(struct client *c, struct cmdq_item *item, key_code key)
|
||||||
struct cmdq_item *item, key_code key)
|
|
||||||
{
|
{
|
||||||
|
struct cmd_find_state *fs = &item->target;
|
||||||
struct window_mode_entry *wme;
|
struct window_mode_entry *wme;
|
||||||
struct key_table *table;
|
struct key_table *table;
|
||||||
struct key_binding *bd;
|
struct key_binding *bd;
|
||||||
@ -81,6 +81,44 @@ cmd_send_keys_inject(struct client *c, struct cmd_find_state *fs,
|
|||||||
return (item);
|
return (item);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static struct cmdq_item *
|
||||||
|
cmd_send_keys_inject_string(struct client *c, struct cmdq_item *item,
|
||||||
|
struct args *args, int i)
|
||||||
|
{
|
||||||
|
const char *s = args->argv[i];
|
||||||
|
struct utf8_data *ud, *uc;
|
||||||
|
wchar_t wc;
|
||||||
|
key_code key;
|
||||||
|
char *endptr;
|
||||||
|
long n;
|
||||||
|
int literal;
|
||||||
|
|
||||||
|
if (args_has(args, 'H')) {
|
||||||
|
n = strtol(s, &endptr, 16);
|
||||||
|
if (*s =='\0' || n < 0 || n > 0xff || *endptr != '\0')
|
||||||
|
return (item);
|
||||||
|
return (cmd_send_keys_inject_key(c, item, KEYC_LITERAL|n));
|
||||||
|
}
|
||||||
|
|
||||||
|
literal = args_has(args, 'l');
|
||||||
|
if (!literal) {
|
||||||
|
key = key_string_lookup_string(s);
|
||||||
|
if (key != KEYC_NONE && key != KEYC_UNKNOWN)
|
||||||
|
return (cmd_send_keys_inject_key(c, item, key));
|
||||||
|
literal = 1;
|
||||||
|
}
|
||||||
|
if (literal) {
|
||||||
|
ud = utf8_fromcstr(s);
|
||||||
|
for (uc = ud; uc->size != 0; uc++) {
|
||||||
|
if (utf8_combine(uc, &wc) != UTF8_DONE)
|
||||||
|
continue;
|
||||||
|
item = cmd_send_keys_inject_key(c, item, wc);
|
||||||
|
}
|
||||||
|
free(ud);
|
||||||
|
}
|
||||||
|
return (item);
|
||||||
|
}
|
||||||
|
|
||||||
static enum cmd_retval
|
static enum cmd_retval
|
||||||
cmd_send_keys_exec(struct cmd *self, struct cmdq_item *item)
|
cmd_send_keys_exec(struct cmd *self, struct cmdq_item *item)
|
||||||
{
|
{
|
||||||
@ -90,11 +128,8 @@ cmd_send_keys_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
struct session *s = item->target.s;
|
struct session *s = item->target.s;
|
||||||
struct winlink *wl = item->target.wl;
|
struct winlink *wl = item->target.wl;
|
||||||
struct mouse_event *m = &item->shared->mouse;
|
struct mouse_event *m = &item->shared->mouse;
|
||||||
struct cmd_find_state *fs = &item->target;
|
|
||||||
struct window_mode_entry *wme = TAILQ_FIRST(&wp->modes);
|
struct window_mode_entry *wme = TAILQ_FIRST(&wp->modes);
|
||||||
struct utf8_data *ud, *uc;
|
int i;
|
||||||
wchar_t wc;
|
|
||||||
int i, literal;
|
|
||||||
key_code key;
|
key_code key;
|
||||||
u_int np = 1;
|
u_int np = 1;
|
||||||
char *cause = NULL;
|
char *cause = NULL;
|
||||||
@ -141,7 +176,7 @@ cmd_send_keys_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
key = options_get_number(s->options, "prefix2");
|
key = options_get_number(s->options, "prefix2");
|
||||||
else
|
else
|
||||||
key = options_get_number(s->options, "prefix");
|
key = options_get_number(s->options, "prefix");
|
||||||
cmd_send_keys_inject(c, fs, item, key);
|
cmd_send_keys_inject_key(c, item, key);
|
||||||
return (CMD_RETURN_NORMAL);
|
return (CMD_RETURN_NORMAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -151,28 +186,8 @@ cmd_send_keys_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (; np != 0; np--) {
|
for (; np != 0; np--) {
|
||||||
for (i = 0; i < args->argc; i++) {
|
for (i = 0; i < args->argc; i++)
|
||||||
literal = args_has(args, 'l');
|
item = cmd_send_keys_inject_string(c, item, args, i);
|
||||||
if (!literal) {
|
|
||||||
key = key_string_lookup_string(args->argv[i]);
|
|
||||||
if (key != KEYC_NONE && key != KEYC_UNKNOWN) {
|
|
||||||
item = cmd_send_keys_inject(c, fs, item,
|
|
||||||
key);
|
|
||||||
} else
|
|
||||||
literal = 1;
|
|
||||||
}
|
|
||||||
if (literal) {
|
|
||||||
ud = utf8_fromcstr(args->argv[i]);
|
|
||||||
for (uc = ud; uc->size != 0; uc++) {
|
|
||||||
if (utf8_combine(uc, &wc) != UTF8_DONE)
|
|
||||||
continue;
|
|
||||||
item = cmd_send_keys_inject(c, fs, item,
|
|
||||||
wc);
|
|
||||||
}
|
|
||||||
free(ud);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return (CMD_RETURN_NORMAL);
|
return (CMD_RETURN_NORMAL);
|
||||||
|
6
format.c
6
format.c
@ -2317,6 +2317,8 @@ format_defaults_pane(struct format_tree *ft, struct window_pane *wp)
|
|||||||
!!(wp->base.mode & MODE_KKEYPAD));
|
!!(wp->base.mode & MODE_KKEYPAD));
|
||||||
format_add(ft, "wrap_flag", "%d",
|
format_add(ft, "wrap_flag", "%d",
|
||||||
!!(wp->base.mode & MODE_WRAP));
|
!!(wp->base.mode & MODE_WRAP));
|
||||||
|
format_add(ft, "origin_flag", "%d",
|
||||||
|
!!(wp->base.mode & MODE_ORIGIN));
|
||||||
|
|
||||||
format_add(ft, "mouse_any_flag", "%d",
|
format_add(ft, "mouse_any_flag", "%d",
|
||||||
!!(wp->base.mode & ALL_MOUSE_MODES));
|
!!(wp->base.mode & ALL_MOUSE_MODES));
|
||||||
@ -2326,6 +2328,10 @@ format_defaults_pane(struct format_tree *ft, struct window_pane *wp)
|
|||||||
!!(wp->base.mode & MODE_MOUSE_BUTTON));
|
!!(wp->base.mode & MODE_MOUSE_BUTTON));
|
||||||
format_add(ft, "mouse_all_flag", "%d",
|
format_add(ft, "mouse_all_flag", "%d",
|
||||||
!!(wp->base.mode & MODE_MOUSE_ALL));
|
!!(wp->base.mode & MODE_MOUSE_ALL));
|
||||||
|
format_add(ft, "mouse_utf8_flag", "%d",
|
||||||
|
!!(wp->base.mode & MODE_MOUSE_UTF8));
|
||||||
|
format_add(ft, "mouse_sgr_flag", "%d",
|
||||||
|
!!(wp->base.mode & MODE_MOUSE_SGR));
|
||||||
|
|
||||||
format_add_cb(ft, "pane_tabs", format_cb_pane_tabs);
|
format_add_cb(ft, "pane_tabs", format_cb_pane_tabs);
|
||||||
}
|
}
|
||||||
|
@ -172,6 +172,13 @@ input_key(struct window_pane *wp, key_code key, struct mouse_event *m)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Literal keys go as themselves (can't be more than eight bits). */
|
||||||
|
if (key & KEYC_LITERAL) {
|
||||||
|
ud.data[0] = (u_char)key;
|
||||||
|
bufferevent_write(wp->event, &ud.data[0], 1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If this is a normal 7-bit key, just send it, with a leading escape
|
* If this is a normal 7-bit key, just send it, with a leading escape
|
||||||
* if necessary. If it is a UTF-8 key, split it and send it.
|
* if necessary. If it is a UTF-8 key, split it and send it.
|
||||||
|
@ -284,6 +284,12 @@ key_string_lookup_key(key_code key)
|
|||||||
return (out);
|
return (out);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Literal keys are themselves. */
|
||||||
|
if (key & KEYC_LITERAL) {
|
||||||
|
snprintf(out, sizeof out, "%c", (int)(key & 0xff));
|
||||||
|
return (out);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Special case: display C-@ as C-Space. Could do this below in
|
* Special case: display C-@ as C-Space. Could do this below in
|
||||||
* the (key >= 0 && key <= 32), but this way we let it be found
|
* the (key >= 0 && key <= 32), but this way we let it be found
|
||||||
|
19
tmux.1
19
tmux.1
@ -2627,7 +2627,7 @@ With
|
|||||||
only
|
only
|
||||||
.Ar key-table .
|
.Ar key-table .
|
||||||
.It Xo Ic send-keys
|
.It Xo Ic send-keys
|
||||||
.Op Fl lMRX
|
.Op Fl HlMRX
|
||||||
.Op Fl N Ar repeat-count
|
.Op Fl N Ar repeat-count
|
||||||
.Op Fl t Ar target-pane
|
.Op Fl t Ar target-pane
|
||||||
.Ar key Ar ...
|
.Ar key Ar ...
|
||||||
@ -2642,10 +2642,16 @@ or
|
|||||||
.Ql NPage )
|
.Ql NPage )
|
||||||
to send; if the string is not recognised as a key, it is sent as a series of
|
to send; if the string is not recognised as a key, it is sent as a series of
|
||||||
characters.
|
characters.
|
||||||
|
All arguments are sent sequentially from first to last.
|
||||||
|
.Pp
|
||||||
The
|
The
|
||||||
.Fl l
|
.Fl l
|
||||||
flag disables key name lookup and sends the keys literally.
|
flag disables key name lookup and processes the keys as literal UTF-8
|
||||||
All arguments are sent sequentially from first to last.
|
characters.
|
||||||
|
The
|
||||||
|
.Fl H
|
||||||
|
flag expects each key to be a hexadecimal number for an ASCII character.
|
||||||
|
.Pp
|
||||||
The
|
The
|
||||||
.Fl R
|
.Fl R
|
||||||
flag causes the terminal state to be reset.
|
flag causes the terminal state to be reset.
|
||||||
@ -4185,11 +4191,14 @@ The following variables are available, where appropriate:
|
|||||||
.It Li "mouse_all_flag" Ta "" Ta "Pane mouse all flag"
|
.It Li "mouse_all_flag" Ta "" Ta "Pane mouse all flag"
|
||||||
.It Li "mouse_any_flag" Ta "" Ta "Pane mouse any flag"
|
.It Li "mouse_any_flag" Ta "" Ta "Pane mouse any flag"
|
||||||
.It Li "mouse_button_flag" Ta "" Ta "Pane mouse button flag"
|
.It Li "mouse_button_flag" Ta "" Ta "Pane mouse button flag"
|
||||||
|
.It Li "mouse_line" Ta "" Ta "Line under mouse, if any"
|
||||||
|
.It Li "mouse_sgr_flag" Ta "" Ta "Pane mouse SGR flag"
|
||||||
.It Li "mouse_standard_flag" Ta "" Ta "Pane mouse standard flag"
|
.It Li "mouse_standard_flag" Ta "" Ta "Pane mouse standard flag"
|
||||||
|
.It Li "mouse_utf8_flag" Ta "" Ta "Pane mouse UTF-8 flag"
|
||||||
|
.It Li "mouse_word" Ta "" Ta "Word under mouse, if any"
|
||||||
.It Li "mouse_x" Ta "" Ta "Mouse X position, if any"
|
.It Li "mouse_x" Ta "" Ta "Mouse X position, if any"
|
||||||
.It Li "mouse_y" Ta "" Ta "Mouse Y position, if any"
|
.It Li "mouse_y" Ta "" Ta "Mouse Y position, if any"
|
||||||
.It Li "mouse_word" Ta "" Ta "Word under mouse, if any"
|
.It Li "origin_flag" Ta "" Ta "Pane origin flag"
|
||||||
.It Li "mouse_line" Ta "" Ta "Line under mouse, if any"
|
|
||||||
.It Li "pane_active" Ta "" Ta "1 if active pane"
|
.It Li "pane_active" Ta "" Ta "1 if active pane"
|
||||||
.It Li "pane_at_bottom" Ta "" Ta "1 if pane is at the bottom of window"
|
.It Li "pane_at_bottom" Ta "" Ta "1 if pane is at the bottom of window"
|
||||||
.It Li "pane_at_left" Ta "" Ta "1 if pane is at the left of window"
|
.It Li "pane_at_left" Ta "" Ta "1 if pane is at the left of window"
|
||||||
|
3
tmux.h
3
tmux.h
@ -113,9 +113,10 @@ struct winlink;
|
|||||||
#define KEYC_CTRL 0x400000000000ULL
|
#define KEYC_CTRL 0x400000000000ULL
|
||||||
#define KEYC_SHIFT 0x800000000000ULL
|
#define KEYC_SHIFT 0x800000000000ULL
|
||||||
#define KEYC_XTERM 0x1000000000000ULL
|
#define KEYC_XTERM 0x1000000000000ULL
|
||||||
|
#define KEYC_LITERAL 0x2000000000000ULL
|
||||||
|
|
||||||
/* Mask to obtain key w/o modifiers. */
|
/* Mask to obtain key w/o modifiers. */
|
||||||
#define KEYC_MASK_MOD (KEYC_ESCAPE|KEYC_CTRL|KEYC_SHIFT|KEYC_XTERM)
|
#define KEYC_MASK_MOD (KEYC_ESCAPE|KEYC_CTRL|KEYC_SHIFT|KEYC_XTERM|KEYC_LITERAL)
|
||||||
#define KEYC_MASK_KEY (~KEYC_MASK_MOD)
|
#define KEYC_MASK_KEY (~KEYC_MASK_MOD)
|
||||||
|
|
||||||
/* Is this a mouse key? */
|
/* Is this a mouse key? */
|
||||||
|
Loading…
Reference in New Issue
Block a user