mirror of
https://github.com/tmate-io/tmate.git
synced 2025-03-15 08:38:53 +01:00
Merge branch 'obsd-master'
This commit is contained in:
commit
4afe26fa82
@ -47,6 +47,7 @@ cmd_select_pane_exec(struct cmd *self, struct cmd_q *cmdq)
|
|||||||
{
|
{
|
||||||
struct args *args = self->args;
|
struct args *args = self->args;
|
||||||
struct winlink *wl;
|
struct winlink *wl;
|
||||||
|
struct window *w;
|
||||||
struct session *s;
|
struct session *s;
|
||||||
struct window_pane *wp, *lastwp, *markedwp;
|
struct window_pane *wp, *lastwp, *markedwp;
|
||||||
const char *style;
|
const char *style;
|
||||||
@ -55,21 +56,24 @@ cmd_select_pane_exec(struct cmd *self, struct cmd_q *cmdq)
|
|||||||
wl = cmd_find_window(cmdq, args_get(args, 't'), NULL);
|
wl = cmd_find_window(cmdq, args_get(args, 't'), NULL);
|
||||||
if (wl == NULL)
|
if (wl == NULL)
|
||||||
return (CMD_RETURN_ERROR);
|
return (CMD_RETURN_ERROR);
|
||||||
|
w = wl->window;
|
||||||
|
|
||||||
if (wl->window->last == NULL) {
|
if (w->last == NULL) {
|
||||||
cmdq_error(cmdq, "no last pane");
|
cmdq_error(cmdq, "no last pane");
|
||||||
return (CMD_RETURN_ERROR);
|
return (CMD_RETURN_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (args_has(self->args, 'e'))
|
if (args_has(self->args, 'e'))
|
||||||
wl->window->last->flags &= ~PANE_INPUTOFF;
|
w->last->flags &= ~PANE_INPUTOFF;
|
||||||
else if (args_has(self->args, 'd'))
|
else if (args_has(self->args, 'd'))
|
||||||
wl->window->last->flags |= PANE_INPUTOFF;
|
w->last->flags |= PANE_INPUTOFF;
|
||||||
else {
|
else {
|
||||||
server_unzoom_window(wl->window);
|
server_unzoom_window(w);
|
||||||
window_set_active_pane(wl->window, wl->window->last);
|
window_redraw_active_switch(w, w->last);
|
||||||
server_status_window(wl->window);
|
if (window_set_active_pane(w, w->last)) {
|
||||||
server_redraw_window_borders(wl->window);
|
server_status_window(w);
|
||||||
|
server_redraw_window_borders(w);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return (CMD_RETURN_NORMAL);
|
return (CMD_RETURN_NORMAL);
|
||||||
@ -77,6 +81,7 @@ cmd_select_pane_exec(struct cmd *self, struct cmd_q *cmdq)
|
|||||||
|
|
||||||
if ((wl = cmd_find_pane(cmdq, args_get(args, 't'), &s, &wp)) == NULL)
|
if ((wl = cmd_find_pane(cmdq, args_get(args, 't'), &s, &wp)) == NULL)
|
||||||
return (CMD_RETURN_ERROR);
|
return (CMD_RETURN_ERROR);
|
||||||
|
w = wl->window;
|
||||||
|
|
||||||
if (args_has(args, 'm') || args_has(args, 'M')) {
|
if (args_has(args, 'm') || args_has(args, 'M')) {
|
||||||
if (args_has(args, 'm') && !window_pane_visible(wp))
|
if (args_has(args, 'm') && !window_pane_visible(wp))
|
||||||
@ -135,16 +140,17 @@ cmd_select_pane_exec(struct cmd *self, struct cmd_q *cmdq)
|
|||||||
return (CMD_RETURN_NORMAL);
|
return (CMD_RETURN_NORMAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (wp == wl->window->active)
|
if (wp == w->active)
|
||||||
return (CMD_RETURN_NORMAL);
|
return (CMD_RETURN_NORMAL);
|
||||||
server_unzoom_window(wp->window);
|
server_unzoom_window(wp->window);
|
||||||
if (!window_pane_visible(wp)) {
|
if (!window_pane_visible(wp)) {
|
||||||
cmdq_error(cmdq, "pane not visible");
|
cmdq_error(cmdq, "pane not visible");
|
||||||
return (CMD_RETURN_ERROR);
|
return (CMD_RETURN_ERROR);
|
||||||
}
|
}
|
||||||
if (window_set_active_pane(wl->window, wp)) {
|
window_redraw_active_switch(w, wp);
|
||||||
server_status_window(wl->window);
|
if (window_set_active_pane(w, wp)) {
|
||||||
server_redraw_window_borders(wl->window);
|
server_status_window(w);
|
||||||
|
server_redraw_window_borders(w);
|
||||||
}
|
}
|
||||||
|
|
||||||
return (CMD_RETURN_NORMAL);
|
return (CMD_RETURN_NORMAL);
|
||||||
|
2
log.c
2
log.c
@ -48,8 +48,6 @@ log_open(const char *path)
|
|||||||
|
|
||||||
setvbuf(log_file, NULL, _IOLBF, 0);
|
setvbuf(log_file, NULL, _IOLBF, 0);
|
||||||
event_set_log_callback(log_event_cb);
|
event_set_log_callback(log_event_cb);
|
||||||
|
|
||||||
tzset();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Close logging. */
|
/* Close logging. */
|
||||||
|
12
style.c
12
style.c
@ -252,3 +252,15 @@ style_apply_update(struct grid_cell *gc, struct options *oo, const char *name)
|
|||||||
if (gcp->attr != 0)
|
if (gcp->attr != 0)
|
||||||
gc->attr |= gcp->attr;
|
gc->attr |= gcp->attr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Check if two styles are the same. */
|
||||||
|
int
|
||||||
|
style_equal(const struct grid_cell *gc1, const struct grid_cell *gc2)
|
||||||
|
{
|
||||||
|
return gc1->fg == gc2->fg &&
|
||||||
|
gc1->bg == gc2->bg &&
|
||||||
|
(gc1->flags & ~GRID_FLAG_PADDING) ==
|
||||||
|
(gc2->flags & ~GRID_FLAG_PADDING) &&
|
||||||
|
(gc1->attr & ~GRID_ATTR_CHARSET) ==
|
||||||
|
(gc2->attr & ~GRID_ATTR_CHARSET);
|
||||||
|
}
|
||||||
|
1
tmux.c
1
tmux.c
@ -201,6 +201,7 @@ main(int argc, char **argv)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
setlocale(LC_TIME, "");
|
setlocale(LC_TIME, "");
|
||||||
|
tzset();
|
||||||
|
|
||||||
if (**argv == '-')
|
if (**argv == '-')
|
||||||
flags = CLIENT_LOGIN;
|
flags = CLIENT_LOGIN;
|
||||||
|
6
tmux.h
6
tmux.h
@ -1984,6 +1984,8 @@ struct window_pane *window_get_active_at(struct window *, u_int, u_int);
|
|||||||
struct window_pane *window_find_string(struct window *, const char *);
|
struct window_pane *window_find_string(struct window *, const char *);
|
||||||
int window_has_pane(struct window *, struct window_pane *);
|
int window_has_pane(struct window *, struct window_pane *);
|
||||||
int window_set_active_pane(struct window *, struct window_pane *);
|
int window_set_active_pane(struct window *, struct window_pane *);
|
||||||
|
void window_redraw_active_switch(struct window *,
|
||||||
|
struct window_pane *);
|
||||||
struct window_pane *window_add_pane(struct window *, u_int);
|
struct window_pane *window_add_pane(struct window *, u_int);
|
||||||
void window_resize(struct window *, u_int, u_int);
|
void window_resize(struct window *, u_int, u_int);
|
||||||
int window_zoom(struct window_pane *);
|
int window_zoom(struct window_pane *);
|
||||||
@ -2072,7 +2074,7 @@ extern const char window_clock_table[14][5][5];
|
|||||||
|
|
||||||
/* window-copy.c */
|
/* window-copy.c */
|
||||||
extern const struct window_mode window_copy_mode;
|
extern const struct window_mode window_copy_mode;
|
||||||
void window_copy_init_from_pane(struct window_pane *, u_int);
|
void window_copy_init_from_pane(struct window_pane *, int);
|
||||||
void window_copy_init_for_output(struct window_pane *);
|
void window_copy_init_for_output(struct window_pane *);
|
||||||
void printflike(2, 3) window_copy_add(struct window_pane *, const char *, ...);
|
void printflike(2, 3) window_copy_add(struct window_pane *, const char *, ...);
|
||||||
void window_copy_vadd(struct window_pane *, const char *, va_list);
|
void window_copy_vadd(struct window_pane *, const char *, va_list);
|
||||||
@ -2213,5 +2215,7 @@ void style_apply(struct grid_cell *, struct options *,
|
|||||||
const char *);
|
const char *);
|
||||||
void style_apply_update(struct grid_cell *, struct options *,
|
void style_apply_update(struct grid_cell *, struct options *,
|
||||||
const char *);
|
const char *);
|
||||||
|
int style_equal(const struct grid_cell *,
|
||||||
|
const struct grid_cell *);
|
||||||
|
|
||||||
#endif /* TMUX_H */
|
#endif /* TMUX_H */
|
||||||
|
@ -208,7 +208,7 @@ window_copy_init(struct window_pane *wp)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
window_copy_init_from_pane(struct window_pane *wp, u_int scroll_exit)
|
window_copy_init_from_pane(struct window_pane *wp, int scroll_exit)
|
||||||
{
|
{
|
||||||
struct window_copy_mode_data *data = wp->modedata;
|
struct window_copy_mode_data *data = wp->modedata;
|
||||||
struct screen *s = &data->screen;
|
struct screen *s = &data->screen;
|
||||||
|
24
window.c
24
window.c
@ -422,6 +422,30 @@ window_set_active_pane(struct window *w, struct window_pane *wp)
|
|||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
window_redraw_active_switch(struct window *w, struct window_pane *wp)
|
||||||
|
{
|
||||||
|
const struct grid_cell *agc, *wgc;
|
||||||
|
|
||||||
|
if (wp == w->active)
|
||||||
|
return;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If window-style and window-active-style are the same, we don't need
|
||||||
|
* to redraw panes when switching active panes. Otherwise, if the
|
||||||
|
* active or inactive pane do not have a custom style, they will need
|
||||||
|
* to be redrawn.
|
||||||
|
*/
|
||||||
|
agc = options_get_style(&w->options, "window-active-style");
|
||||||
|
wgc = options_get_style(&w->options, "window-style");
|
||||||
|
if (style_equal(agc, wgc))
|
||||||
|
return;
|
||||||
|
if (style_equal(&grid_default_cell, &w->active->colgc))
|
||||||
|
w->active->flags |= PANE_REDRAW;
|
||||||
|
if (style_equal(&grid_default_cell, &wp->colgc))
|
||||||
|
wp->flags |= PANE_REDRAW;
|
||||||
|
}
|
||||||
|
|
||||||
struct window_pane *
|
struct window_pane *
|
||||||
window_get_active_at(struct window *w, u_int x, u_int y)
|
window_get_active_at(struct window *w, u_int x, u_int y)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user