mirror of
https://github.com/tmate-io/tmate-ssh-server.git
synced 2020-11-18 19:53:51 -08:00
Merge branch 'obsd-master'
Conflicts: tmux.h
This commit is contained in:
commit
504b97b6a4
2
cfg.c
2
cfg.c
@ -120,7 +120,7 @@ cfg_add_cause(const char *fmt, ...)
|
|||||||
|
|
||||||
va_start(ap, fmt);
|
va_start(ap, fmt);
|
||||||
xvasprintf(&msg, fmt, ap);
|
xvasprintf(&msg, fmt, ap);
|
||||||
va_end (ap);
|
va_end(ap);
|
||||||
|
|
||||||
cfg_ncauses++;
|
cfg_ncauses++;
|
||||||
cfg_causes = xreallocarray(cfg_causes, cfg_ncauses, sizeof *cfg_causes);
|
cfg_causes = xreallocarray(cfg_causes, cfg_ncauses, sizeof *cfg_causes);
|
||||||
|
@ -57,15 +57,17 @@ char *
|
|||||||
cmd_capture_pane_pending(struct args *args, struct window_pane *wp,
|
cmd_capture_pane_pending(struct args *args, struct window_pane *wp,
|
||||||
size_t *len)
|
size_t *len)
|
||||||
{
|
{
|
||||||
char *buf, *line, tmp[5];
|
struct evbuffer *pending;
|
||||||
size_t linelen;
|
char *buf, *line, tmp[5];
|
||||||
u_int i;
|
size_t linelen;
|
||||||
|
u_int i;
|
||||||
|
|
||||||
if (wp->ictx.since_ground == NULL)
|
pending = input_pending(wp);
|
||||||
|
if (pending == NULL)
|
||||||
return (xstrdup(""));
|
return (xstrdup(""));
|
||||||
|
|
||||||
line = EVBUFFER_DATA(wp->ictx.since_ground);
|
line = EVBUFFER_DATA(pending);
|
||||||
linelen = EVBUFFER_LENGTH(wp->ictx.since_ground);
|
linelen = EVBUFFER_LENGTH(pending);
|
||||||
|
|
||||||
buf = xstrdup("");
|
buf = xstrdup("");
|
||||||
if (args_has(args, 'C')) {
|
if (args_has(args, 'C')) {
|
||||||
|
@ -59,11 +59,12 @@ struct cmd_find_window_data {
|
|||||||
struct winlink *wl;
|
struct winlink *wl;
|
||||||
char *list_ctx;
|
char *list_ctx;
|
||||||
u_int pane_id;
|
u_int pane_id;
|
||||||
|
TAILQ_ENTRY(cmd_find_window_data) entry;
|
||||||
};
|
};
|
||||||
ARRAY_DECL(cmd_find_window_data_list, struct cmd_find_window_data);
|
TAILQ_HEAD(cmd_find_window_list, cmd_find_window_data);
|
||||||
|
|
||||||
u_int cmd_find_window_match_flags(struct args *);
|
u_int cmd_find_window_match_flags(struct args *);
|
||||||
void cmd_find_window_match(struct cmd_find_window_data_list *, int,
|
void cmd_find_window_match(struct cmd_find_window_list *, int,
|
||||||
struct winlink *, const char *, const char *);
|
struct winlink *, const char *, const char *);
|
||||||
|
|
||||||
u_int
|
u_int
|
||||||
@ -87,16 +88,16 @@ cmd_find_window_match_flags(struct args *args)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
cmd_find_window_match(struct cmd_find_window_data_list *find_list,
|
cmd_find_window_match(struct cmd_find_window_list *find_list,
|
||||||
int match_flags, struct winlink *wl, const char *str,
|
int match_flags, struct winlink *wl, const char *str,
|
||||||
const char *searchstr)
|
const char *searchstr)
|
||||||
{
|
{
|
||||||
struct cmd_find_window_data find_data;
|
struct cmd_find_window_data *find_data;
|
||||||
struct window_pane *wp;
|
struct window_pane *wp;
|
||||||
u_int i, line;
|
u_int i, line;
|
||||||
char *sres;
|
char *sres;
|
||||||
|
|
||||||
memset(&find_data, 0, sizeof find_data);
|
find_data = xcalloc(1, sizeof *find_data);
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
TAILQ_FOREACH(wp, &wl->window->panes, entry) {
|
TAILQ_FOREACH(wp, &wl->window->panes, entry) {
|
||||||
@ -104,30 +105,32 @@ cmd_find_window_match(struct cmd_find_window_data_list *find_list,
|
|||||||
|
|
||||||
if ((match_flags & CMD_FIND_WINDOW_BY_NAME) &&
|
if ((match_flags & CMD_FIND_WINDOW_BY_NAME) &&
|
||||||
fnmatch(searchstr, wl->window->name, 0) == 0) {
|
fnmatch(searchstr, wl->window->name, 0) == 0) {
|
||||||
find_data.list_ctx = xstrdup("");
|
find_data->list_ctx = xstrdup("");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((match_flags & CMD_FIND_WINDOW_BY_TITLE) &&
|
if ((match_flags & CMD_FIND_WINDOW_BY_TITLE) &&
|
||||||
fnmatch(searchstr, wp->base.title, 0) == 0) {
|
fnmatch(searchstr, wp->base.title, 0) == 0) {
|
||||||
xasprintf(&find_data.list_ctx,
|
xasprintf(&find_data->list_ctx,
|
||||||
"pane %u title: \"%s\"", i - 1, wp->base.title);
|
"pane %u title: \"%s\"", i - 1, wp->base.title);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (match_flags & CMD_FIND_WINDOW_BY_CONTENT &&
|
if (match_flags & CMD_FIND_WINDOW_BY_CONTENT &&
|
||||||
(sres = window_pane_search(wp, str, &line)) != NULL) {
|
(sres = window_pane_search(wp, str, &line)) != NULL) {
|
||||||
xasprintf(&find_data.list_ctx,
|
xasprintf(&find_data->list_ctx,
|
||||||
"pane %u line %u: \"%s\"", i - 1, line + 1, sres);
|
"pane %u line %u: \"%s\"", i - 1, line + 1, sres);
|
||||||
free(sres);
|
free(sres);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (find_data.list_ctx != NULL) {
|
|
||||||
find_data.wl = wl;
|
if (find_data->list_ctx != NULL) {
|
||||||
find_data.pane_id = i - 1;
|
find_data->wl = wl;
|
||||||
ARRAY_ADD(find_list, find_data);
|
find_data->pane_id = i - 1;
|
||||||
}
|
TAILQ_INSERT_TAIL(find_list, find_data, entry);
|
||||||
|
} else
|
||||||
|
free(find_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
enum cmd_retval
|
enum cmd_retval
|
||||||
@ -138,7 +141,9 @@ cmd_find_window_exec(struct cmd *self, struct cmd_q *cmdq)
|
|||||||
struct window_choose_data *cdata;
|
struct window_choose_data *cdata;
|
||||||
struct session *s;
|
struct session *s;
|
||||||
struct winlink *wl, *wm;
|
struct winlink *wl, *wm;
|
||||||
struct cmd_find_window_data_list find_list;
|
struct cmd_find_window_list find_list;
|
||||||
|
struct cmd_find_window_data *find_data;
|
||||||
|
struct cmd_find_window_data *find_data1;
|
||||||
char *str, *searchstr;
|
char *str, *searchstr;
|
||||||
const char *template;
|
const char *template;
|
||||||
u_int i, match_flags;
|
u_int i, match_flags;
|
||||||
@ -158,21 +163,20 @@ cmd_find_window_exec(struct cmd *self, struct cmd_q *cmdq)
|
|||||||
match_flags = cmd_find_window_match_flags(args);
|
match_flags = cmd_find_window_match_flags(args);
|
||||||
str = args->argv[0];
|
str = args->argv[0];
|
||||||
|
|
||||||
ARRAY_INIT(&find_list);
|
TAILQ_INIT(&find_list);
|
||||||
|
|
||||||
xasprintf(&searchstr, "*%s*", str);
|
xasprintf(&searchstr, "*%s*", str);
|
||||||
RB_FOREACH(wm, winlinks, &s->windows)
|
RB_FOREACH(wm, winlinks, &s->windows)
|
||||||
cmd_find_window_match(&find_list, match_flags, wm, str, searchstr);
|
cmd_find_window_match(&find_list, match_flags, wm, str, searchstr);
|
||||||
free(searchstr);
|
free(searchstr);
|
||||||
|
|
||||||
if (ARRAY_LENGTH(&find_list) == 0) {
|
if (TAILQ_EMPTY(&find_list)) {
|
||||||
cmdq_error(cmdq, "no windows matching: %s", str);
|
cmdq_error(cmdq, "no windows matching: %s", str);
|
||||||
ARRAY_FREE(&find_list);
|
|
||||||
return (CMD_RETURN_ERROR);
|
return (CMD_RETURN_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ARRAY_LENGTH(&find_list) == 1) {
|
if (TAILQ_NEXT(TAILQ_FIRST(&find_list), entry) == NULL) {
|
||||||
if (session_select(s, ARRAY_FIRST(&find_list).wl->idx) == 0)
|
if (session_select(s, TAILQ_FIRST(&find_list)->wl->idx) == 0)
|
||||||
server_redraw_session(s);
|
server_redraw_session(s);
|
||||||
recalculate_sizes();
|
recalculate_sizes();
|
||||||
goto out;
|
goto out;
|
||||||
@ -181,30 +185,33 @@ cmd_find_window_exec(struct cmd *self, struct cmd_q *cmdq)
|
|||||||
if (window_pane_set_mode(wl->window->active, &window_choose_mode) != 0)
|
if (window_pane_set_mode(wl->window->active, &window_choose_mode) != 0)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_LENGTH(&find_list); i++) {
|
i = 0;
|
||||||
wm = ARRAY_ITEM(&find_list, i).wl;
|
TAILQ_FOREACH(find_data, &find_list, entry) {
|
||||||
|
|
||||||
cdata = window_choose_data_create(TREE_OTHER, c, c->session);
|
cdata = window_choose_data_create(TREE_OTHER, c, c->session);
|
||||||
cdata->idx = wm->idx;
|
cdata->idx = find_data->wl->idx;
|
||||||
cdata->wl = wm;
|
cdata->wl = find_data->wl;
|
||||||
|
|
||||||
cdata->ft_template = xstrdup(template);
|
cdata->ft_template = xstrdup(template);
|
||||||
cdata->pane_id = ARRAY_ITEM(&find_list, i).pane_id;
|
cdata->pane_id = find_data->pane_id;
|
||||||
|
|
||||||
format_add(cdata->ft, "line", "%u", i);
|
format_add(cdata->ft, "line", "%u", i);
|
||||||
format_add(cdata->ft, "window_find_matches", "%s",
|
format_add(cdata->ft, "window_find_matches", "%s",
|
||||||
ARRAY_ITEM(&find_list, i).list_ctx);
|
find_data->list_ctx);
|
||||||
format_defaults(cdata->ft, NULL, s, wm, NULL);
|
format_defaults(cdata->ft, NULL, s, find_data->wl, NULL);
|
||||||
|
|
||||||
window_choose_add(wl->window->active, cdata);
|
window_choose_add(wl->window->active, cdata);
|
||||||
|
|
||||||
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
window_choose_ready(wl->window->active, 0, cmd_find_window_callback);
|
window_choose_ready(wl->window->active, 0, cmd_find_window_callback);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
for (i = 0; i < ARRAY_LENGTH(&find_list); i++)
|
TAILQ_FOREACH_SAFE(find_data, &find_list, entry, find_data1) {
|
||||||
free(ARRAY_ITEM(&find_list, i).list_ctx);
|
free(find_data->list_ctx);
|
||||||
ARRAY_FREE(&find_list);
|
TAILQ_REMOVE(&find_list, find_data, entry);
|
||||||
|
free(find_data);
|
||||||
|
}
|
||||||
return (CMD_RETURN_NORMAL);
|
return (CMD_RETURN_NORMAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -192,7 +192,7 @@ cmd_find_best_session_with_window(struct cmd_find_state *fs)
|
|||||||
RB_FOREACH(s, sessions, &sessions) {
|
RB_FOREACH(s, sessions, &sessions) {
|
||||||
if (!session_has(s, fs->w))
|
if (!session_has(s, fs->w))
|
||||||
continue;
|
continue;
|
||||||
slist = xreallocarray (slist, ssize + 1, sizeof *slist);
|
slist = xreallocarray(slist, ssize + 1, sizeof *slist);
|
||||||
slist[ssize++] = s;
|
slist[ssize++] = s;
|
||||||
}
|
}
|
||||||
if (ssize == 0)
|
if (ssize == 0)
|
||||||
@ -200,7 +200,7 @@ cmd_find_best_session_with_window(struct cmd_find_state *fs)
|
|||||||
fs->s = cmd_find_best_session(slist, ssize, fs->flags);
|
fs->s = cmd_find_best_session(slist, ssize, fs->flags);
|
||||||
if (fs->s == NULL)
|
if (fs->s == NULL)
|
||||||
goto fail;
|
goto fail;
|
||||||
free (slist);
|
free(slist);
|
||||||
return (cmd_find_best_winlink_with_window(fs));
|
return (cmd_find_best_winlink_with_window(fs));
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
@ -328,7 +328,7 @@ cmd_find_current_client(struct cmd_q *cmdq)
|
|||||||
TAILQ_FOREACH(c, &clients, entry) {
|
TAILQ_FOREACH(c, &clients, entry) {
|
||||||
if (c->session != s)
|
if (c->session != s)
|
||||||
continue;
|
continue;
|
||||||
clist = xreallocarray (clist, csize + 1, sizeof *clist);
|
clist = xreallocarray(clist, csize + 1, sizeof *clist);
|
||||||
clist[csize++] = c;
|
clist[csize++] = c;
|
||||||
}
|
}
|
||||||
if (csize != 0) {
|
if (csize != 0) {
|
||||||
@ -738,7 +738,7 @@ cmd_find_get_pane_with_window(struct cmd_find_state *fs, const char *pane)
|
|||||||
void
|
void
|
||||||
cmd_find_clear_state(struct cmd_find_state *fs, struct cmd_q *cmdq, int flags)
|
cmd_find_clear_state(struct cmd_find_state *fs, struct cmd_q *cmdq, int flags)
|
||||||
{
|
{
|
||||||
memset (fs, 0, sizeof *fs);
|
memset(fs, 0, sizeof *fs);
|
||||||
|
|
||||||
fs->cmdq = cmdq;
|
fs->cmdq = cmdq;
|
||||||
fs->flags = flags;
|
fs->flags = flags;
|
||||||
|
@ -52,7 +52,6 @@ cmd_send_keys_exec(struct cmd *self, struct cmd_q *cmdq)
|
|||||||
struct mouse_event *m = &cmdq->item->mouse;
|
struct mouse_event *m = &cmdq->item->mouse;
|
||||||
struct window_pane *wp;
|
struct window_pane *wp;
|
||||||
struct session *s;
|
struct session *s;
|
||||||
struct input_ctx *ictx;
|
|
||||||
const u_char *str;
|
const u_char *str;
|
||||||
int i, key;
|
int i, key;
|
||||||
|
|
||||||
@ -78,21 +77,8 @@ cmd_send_keys_exec(struct cmd *self, struct cmd_q *cmdq)
|
|||||||
return (CMD_RETURN_NORMAL);
|
return (CMD_RETURN_NORMAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (args_has(args, 'R')) {
|
if (args_has(args, 'R'))
|
||||||
ictx = &wp->ictx;
|
input_reset(wp);
|
||||||
|
|
||||||
memcpy(&ictx->cell, &grid_default_cell, sizeof ictx->cell);
|
|
||||||
memcpy(&ictx->old_cell, &ictx->cell, sizeof ictx->old_cell);
|
|
||||||
ictx->old_cx = 0;
|
|
||||||
ictx->old_cy = 0;
|
|
||||||
|
|
||||||
if (wp->mode == NULL)
|
|
||||||
screen_write_start(&ictx->ctx, wp, &wp->base);
|
|
||||||
else
|
|
||||||
screen_write_start(&ictx->ctx, NULL, &wp->base);
|
|
||||||
screen_write_reset(&ictx->ctx);
|
|
||||||
screen_write_stop(&ictx->ctx);
|
|
||||||
}
|
|
||||||
|
|
||||||
for (i = 0; i < args->argc; i++) {
|
for (i = 0; i < args->argc; i++) {
|
||||||
str = args->argv[i];
|
str = args->argv[i];
|
||||||
|
@ -46,7 +46,7 @@ cmd_switch_client_exec(struct cmd *self, struct cmd_q *cmdq)
|
|||||||
struct winlink *wl = NULL;
|
struct winlink *wl = NULL;
|
||||||
struct window *w = NULL;
|
struct window *w = NULL;
|
||||||
struct window_pane *wp = NULL;
|
struct window_pane *wp = NULL;
|
||||||
const char *tflag, *tablename;
|
const char *tflag, *tablename, *update;
|
||||||
struct key_table *table;
|
struct key_table *table;
|
||||||
|
|
||||||
if ((c = cmd_find_client(cmdq, args_get(args, 'c'), 0)) == NULL)
|
if ((c = cmd_find_client(cmdq, args_get(args, 'c'), 0)) == NULL)
|
||||||
@ -119,6 +119,11 @@ cmd_switch_client_exec(struct cmd *self, struct cmd_q *cmdq)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (c != NULL && s != c->session) {
|
||||||
|
update = options_get_string(&s->options, "update-environment");
|
||||||
|
environ_update(update, &c->environ, &s->environ);
|
||||||
|
}
|
||||||
|
|
||||||
if (c->session != NULL)
|
if (c->session != NULL)
|
||||||
c->last_session = c->session;
|
c->last_session = c->session;
|
||||||
c->session = s;
|
c->session = s;
|
||||||
|
23
environ.c
23
environ.c
@ -157,23 +157,16 @@ environ_update(const char *vars, struct environ *srcenv,
|
|||||||
void
|
void
|
||||||
environ_push(struct environ *env)
|
environ_push(struct environ *env)
|
||||||
{
|
{
|
||||||
ARRAY_DECL(, char *) varlist;
|
struct environ_entry *envent;
|
||||||
struct environ_entry *envent;
|
char **vp, *v;
|
||||||
char **varp, *var;
|
|
||||||
u_int i;
|
|
||||||
|
|
||||||
ARRAY_INIT(&varlist);
|
for (vp = environ; *vp != NULL; vp++) {
|
||||||
for (varp = environ; *varp != NULL; varp++) {
|
v = xstrdup(*vp);
|
||||||
var = xstrdup(*varp);
|
v[strcspn(v, "=")] = '\0';
|
||||||
var[strcspn(var, "=")] = '\0';
|
|
||||||
ARRAY_ADD(&varlist, var);
|
unsetenv(v);
|
||||||
|
free(v);
|
||||||
}
|
}
|
||||||
for (i = 0; i < ARRAY_LENGTH(&varlist); i++) {
|
|
||||||
var = ARRAY_ITEM(&varlist, i);
|
|
||||||
unsetenv(var);
|
|
||||||
free(var);
|
|
||||||
}
|
|
||||||
ARRAY_FREE(&varlist);
|
|
||||||
|
|
||||||
RB_FOREACH(envent, environ, env) {
|
RB_FOREACH(envent, environ, env) {
|
||||||
if (envent->value != NULL)
|
if (envent->value != NULL)
|
||||||
|
2
format.c
2
format.c
@ -718,8 +718,6 @@ format_defaults_pane(struct format_tree *ft, struct window_pane *wp)
|
|||||||
format_add(ft, "cursor_y", "%u", wp->base.cy);
|
format_add(ft, "cursor_y", "%u", wp->base.cy);
|
||||||
format_add(ft, "scroll_region_upper", "%u", wp->base.rupper);
|
format_add(ft, "scroll_region_upper", "%u", wp->base.rupper);
|
||||||
format_add(ft, "scroll_region_lower", "%u", wp->base.rlower);
|
format_add(ft, "scroll_region_lower", "%u", wp->base.rlower);
|
||||||
format_add(ft, "saved_cursor_x", "%u", wp->ictx.old_cx);
|
|
||||||
format_add(ft, "saved_cursor_y", "%u", wp->ictx.old_cy);
|
|
||||||
|
|
||||||
format_add(ft, "alternate_on", "%d", wp->saved_grid ? 1 : 0);
|
format_add(ft, "alternate_on", "%d", wp->saved_grid ? 1 : 0);
|
||||||
format_add(ft, "alternate_saved_x", "%u", wp->saved_cx);
|
format_add(ft, "alternate_saved_x", "%u", wp->saved_cx);
|
||||||
|
29
grid.c
29
grid.c
@ -49,15 +49,16 @@ const struct grid_cell grid_default_cell = { 0, 0, 8, 8, (1 << 4) | 1, " " };
|
|||||||
|
|
||||||
int grid_check_y(struct grid *, u_int);
|
int grid_check_y(struct grid *, u_int);
|
||||||
|
|
||||||
#ifdef DEBUG
|
void grid_reflow_join(struct grid *, u_int *, struct grid_line *, u_int);
|
||||||
int
|
void grid_reflow_split(struct grid *, u_int *, struct grid_line *, u_int,
|
||||||
grid_check_y(struct grid *gd, u_int py)
|
u_int);
|
||||||
{
|
void grid_reflow_move(struct grid *, u_int *, struct grid_line *);
|
||||||
if ((py) >= (gd)->hsize + (gd)->sy)
|
size_t grid_string_cells_fg(const struct grid_cell *, int *);
|
||||||
log_fatalx("y out of range: %u", py);
|
size_t grid_string_cells_bg(const struct grid_cell *, int *);
|
||||||
return (0);
|
void grid_string_cells_code(const struct grid_cell *,
|
||||||
}
|
const struct grid_cell *, char *, size_t, int);
|
||||||
#else
|
|
||||||
|
/* Check grid y position. */
|
||||||
int
|
int
|
||||||
grid_check_y(struct grid *gd, u_int py)
|
grid_check_y(struct grid *gd, u_int py)
|
||||||
{
|
{
|
||||||
@ -67,16 +68,6 @@ grid_check_y(struct grid *gd, u_int py)
|
|||||||
}
|
}
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
void grid_reflow_join(struct grid *, u_int *, struct grid_line *, u_int);
|
|
||||||
void grid_reflow_split(struct grid *, u_int *, struct grid_line *, u_int,
|
|
||||||
u_int);
|
|
||||||
void grid_reflow_move(struct grid *, u_int *, struct grid_line *);
|
|
||||||
size_t grid_string_cells_fg(const struct grid_cell *, int *);
|
|
||||||
size_t grid_string_cells_bg(const struct grid_cell *, int *);
|
|
||||||
void grid_string_cells_code(const struct grid_cell *,
|
|
||||||
const struct grid_cell *, char *, size_t, int);
|
|
||||||
|
|
||||||
/* Create a new grid. */
|
/* Create a new grid. */
|
||||||
struct grid *
|
struct grid *
|
||||||
|
93
input.c
93
input.c
@ -46,6 +46,55 @@
|
|||||||
* be passed to the underlying teminal(s).
|
* be passed to the underlying teminal(s).
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* Input parser cell. */
|
||||||
|
struct input_cell {
|
||||||
|
struct grid_cell cell;
|
||||||
|
int set;
|
||||||
|
int g0set; /* 1 if ACS */
|
||||||
|
int g1set; /* 1 if ACS */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Input parser context. */
|
||||||
|
struct input_ctx {
|
||||||
|
struct window_pane *wp;
|
||||||
|
struct screen_write_ctx ctx;
|
||||||
|
|
||||||
|
struct input_cell cell;
|
||||||
|
|
||||||
|
struct input_cell old_cell;
|
||||||
|
u_int old_cx;
|
||||||
|
u_int old_cy;
|
||||||
|
|
||||||
|
u_char interm_buf[4];
|
||||||
|
size_t interm_len;
|
||||||
|
|
||||||
|
u_char param_buf[64];
|
||||||
|
size_t param_len;
|
||||||
|
|
||||||
|
#define INPUT_BUF_START 32
|
||||||
|
#define INPUT_BUF_LIMIT 1048576
|
||||||
|
u_char *input_buf;
|
||||||
|
size_t input_len;
|
||||||
|
size_t input_space;
|
||||||
|
|
||||||
|
int param_list[24]; /* -1 not present */
|
||||||
|
u_int param_list_len;
|
||||||
|
|
||||||
|
struct utf8_data utf8data;
|
||||||
|
|
||||||
|
int ch;
|
||||||
|
int flags;
|
||||||
|
#define INPUT_DISCARD 0x1
|
||||||
|
|
||||||
|
const struct input_state *state;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* All input received since we were last in the ground state. Sent to
|
||||||
|
* control clients on connection.
|
||||||
|
*/
|
||||||
|
struct evbuffer *since_ground;
|
||||||
|
};
|
||||||
|
|
||||||
/* Helper functions. */
|
/* Helper functions. */
|
||||||
struct input_transition;
|
struct input_transition;
|
||||||
int input_split(struct input_ctx *);
|
int input_split(struct input_ctx *);
|
||||||
@ -706,7 +755,9 @@ input_reset_cell(struct input_ctx *ictx)
|
|||||||
void
|
void
|
||||||
input_init(struct window_pane *wp)
|
input_init(struct window_pane *wp)
|
||||||
{
|
{
|
||||||
struct input_ctx *ictx = &wp->ictx;
|
struct input_ctx *ictx;
|
||||||
|
|
||||||
|
ictx = wp->ictx = xcalloc(1, sizeof *ictx);
|
||||||
|
|
||||||
input_reset_cell(ictx);
|
input_reset_cell(ictx);
|
||||||
|
|
||||||
@ -732,18 +783,46 @@ input_init(struct window_pane *wp)
|
|||||||
void
|
void
|
||||||
input_free(struct window_pane *wp)
|
input_free(struct window_pane *wp)
|
||||||
{
|
{
|
||||||
if (wp == NULL)
|
struct input_ctx *ictx = wp->ictx;
|
||||||
return;
|
|
||||||
|
|
||||||
free(wp->ictx.input_buf);
|
free(ictx->input_buf);
|
||||||
evbuffer_free(wp->ictx.since_ground);
|
evbuffer_free(ictx->since_ground);
|
||||||
|
|
||||||
|
free (ictx);
|
||||||
|
wp->ictx = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Reset input state and clear screen. */
|
||||||
|
void
|
||||||
|
input_reset(struct window_pane *wp)
|
||||||
|
{
|
||||||
|
struct input_ctx *ictx = wp->ictx;
|
||||||
|
|
||||||
|
memcpy(&ictx->cell, &grid_default_cell, sizeof ictx->cell);
|
||||||
|
memcpy(&ictx->old_cell, &ictx->cell, sizeof ictx->old_cell);
|
||||||
|
ictx->old_cx = 0;
|
||||||
|
ictx->old_cy = 0;
|
||||||
|
|
||||||
|
if (wp->mode == NULL)
|
||||||
|
screen_write_start(&ictx->ctx, wp, &wp->base);
|
||||||
|
else
|
||||||
|
screen_write_start(&ictx->ctx, NULL, &wp->base);
|
||||||
|
screen_write_reset(&ictx->ctx);
|
||||||
|
screen_write_stop(&ictx->ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Return pending data. */
|
||||||
|
struct evbuffer *
|
||||||
|
input_pending(struct window_pane *wp)
|
||||||
|
{
|
||||||
|
return (wp->ictx->since_ground);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Change input state. */
|
/* Change input state. */
|
||||||
void
|
void
|
||||||
input_set_state(struct window_pane *wp, const struct input_transition *itr)
|
input_set_state(struct window_pane *wp, const struct input_transition *itr)
|
||||||
{
|
{
|
||||||
struct input_ctx *ictx = &wp->ictx;
|
struct input_ctx *ictx = wp->ictx;
|
||||||
|
|
||||||
if (ictx->state->exit != NULL)
|
if (ictx->state->exit != NULL)
|
||||||
ictx->state->exit(ictx);
|
ictx->state->exit(ictx);
|
||||||
@ -756,7 +835,7 @@ input_set_state(struct window_pane *wp, const struct input_transition *itr)
|
|||||||
void
|
void
|
||||||
input_parse(struct window_pane *wp)
|
input_parse(struct window_pane *wp)
|
||||||
{
|
{
|
||||||
struct input_ctx *ictx = &wp->ictx;
|
struct input_ctx *ictx = wp->ictx;
|
||||||
const struct input_transition *itr;
|
const struct input_transition *itr;
|
||||||
struct evbuffer *evb = wp->event->input;
|
struct evbuffer *evb = wp->event->input;
|
||||||
u_char *buf;
|
u_char *buf;
|
||||||
|
@ -236,7 +236,7 @@ key_bindings_init(void)
|
|||||||
if (error != 0)
|
if (error != 0)
|
||||||
fatalx("bad default key");
|
fatalx("bad default key");
|
||||||
cmdq_run(cmdq, cmdlist, NULL);
|
cmdq_run(cmdq, cmdlist, NULL);
|
||||||
cmd_list_free (cmdlist);
|
cmd_list_free(cmdlist);
|
||||||
}
|
}
|
||||||
cmdq_free(cmdq);
|
cmdq_free(cmdq);
|
||||||
}
|
}
|
||||||
|
14
mode-key.c
14
mode-key.c
@ -38,6 +38,20 @@
|
|||||||
* (any matching MODEKEYEDIT_SWITCHMODE*) are special-cased to do this.
|
* (any matching MODEKEYEDIT_SWITCHMODE*) are special-cased to do this.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* Entry in the default mode key tables. */
|
||||||
|
struct mode_key_entry {
|
||||||
|
int key;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Editing mode for vi: 0 is edit mode, keys not in the table are
|
||||||
|
* returned as MODEKEY_OTHER; 1 is command mode, keys not in the table
|
||||||
|
* are returned as MODEKEY_NONE. This is also matched on, allowing some
|
||||||
|
* keys to be bound in edit mode.
|
||||||
|
*/
|
||||||
|
int mode;
|
||||||
|
enum mode_key_cmd cmd;
|
||||||
|
};
|
||||||
|
|
||||||
/* Edit keys command strings. */
|
/* Edit keys command strings. */
|
||||||
const struct mode_key_cmdstr mode_key_cmdstr_edit[] = {
|
const struct mode_key_cmdstr mode_key_cmdstr_edit[] = {
|
||||||
{ MODEKEYEDIT_BACKSPACE, "backspace" },
|
{ MODEKEYEDIT_BACKSPACE, "backspace" },
|
||||||
|
@ -32,7 +32,7 @@ int screen_redraw_check_active(u_int, u_int, int, struct window *,
|
|||||||
void screen_redraw_draw_borders(struct client *, int, u_int);
|
void screen_redraw_draw_borders(struct client *, int, u_int);
|
||||||
void screen_redraw_draw_panes(struct client *, u_int);
|
void screen_redraw_draw_panes(struct client *, u_int);
|
||||||
void screen_redraw_draw_status(struct client *, u_int);
|
void screen_redraw_draw_status(struct client *, u_int);
|
||||||
void screen_redraw_draw_number(struct client *, struct window_pane *);
|
void screen_redraw_draw_number(struct client *, struct window_pane *, u_int);
|
||||||
|
|
||||||
#define CELL_INSIDE 0
|
#define CELL_INSIDE 0
|
||||||
#define CELL_LEFTRIGHT 1
|
#define CELL_LEFTRIGHT 1
|
||||||
@ -354,7 +354,7 @@ screen_redraw_draw_panes(struct client *c, u_int top)
|
|||||||
for (i = 0; i < wp->sy; i++)
|
for (i = 0; i < wp->sy; i++)
|
||||||
tty_draw_pane(tty, wp, i, wp->xoff, top + wp->yoff);
|
tty_draw_pane(tty, wp, i, wp->xoff, top + wp->yoff);
|
||||||
if (c->flags & CLIENT_IDENTIFY)
|
if (c->flags & CLIENT_IDENTIFY)
|
||||||
screen_redraw_draw_number(c, wp);
|
screen_redraw_draw_number(c, wp, top);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -372,7 +372,7 @@ screen_redraw_draw_status(struct client *c, u_int top)
|
|||||||
|
|
||||||
/* Draw number on a pane. */
|
/* Draw number on a pane. */
|
||||||
void
|
void
|
||||||
screen_redraw_draw_number(struct client *c, struct window_pane *wp)
|
screen_redraw_draw_number(struct client *c, struct window_pane *wp, u_int top)
|
||||||
{
|
{
|
||||||
struct tty *tty = &c->tty;
|
struct tty *tty = &c->tty;
|
||||||
struct session *s = c->session;
|
struct session *s = c->session;
|
||||||
@ -396,6 +396,9 @@ screen_redraw_draw_number(struct client *c, struct window_pane *wp)
|
|||||||
px = wp->sx / 2; py = wp->sy / 2;
|
px = wp->sx / 2; py = wp->sy / 2;
|
||||||
xoff = wp->xoff; yoff = wp->yoff;
|
xoff = wp->xoff; yoff = wp->yoff;
|
||||||
|
|
||||||
|
if (top)
|
||||||
|
yoff++;
|
||||||
|
|
||||||
if (wp->sx < len * 6 || wp->sy < 5) {
|
if (wp->sx < len * 6 || wp->sy < 5) {
|
||||||
tty_cursor(tty, xoff + px - len / 2, yoff + py);
|
tty_cursor(tty, xoff + px - len / 2, yoff + py);
|
||||||
goto draw_text;
|
goto draw_text;
|
||||||
|
@ -1187,11 +1187,6 @@ server_client_msg_identify(struct client *c, struct imsg *imsg)
|
|||||||
return;
|
return;
|
||||||
c->flags |= CLIENT_IDENTIFIED;
|
c->flags |= CLIENT_IDENTIFIED;
|
||||||
|
|
||||||
#ifdef __CYGWIN__
|
|
||||||
c->fd = open(c->ttyname, O_RDWR|O_NOCTTY);
|
|
||||||
c->cwd = open(".", O_RDONLY);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (c->flags & CLIENT_CONTROL) {
|
if (c->flags & CLIENT_CONTROL) {
|
||||||
c->stdin_callback = control_callback;
|
c->stdin_callback = control_callback;
|
||||||
|
|
||||||
|
270
status.c
270
status.c
@ -45,10 +45,15 @@ void status_message_callback(int, short, void *);
|
|||||||
const char *status_prompt_up_history(u_int *);
|
const char *status_prompt_up_history(u_int *);
|
||||||
const char *status_prompt_down_history(u_int *);
|
const char *status_prompt_down_history(u_int *);
|
||||||
void status_prompt_add_history(const char *);
|
void status_prompt_add_history(const char *);
|
||||||
char *status_prompt_complete(const char *);
|
|
||||||
|
const char **status_prompt_complete_list(u_int *, const char *);
|
||||||
|
char *status_prompt_complete_prefix(const char **, u_int);
|
||||||
|
char *status_prompt_complete(struct session *, const char *);
|
||||||
|
|
||||||
/* Status prompt history. */
|
/* Status prompt history. */
|
||||||
ARRAY_DECL(, char *) status_prompt_history = ARRAY_INITIALIZER;
|
#define PROMPT_HISTORY 100
|
||||||
|
char **status_prompt_hlist;
|
||||||
|
u_int status_prompt_hsize;
|
||||||
|
|
||||||
/* Status output tree. */
|
/* Status output tree. */
|
||||||
RB_GENERATE(status_out_tree, status_out, entry, status_out_cmp);
|
RB_GENERATE(status_out_tree, status_out, entry, status_out_cmp);
|
||||||
@ -977,7 +982,7 @@ status_prompt_key(struct client *c, int key)
|
|||||||
word[last - first] = '\0';
|
word[last - first] = '\0';
|
||||||
|
|
||||||
/* And try to complete it. */
|
/* And try to complete it. */
|
||||||
if ((s = status_prompt_complete(word)) == NULL)
|
if ((s = status_prompt_complete(sess, word)) == NULL)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/* Trim out word. */
|
/* Trim out word. */
|
||||||
@ -1235,114 +1240,235 @@ status_prompt_key(struct client *c, int key)
|
|||||||
const char *
|
const char *
|
||||||
status_prompt_up_history(u_int *idx)
|
status_prompt_up_history(u_int *idx)
|
||||||
{
|
{
|
||||||
u_int size;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* History runs from 0 to size - 1.
|
* History runs from 0 to size - 1. Index is from 0 to size. Zero is
|
||||||
*
|
* empty.
|
||||||
* Index is from 0 to size. Zero is empty.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
size = ARRAY_LENGTH(&status_prompt_history);
|
if (status_prompt_hsize == 0 || *idx == status_prompt_hsize)
|
||||||
if (size == 0 || *idx == size)
|
|
||||||
return (NULL);
|
return (NULL);
|
||||||
(*idx)++;
|
(*idx)++;
|
||||||
return (ARRAY_ITEM(&status_prompt_history, size - *idx));
|
return (status_prompt_hlist[status_prompt_hsize - *idx]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get next line from the history. */
|
/* Get next line from the history. */
|
||||||
const char *
|
const char *
|
||||||
status_prompt_down_history(u_int *idx)
|
status_prompt_down_history(u_int *idx)
|
||||||
{
|
{
|
||||||
u_int size;
|
if (status_prompt_hsize == 0 || *idx == 0)
|
||||||
|
|
||||||
size = ARRAY_LENGTH(&status_prompt_history);
|
|
||||||
if (size == 0 || *idx == 0)
|
|
||||||
return ("");
|
return ("");
|
||||||
(*idx)--;
|
(*idx)--;
|
||||||
if (*idx == 0)
|
if (*idx == 0)
|
||||||
return ("");
|
return ("");
|
||||||
return (ARRAY_ITEM(&status_prompt_history, size - *idx));
|
return (status_prompt_hlist[status_prompt_hsize - *idx]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Add line to the history. */
|
/* Add line to the history. */
|
||||||
void
|
void
|
||||||
status_prompt_add_history(const char *line)
|
status_prompt_add_history(const char *line)
|
||||||
{
|
{
|
||||||
u_int size;
|
size_t size;
|
||||||
|
|
||||||
size = ARRAY_LENGTH(&status_prompt_history);
|
if (status_prompt_hsize > 0 &&
|
||||||
if (size > 0 && strcmp(ARRAY_LAST(&status_prompt_history), line) == 0)
|
strcmp(status_prompt_hlist[status_prompt_hsize - 1], line) == 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (size == PROMPT_HISTORY) {
|
if (status_prompt_hsize == PROMPT_HISTORY) {
|
||||||
free(ARRAY_FIRST(&status_prompt_history));
|
free(status_prompt_hlist[0]);
|
||||||
ARRAY_REMOVE(&status_prompt_history, 0);
|
|
||||||
|
size = (PROMPT_HISTORY - 1) * sizeof *status_prompt_hlist;
|
||||||
|
memmove(&status_prompt_hlist[0], &status_prompt_hlist[1], size);
|
||||||
|
|
||||||
|
status_prompt_hlist[status_prompt_hsize - 1] = xstrdup(line);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ARRAY_ADD(&status_prompt_history, xstrdup(line));
|
status_prompt_hlist = xreallocarray(status_prompt_hlist,
|
||||||
|
status_prompt_hsize + 1, sizeof *status_prompt_hlist);
|
||||||
|
status_prompt_hlist[status_prompt_hsize++] = xstrdup(line);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Build completion list. */
|
||||||
|
const char **
|
||||||
|
status_prompt_complete_list(u_int *size, const char *s)
|
||||||
|
{
|
||||||
|
const char **list = NULL, **layout;
|
||||||
|
const struct cmd_entry **cmdent;
|
||||||
|
const struct options_table_entry *oe;
|
||||||
|
const char *layouts[] = {
|
||||||
|
"even-horizontal", "even-vertical", "main-horizontal",
|
||||||
|
"main-vertical", "tiled", NULL
|
||||||
|
};
|
||||||
|
|
||||||
|
*size = 0;
|
||||||
|
for (cmdent = cmd_table; *cmdent != NULL; cmdent++) {
|
||||||
|
if (strncmp((*cmdent)->name, s, strlen(s)) == 0) {
|
||||||
|
list = xreallocarray(list, (*size) + 1, sizeof *list);
|
||||||
|
list[(*size)++] = (*cmdent)->name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (oe = server_options_table; oe->name != NULL; oe++) {
|
||||||
|
if (strncmp(oe->name, s, strlen(s)) == 0) {
|
||||||
|
list = xreallocarray(list, (*size) + 1, sizeof *list);
|
||||||
|
list[(*size)++] = oe->name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (oe = session_options_table; oe->name != NULL; oe++) {
|
||||||
|
if (strncmp(oe->name, s, strlen(s)) == 0) {
|
||||||
|
list = xreallocarray(list, (*size) + 1, sizeof *list);
|
||||||
|
list[(*size)++] = oe->name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (oe = window_options_table; oe->name != NULL; oe++) {
|
||||||
|
if (strncmp(oe->name, s, strlen(s)) == 0) {
|
||||||
|
list = xreallocarray(list, (*size) + 1, sizeof *list);
|
||||||
|
list[(*size)++] = oe->name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (layout = layouts; *layout != NULL; layout++) {
|
||||||
|
if (strncmp(*layout, s, strlen(s)) == 0) {
|
||||||
|
list = xreallocarray(list, (*size) + 1, sizeof *list);
|
||||||
|
list[(*size)++] = *layout;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return (list);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Find longest prefix. */
|
||||||
|
char *
|
||||||
|
status_prompt_complete_prefix(const char **list, u_int size)
|
||||||
|
{
|
||||||
|
char *out;
|
||||||
|
u_int i;
|
||||||
|
size_t j;
|
||||||
|
|
||||||
|
out = xstrdup(list[0]);
|
||||||
|
for (i = 1; i < size; i++) {
|
||||||
|
j = strlen(list[i]);
|
||||||
|
if (j > strlen(out))
|
||||||
|
j = strlen(out);
|
||||||
|
for (; j > 0; j--) {
|
||||||
|
if (out[j - 1] != list[i][j - 1])
|
||||||
|
out[j - 1] = '\0';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return (out);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Complete word. */
|
/* Complete word. */
|
||||||
char *
|
char *
|
||||||
status_prompt_complete(const char *s)
|
status_prompt_complete(struct session *sess, const char *s)
|
||||||
{
|
{
|
||||||
const struct cmd_entry **cmdent;
|
const char **list = NULL, *colon;
|
||||||
const struct options_table_entry *oe;
|
u_int size = 0, i;
|
||||||
ARRAY_DECL(, const char *) list;
|
struct session *s_loop;
|
||||||
char *prefix, *s2;
|
struct winlink *wl;
|
||||||
u_int i;
|
struct window *w;
|
||||||
size_t j;
|
char *copy, *out, *tmp;
|
||||||
|
|
||||||
if (*s == '\0')
|
if (*s == '\0')
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
out = NULL;
|
||||||
|
|
||||||
/* First, build a list of all the possible matches. */
|
if (strncmp(s, "-t", 2) != 0 && strncmp(s, "-s", 2) != 0) {
|
||||||
ARRAY_INIT(&list);
|
list = status_prompt_complete_list(&size, s);
|
||||||
for (cmdent = cmd_table; *cmdent != NULL; cmdent++) {
|
if (size == 0)
|
||||||
if (strncmp((*cmdent)->name, s, strlen(s)) == 0)
|
out = NULL;
|
||||||
ARRAY_ADD(&list, (*cmdent)->name);
|
else if (size == 1)
|
||||||
}
|
xasprintf(&out, "%s ", list[0]);
|
||||||
for (oe = server_options_table; oe->name != NULL; oe++) {
|
else
|
||||||
if (strncmp(oe->name, s, strlen(s)) == 0)
|
out = status_prompt_complete_prefix(list, size);
|
||||||
ARRAY_ADD(&list, oe->name);
|
free(list);
|
||||||
}
|
return (out);
|
||||||
for (oe = session_options_table; oe->name != NULL; oe++) {
|
|
||||||
if (strncmp(oe->name, s, strlen(s)) == 0)
|
|
||||||
ARRAY_ADD(&list, oe->name);
|
|
||||||
}
|
|
||||||
for (oe = window_options_table; oe->name != NULL; oe++) {
|
|
||||||
if (strncmp(oe->name, s, strlen(s)) == 0)
|
|
||||||
ARRAY_ADD(&list, oe->name);
|
|
||||||
}
|
}
|
||||||
|
copy = xstrdup(s);
|
||||||
|
|
||||||
/* If none, bail now. */
|
colon = ":";
|
||||||
if (ARRAY_LENGTH(&list) == 0) {
|
if (copy[strlen(copy) - 1] == ':')
|
||||||
ARRAY_FREE(&list);
|
copy[strlen(copy) - 1] = '\0';
|
||||||
return (NULL);
|
else
|
||||||
}
|
colon = "";
|
||||||
|
s = copy + 2;
|
||||||
|
|
||||||
/* If an exact match, return it, with a trailing space. */
|
RB_FOREACH(s_loop, sessions, &sessions) {
|
||||||
if (ARRAY_LENGTH(&list) == 1) {
|
if (strncmp(s_loop->name, s, strlen(s)) == 0) {
|
||||||
xasprintf(&s2, "%s ", ARRAY_FIRST(&list));
|
list = xreallocarray(list, size + 2, sizeof *list);
|
||||||
ARRAY_FREE(&list);
|
list[size++] = s_loop->name;
|
||||||
return (s2);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Now loop through the list and find the longest common prefix. */
|
|
||||||
prefix = xstrdup(ARRAY_FIRST(&list));
|
|
||||||
for (i = 1; i < ARRAY_LENGTH(&list); i++) {
|
|
||||||
s = ARRAY_ITEM(&list, i);
|
|
||||||
|
|
||||||
j = strlen(s);
|
|
||||||
if (j > strlen(prefix))
|
|
||||||
j = strlen(prefix);
|
|
||||||
for (; j > 0; j--) {
|
|
||||||
if (prefix[j - 1] != s[j - 1])
|
|
||||||
prefix[j - 1] = '\0';
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (size == 1) {
|
||||||
|
out = xstrdup(list[0]);
|
||||||
|
if (session_find(list[0]) != NULL)
|
||||||
|
colon = ":";
|
||||||
|
} else if (size != 0)
|
||||||
|
out = status_prompt_complete_prefix(list, size);
|
||||||
|
if (out != NULL) {
|
||||||
|
xasprintf(&tmp, "-%c%s%s", copy[1], out, colon);
|
||||||
|
out = tmp;
|
||||||
|
goto found;
|
||||||
|
}
|
||||||
|
|
||||||
ARRAY_FREE(&list);
|
colon = "";
|
||||||
return (prefix);
|
if (*s == ':') {
|
||||||
|
RB_FOREACH(wl, winlinks, &sess->windows) {
|
||||||
|
xasprintf(&tmp, ":%s", wl->window->name);
|
||||||
|
if (strncmp(tmp, s, strlen(s)) == 0){
|
||||||
|
list = xreallocarray(list, size + 1,
|
||||||
|
sizeof *list);
|
||||||
|
list[size++] = tmp;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
free(tmp);
|
||||||
|
|
||||||
|
xasprintf(&tmp, ":%d", wl->idx);
|
||||||
|
if (strncmp(tmp, s, strlen(s)) == 0) {
|
||||||
|
list = xreallocarray(list, size + 1,
|
||||||
|
sizeof *list);
|
||||||
|
list[size++] = tmp;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
free(tmp);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
RB_FOREACH(s_loop, sessions, &sessions) {
|
||||||
|
RB_FOREACH(wl, winlinks, &s_loop->windows) {
|
||||||
|
w = wl->window;
|
||||||
|
|
||||||
|
xasprintf(&tmp, "%s:%s", s_loop->name, w->name);
|
||||||
|
if (strncmp(tmp, s, strlen(s)) == 0) {
|
||||||
|
list = xreallocarray(list, size + 1,
|
||||||
|
sizeof *list);
|
||||||
|
list[size++] = tmp;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
free(tmp);
|
||||||
|
|
||||||
|
xasprintf(&tmp, "%s:%d", s_loop->name, wl->idx);
|
||||||
|
if (strncmp(tmp, s, strlen(s)) == 0) {
|
||||||
|
list = xreallocarray(list, size + 1,
|
||||||
|
sizeof *list);
|
||||||
|
list[size++] = tmp;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
free(tmp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (size == 1) {
|
||||||
|
out = xstrdup(list[0]);
|
||||||
|
colon = " ";
|
||||||
|
} else if (size != 0)
|
||||||
|
out = status_prompt_complete_prefix(list, size);
|
||||||
|
if (out != NULL) {
|
||||||
|
xasprintf(&tmp, "-%c%s%s", copy[1], out, colon);
|
||||||
|
out = tmp;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < size; i++)
|
||||||
|
free((void *)list[i]);
|
||||||
|
|
||||||
|
found:
|
||||||
|
free(copy);
|
||||||
|
free(list);
|
||||||
|
return (out);
|
||||||
}
|
}
|
||||||
|
4
style.c
4
style.c
@ -168,12 +168,12 @@ style_update_new(struct options *oo, const char *name, const char *newname)
|
|||||||
|
|
||||||
o = options_find1(oo, newname);
|
o = options_find1(oo, newname);
|
||||||
if (o == NULL)
|
if (o == NULL)
|
||||||
o = options_set_style (oo, newname, "default", 0);
|
o = options_set_style(oo, newname, "default", 0);
|
||||||
gc = &o->style;
|
gc = &o->style;
|
||||||
|
|
||||||
o = options_find1(oo, name);
|
o = options_find1(oo, name);
|
||||||
if (o == NULL)
|
if (o == NULL)
|
||||||
o = options_set_number (oo, name, 8);
|
o = options_set_number(oo, name, 8);
|
||||||
value = o->num;
|
value = o->num;
|
||||||
|
|
||||||
if (strstr(name, "-bg") != NULL)
|
if (strstr(name, "-bg") != NULL)
|
||||||
|
2
tmux.1
2
tmux.1
@ -3323,8 +3323,6 @@ The following variables are available, where appropriate:
|
|||||||
.It Li "pane_top" Ta "" Ta "Top of pane"
|
.It Li "pane_top" Ta "" Ta "Top of pane"
|
||||||
.It Li "pane_tty" Ta "" Ta "Pseudo terminal of pane"
|
.It Li "pane_tty" Ta "" Ta "Pseudo terminal of pane"
|
||||||
.It Li "pane_width" Ta "" Ta "Width of pane"
|
.It Li "pane_width" Ta "" Ta "Width of pane"
|
||||||
.It Li "saved_cursor_x" Ta "" Ta "Saved cursor X in pane"
|
|
||||||
.It Li "saved_cursor_y" Ta "" Ta "Saved cursor Y in pane"
|
|
||||||
.It Li "scroll_region_lower" Ta "" Ta "Bottom of scroll region in pane"
|
.It Li "scroll_region_lower" Ta "" Ta "Bottom of scroll region in pane"
|
||||||
.It Li "scroll_region_upper" Ta "" Ta "Top of scroll region in pane"
|
.It Li "scroll_region_upper" Ta "" Ta "Top of scroll region in pane"
|
||||||
.It Li "session_attached" Ta "" Ta "Number of clients session is attached to"
|
.It Li "session_attached" Ta "" Ta "Number of clients session is attached to"
|
||||||
|
195
tmux.h
195
tmux.h
@ -34,15 +34,16 @@
|
|||||||
#include <utempter.h>
|
#include <utempter.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "array.h"
|
|
||||||
|
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
|
|
||||||
extern char *__progname;
|
extern char *__progname;
|
||||||
extern char **environ;
|
extern char **environ;
|
||||||
|
|
||||||
/* Default prompt history length. */
|
extern char *__progname;
|
||||||
#define PROMPT_HISTORY 100
|
extern char **environ;
|
||||||
|
|
||||||
|
/* Default global configuration file. */
|
||||||
|
#define TMUX_CONF "/etc/tmux.conf"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Minimum layout cell size, NOT including separator line. The scroll region
|
* Minimum layout cell size, NOT including separator line. The scroll region
|
||||||
@ -569,20 +570,6 @@ enum mode_key_cmd {
|
|||||||
MODEKEYCOPY_UP,
|
MODEKEYCOPY_UP,
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Entry in the default mode key tables. */
|
|
||||||
struct mode_key_entry {
|
|
||||||
int key;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Editing mode for vi: 0 is edit mode, keys not in the table are
|
|
||||||
* returned as MODEKEY_OTHER; 1 is command mode, keys not in the table
|
|
||||||
* are returned as MODEKEY_NONE. This is also matched on, allowing some
|
|
||||||
* keys to be bound in edit mode.
|
|
||||||
*/
|
|
||||||
int mode;
|
|
||||||
enum mode_key_cmd cmd;
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Data required while mode keys are in use. */
|
/* Data required while mode keys are in use. */
|
||||||
struct mode_key_data {
|
struct mode_key_data {
|
||||||
struct mode_key_tree *tree;
|
struct mode_key_tree *tree;
|
||||||
@ -610,6 +597,7 @@ struct mode_key_cmdstr {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* Named mode key table description. */
|
/* Named mode key table description. */
|
||||||
|
struct mode_key_entry;
|
||||||
struct mode_key_table {
|
struct mode_key_table {
|
||||||
const char *name;
|
const char *name;
|
||||||
const struct mode_key_cmdstr *cmdstr;
|
const struct mode_key_cmdstr *cmdstr;
|
||||||
@ -705,7 +693,7 @@ struct options_entry {
|
|||||||
} type;
|
} type;
|
||||||
|
|
||||||
char *str;
|
char *str;
|
||||||
long long num;
|
long long num;
|
||||||
struct grid_cell style;
|
struct grid_cell style;
|
||||||
|
|
||||||
RB_ENTRY(options_entry) entry;
|
RB_ENTRY(options_entry) entry;
|
||||||
@ -788,55 +776,6 @@ struct screen_write_ctx {
|
|||||||
#define screen_hsize(s) ((s)->grid->hsize)
|
#define screen_hsize(s) ((s)->grid->hsize)
|
||||||
#define screen_hlimit(s) ((s)->grid->hlimit)
|
#define screen_hlimit(s) ((s)->grid->hlimit)
|
||||||
|
|
||||||
/* Input parser cell. */
|
|
||||||
struct input_cell {
|
|
||||||
struct grid_cell cell;
|
|
||||||
int set;
|
|
||||||
int g0set; /* 1 if ACS */
|
|
||||||
int g1set; /* 1 if ACS */
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Input parser context. */
|
|
||||||
struct input_ctx {
|
|
||||||
struct window_pane *wp;
|
|
||||||
struct screen_write_ctx ctx;
|
|
||||||
|
|
||||||
struct input_cell cell;
|
|
||||||
|
|
||||||
struct input_cell old_cell;
|
|
||||||
u_int old_cx;
|
|
||||||
u_int old_cy;
|
|
||||||
|
|
||||||
u_char interm_buf[4];
|
|
||||||
size_t interm_len;
|
|
||||||
|
|
||||||
u_char param_buf[64];
|
|
||||||
size_t param_len;
|
|
||||||
|
|
||||||
#define INPUT_BUF_START 32
|
|
||||||
#define INPUT_BUF_LIMIT 1048576
|
|
||||||
u_char *input_buf;
|
|
||||||
size_t input_len;
|
|
||||||
size_t input_space;
|
|
||||||
|
|
||||||
int param_list[24]; /* -1 not present */
|
|
||||||
u_int param_list_len;
|
|
||||||
|
|
||||||
struct utf8_data utf8data;
|
|
||||||
|
|
||||||
int ch;
|
|
||||||
int flags;
|
|
||||||
#define INPUT_DISCARD 0x1
|
|
||||||
|
|
||||||
const struct input_state *state;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* All input received since we were last in the ground state. Sent to
|
|
||||||
* control clients on connection.
|
|
||||||
*/
|
|
||||||
struct evbuffer *since_ground;
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Window mode. Windows can be in several modes and this is used to call the
|
* Window mode. Windows can be in several modes and this is used to call the
|
||||||
* right function to handle input and output.
|
* right function to handle input and output.
|
||||||
@ -869,21 +808,14 @@ struct window_choose_data {
|
|||||||
struct winlink *wl;
|
struct winlink *wl;
|
||||||
int pane_id;
|
int pane_id;
|
||||||
|
|
||||||
char *ft_template;
|
char *ft_template;
|
||||||
struct format_tree *ft;
|
struct format_tree *ft;
|
||||||
|
|
||||||
char *command;
|
char *command;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct window_choose_mode_item {
|
|
||||||
struct window_choose_data *wcd;
|
|
||||||
char *name;
|
|
||||||
int pos;
|
|
||||||
int state;
|
|
||||||
#define TREE_EXPANDED 0x1
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Child window structure. */
|
/* Child window structure. */
|
||||||
|
struct input_ctx;
|
||||||
struct window_pane {
|
struct window_pane {
|
||||||
u_int id;
|
u_int id;
|
||||||
u_int active_point;
|
u_int active_point;
|
||||||
@ -923,7 +855,7 @@ struct window_pane {
|
|||||||
int fd;
|
int fd;
|
||||||
struct bufferevent *event;
|
struct bufferevent *event;
|
||||||
|
|
||||||
struct input_ctx ictx;
|
struct input_ctx *ictx;
|
||||||
|
|
||||||
struct grid_cell colgc;
|
struct grid_cell colgc;
|
||||||
|
|
||||||
@ -954,7 +886,7 @@ struct window {
|
|||||||
u_int id;
|
u_int id;
|
||||||
char *name;
|
char *name;
|
||||||
struct event name_timer;
|
struct event name_timer;
|
||||||
struct timeval silence_timer;
|
struct timeval silence_timer;
|
||||||
|
|
||||||
struct window_pane *active;
|
struct window_pane *active;
|
||||||
struct window_pane *last;
|
struct window_pane *last;
|
||||||
@ -995,7 +927,7 @@ struct winlink {
|
|||||||
struct grid_cell status_cell;
|
struct grid_cell status_cell;
|
||||||
char *status_text;
|
char *status_text;
|
||||||
|
|
||||||
int flags;
|
int flags;
|
||||||
#define WINLINK_BELL 0x1
|
#define WINLINK_BELL 0x1
|
||||||
#define WINLINK_ACTIVITY 0x2
|
#define WINLINK_ACTIVITY 0x2
|
||||||
#define WINLINK_SILENCE 0x4
|
#define WINLINK_SILENCE 0x4
|
||||||
@ -1087,7 +1019,7 @@ struct session {
|
|||||||
#define SESSION_UNATTACHED 0x1 /* not attached to any clients */
|
#define SESSION_UNATTACHED 0x1 /* not attached to any clients */
|
||||||
int flags;
|
int flags;
|
||||||
|
|
||||||
u_int attached;
|
u_int attached;
|
||||||
|
|
||||||
struct termios *tio;
|
struct termios *tio;
|
||||||
|
|
||||||
@ -1100,33 +1032,6 @@ struct session {
|
|||||||
};
|
};
|
||||||
RB_HEAD(sessions, session);
|
RB_HEAD(sessions, session);
|
||||||
|
|
||||||
/* TTY information. */
|
|
||||||
struct tty_key {
|
|
||||||
char ch;
|
|
||||||
int key;
|
|
||||||
|
|
||||||
struct tty_key *left;
|
|
||||||
struct tty_key *right;
|
|
||||||
|
|
||||||
struct tty_key *next;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct tty_term {
|
|
||||||
char *name;
|
|
||||||
u_int references;
|
|
||||||
|
|
||||||
char acs[UCHAR_MAX + 1][2];
|
|
||||||
|
|
||||||
struct tty_code codes[NTTYCODE];
|
|
||||||
|
|
||||||
#define TERM_256COLOURS 0x1
|
|
||||||
#define TERM_EARLYWRAP 0x2
|
|
||||||
int flags;
|
|
||||||
|
|
||||||
LIST_ENTRY(tty_term) entry;
|
|
||||||
};
|
|
||||||
LIST_HEAD(tty_terms, tty_term);
|
|
||||||
|
|
||||||
/* Mouse button masks. */
|
/* Mouse button masks. */
|
||||||
#define MOUSE_MASK_BUTTONS 3
|
#define MOUSE_MASK_BUTTONS 3
|
||||||
#define MOUSE_MASK_SHIFT 4
|
#define MOUSE_MASK_SHIFT 4
|
||||||
@ -1168,6 +1073,33 @@ struct mouse_event {
|
|||||||
u_int sgr_b;
|
u_int sgr_b;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* TTY information. */
|
||||||
|
struct tty_key {
|
||||||
|
char ch;
|
||||||
|
int key;
|
||||||
|
|
||||||
|
struct tty_key *left;
|
||||||
|
struct tty_key *right;
|
||||||
|
|
||||||
|
struct tty_key *next;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct tty_term {
|
||||||
|
char *name;
|
||||||
|
u_int references;
|
||||||
|
|
||||||
|
char acs[UCHAR_MAX + 1][2];
|
||||||
|
|
||||||
|
struct tty_code codes[NTTYCODE];
|
||||||
|
|
||||||
|
#define TERM_256COLOURS 0x1
|
||||||
|
#define TERM_EARLYWRAP 0x2
|
||||||
|
int flags;
|
||||||
|
|
||||||
|
LIST_ENTRY(tty_term) entry;
|
||||||
|
};
|
||||||
|
LIST_HEAD(tty_terms, tty_term);
|
||||||
|
|
||||||
struct tty {
|
struct tty {
|
||||||
struct client *client;
|
struct client *client;
|
||||||
|
|
||||||
@ -1215,7 +1147,7 @@ struct tty {
|
|||||||
void (*mouse_drag_update)(struct client *,
|
void (*mouse_drag_update)(struct client *,
|
||||||
struct mouse_event *);
|
struct mouse_event *);
|
||||||
void (*mouse_drag_release)(struct client *,
|
void (*mouse_drag_release)(struct client *,
|
||||||
struct mouse_event *);
|
struct mouse_event *);
|
||||||
|
|
||||||
struct event key_timer;
|
struct event key_timer;
|
||||||
struct tty_key *key_tree;
|
struct tty_key *key_tree;
|
||||||
@ -1251,16 +1183,16 @@ struct tty_ctx {
|
|||||||
|
|
||||||
/* Saved message entry. */
|
/* Saved message entry. */
|
||||||
struct message_entry {
|
struct message_entry {
|
||||||
char *msg;
|
char *msg;
|
||||||
u_int msg_num;
|
u_int msg_num;
|
||||||
time_t msg_time;
|
time_t msg_time;
|
||||||
TAILQ_ENTRY(message_entry) entry;
|
TAILQ_ENTRY(message_entry) entry;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Status output data from a job. */
|
/* Status output data from a job. */
|
||||||
struct status_out {
|
struct status_out {
|
||||||
char *cmd;
|
char *cmd;
|
||||||
char *out;
|
char *out;
|
||||||
|
|
||||||
RB_ENTRY(status_out) entry;
|
RB_ENTRY(status_out) entry;
|
||||||
};
|
};
|
||||||
@ -1289,7 +1221,7 @@ struct client {
|
|||||||
void (*stdin_callback)(struct client *, int, void *);
|
void (*stdin_callback)(struct client *, int, void *);
|
||||||
void *stdin_callback_data;
|
void *stdin_callback_data;
|
||||||
struct evbuffer *stdin_data;
|
struct evbuffer *stdin_data;
|
||||||
int stdin_closed;
|
int stdin_closed;
|
||||||
struct evbuffer *stdout_data;
|
struct evbuffer *stdout_data;
|
||||||
struct evbuffer *stderr_data;
|
struct evbuffer *stderr_data;
|
||||||
|
|
||||||
@ -1335,7 +1267,7 @@ struct client {
|
|||||||
int (*prompt_callbackfn)(void *, const char *);
|
int (*prompt_callbackfn)(void *, const char *);
|
||||||
void (*prompt_freefn)(void *);
|
void (*prompt_freefn)(void *);
|
||||||
void *prompt_data;
|
void *prompt_data;
|
||||||
u_int prompt_hindex;
|
u_int prompt_hindex;
|
||||||
|
|
||||||
#define PROMPT_SINGLE 0x1
|
#define PROMPT_SINGLE 0x1
|
||||||
int prompt_flags;
|
int prompt_flags;
|
||||||
@ -1364,8 +1296,8 @@ RB_HEAD(args_tree, args_entry);
|
|||||||
|
|
||||||
struct args {
|
struct args {
|
||||||
struct args_tree tree;
|
struct args_tree tree;
|
||||||
int argc;
|
int argc;
|
||||||
char **argv;
|
char **argv;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Command and list of commands. */
|
/* Command and list of commands. */
|
||||||
@ -1381,9 +1313,10 @@ struct cmd {
|
|||||||
|
|
||||||
TAILQ_ENTRY(cmd) qentry;
|
TAILQ_ENTRY(cmd) qentry;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct cmd_list {
|
struct cmd_list {
|
||||||
int references;
|
int references;
|
||||||
TAILQ_HEAD(, cmd) list;
|
TAILQ_HEAD(, cmd) list;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Command return values. */
|
/* Command return values. */
|
||||||
@ -1422,7 +1355,7 @@ struct cmd_q {
|
|||||||
void (*emptyfn)(struct cmd_q *);
|
void (*emptyfn)(struct cmd_q *);
|
||||||
void *data;
|
void *data;
|
||||||
|
|
||||||
TAILQ_ENTRY(cmd_q) waitentry;
|
TAILQ_ENTRY(cmd_q) waitentry;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Command definition. */
|
/* Command definition. */
|
||||||
@ -1453,6 +1386,7 @@ struct key_binding {
|
|||||||
RB_ENTRY(key_binding) entry;
|
RB_ENTRY(key_binding) entry;
|
||||||
};
|
};
|
||||||
RB_HEAD(key_bindings, key_binding);
|
RB_HEAD(key_bindings, key_binding);
|
||||||
|
|
||||||
struct key_table {
|
struct key_table {
|
||||||
const char *name;
|
const char *name;
|
||||||
struct key_bindings key_bindings;
|
struct key_bindings key_bindings;
|
||||||
@ -1483,8 +1417,8 @@ struct options_table_entry {
|
|||||||
const char *name;
|
const char *name;
|
||||||
enum options_table_type type;
|
enum options_table_type type;
|
||||||
|
|
||||||
u_int minimum;
|
u_int minimum;
|
||||||
u_int maximum;
|
u_int maximum;
|
||||||
const char **choices;
|
const char **choices;
|
||||||
|
|
||||||
const char *default_str;
|
const char *default_str;
|
||||||
@ -1871,7 +1805,7 @@ void printflike(2, 3) cmdq_print(struct cmd_q *, const char *, ...);
|
|||||||
void printflike(2, 3) cmdq_error(struct cmd_q *, const char *, ...);
|
void printflike(2, 3) cmdq_error(struct cmd_q *, const char *, ...);
|
||||||
void cmdq_guard(struct cmd_q *, const char *, int);
|
void cmdq_guard(struct cmd_q *, const char *, int);
|
||||||
void cmdq_run(struct cmd_q *, struct cmd_list *,
|
void cmdq_run(struct cmd_q *, struct cmd_list *,
|
||||||
struct mouse_event *);
|
struct mouse_event *);
|
||||||
void cmdq_append(struct cmd_q *, struct cmd_list *,
|
void cmdq_append(struct cmd_q *, struct cmd_list *,
|
||||||
struct mouse_event *);
|
struct mouse_event *);
|
||||||
int cmdq_continue(struct cmd_q *);
|
int cmdq_continue(struct cmd_q *);
|
||||||
@ -1893,8 +1827,8 @@ RB_PROTOTYPE(key_tables, key_table, entry, key_table_cmp);
|
|||||||
extern struct key_tables key_tables;
|
extern struct key_tables key_tables;
|
||||||
int key_table_cmp(struct key_table *, struct key_table *);
|
int key_table_cmp(struct key_table *, struct key_table *);
|
||||||
int key_bindings_cmp(struct key_binding *, struct key_binding *);
|
int key_bindings_cmp(struct key_binding *, struct key_binding *);
|
||||||
struct key_table *key_bindings_get_table(const char *, int);
|
struct key_table *key_bindings_get_table(const char *, int);
|
||||||
void key_bindings_unref_table(struct key_table *);
|
void key_bindings_unref_table(struct key_table *);
|
||||||
void key_bindings_add(const char *, int, int, struct cmd_list *);
|
void key_bindings_add(const char *, int, int, struct cmd_list *);
|
||||||
void key_bindings_remove(const char *, int);
|
void key_bindings_remove(const char *, int);
|
||||||
void key_bindings_remove_table(const char *);
|
void key_bindings_remove_table(const char *);
|
||||||
@ -1916,7 +1850,7 @@ void server_add_accept(int);
|
|||||||
/* server-client.c */
|
/* server-client.c */
|
||||||
void server_client_handle_key(struct client *, int);
|
void server_client_handle_key(struct client *, int);
|
||||||
void server_client_create(int);
|
void server_client_create(int);
|
||||||
int server_client_open(struct client *, char **);
|
int server_client_open(struct client *, char **);
|
||||||
void server_client_lost(struct client *);
|
void server_client_lost(struct client *);
|
||||||
void server_client_callback(int, short, void *);
|
void server_client_callback(int, short, void *);
|
||||||
void server_client_status_timer(void);
|
void server_client_status_timer(void);
|
||||||
@ -1986,6 +1920,8 @@ void recalculate_sizes(void);
|
|||||||
/* input.c */
|
/* input.c */
|
||||||
void input_init(struct window_pane *);
|
void input_init(struct window_pane *);
|
||||||
void input_free(struct window_pane *);
|
void input_free(struct window_pane *);
|
||||||
|
void input_reset(struct window_pane *);
|
||||||
|
struct evbuffer *input_pending(struct window_pane *);
|
||||||
void input_parse(struct window_pane *);
|
void input_parse(struct window_pane *);
|
||||||
|
|
||||||
/* input-key.c */
|
/* input-key.c */
|
||||||
@ -2008,7 +1944,6 @@ int attributes_fromstring(const char *);
|
|||||||
|
|
||||||
/* grid.c */
|
/* grid.c */
|
||||||
extern const struct grid_cell grid_default_cell;
|
extern const struct grid_cell grid_default_cell;
|
||||||
extern const struct grid_cell grid_marker_cell;
|
|
||||||
struct grid *grid_create(u_int, u_int, u_int);
|
struct grid *grid_create(u_int, u_int, u_int);
|
||||||
void grid_destroy(struct grid *);
|
void grid_destroy(struct grid *);
|
||||||
int grid_compare(struct grid *, struct grid *);
|
int grid_compare(struct grid *, struct grid *);
|
||||||
@ -2166,9 +2101,9 @@ void window_lost_pane(struct window *, struct window_pane *);
|
|||||||
void window_remove_pane(struct window *, struct window_pane *);
|
void window_remove_pane(struct window *, struct window_pane *);
|
||||||
struct window_pane *window_pane_at_index(struct window *, u_int);
|
struct window_pane *window_pane_at_index(struct window *, u_int);
|
||||||
struct window_pane *window_pane_next_by_number(struct window *,
|
struct window_pane *window_pane_next_by_number(struct window *,
|
||||||
struct window_pane *, u_int);
|
struct window_pane *, u_int);
|
||||||
struct window_pane *window_pane_previous_by_number(struct window *,
|
struct window_pane *window_pane_previous_by_number(struct window *,
|
||||||
struct window_pane *, u_int);
|
struct window_pane *, u_int);
|
||||||
int window_pane_index(struct window_pane *, u_int *);
|
int window_pane_index(struct window_pane *, u_int *);
|
||||||
u_int window_count_panes(struct window *);
|
u_int window_count_panes(struct window *);
|
||||||
void window_destroy_panes(struct window *);
|
void window_destroy_panes(struct window *);
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
#include "array.h"
|
||||||
#include "tmux.h"
|
#include "tmux.h"
|
||||||
|
|
||||||
struct screen *window_choose_init(struct window_pane *);
|
struct screen *window_choose_init(struct window_pane *);
|
||||||
@ -59,6 +60,14 @@ const struct window_mode window_choose_mode = {
|
|||||||
NULL,
|
NULL,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct window_choose_mode_item {
|
||||||
|
struct window_choose_data *wcd;
|
||||||
|
char *name;
|
||||||
|
int pos;
|
||||||
|
int state;
|
||||||
|
#define TREE_EXPANDED 0x1
|
||||||
|
};
|
||||||
|
|
||||||
struct window_choose_mode_data {
|
struct window_choose_mode_data {
|
||||||
struct screen screen;
|
struct screen screen;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user