mirror of
https://github.com/tmux/tmux.git
synced 2025-01-23 06:03:43 +00:00
Improve logging of screen mode changes.
This commit is contained in:
parent
32c97a7f2f
commit
2e7ec8c0b9
@ -769,6 +769,9 @@ screen_write_mode_set(struct screen_write_ctx *ctx, int mode)
|
|||||||
struct screen *s = ctx->s;
|
struct screen *s = ctx->s;
|
||||||
|
|
||||||
s->mode |= mode;
|
s->mode |= mode;
|
||||||
|
|
||||||
|
if (log_get_level() != 0)
|
||||||
|
log_debug("%s: %s", __func__, screen_mode_to_string(mode));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Clear a mode. */
|
/* Clear a mode. */
|
||||||
@ -778,6 +781,9 @@ screen_write_mode_clear(struct screen_write_ctx *ctx, int mode)
|
|||||||
struct screen *s = ctx->s;
|
struct screen *s = ctx->s;
|
||||||
|
|
||||||
s->mode &= ~mode;
|
s->mode &= ~mode;
|
||||||
|
|
||||||
|
if (log_get_level() != 0)
|
||||||
|
log_debug("%s: %s", __func__, screen_mode_to_string(mode));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Cursor up by ny. */
|
/* Cursor up by ny. */
|
||||||
|
52
screen.c
52
screen.c
@ -155,8 +155,8 @@ screen_reset_tabs(struct screen *s)
|
|||||||
void
|
void
|
||||||
screen_set_cursor_style(struct screen *s, u_int style)
|
screen_set_cursor_style(struct screen *s, u_int style)
|
||||||
{
|
{
|
||||||
switch (style)
|
log_debug("%s: new %u, was %u", __func__, style, s->cstyle);
|
||||||
{
|
switch (style) {
|
||||||
case 0:
|
case 0:
|
||||||
s->cstyle = SCREEN_CURSOR_DEFAULT;
|
s->cstyle = SCREEN_CURSOR_DEFAULT;
|
||||||
break;
|
break;
|
||||||
@ -652,3 +652,51 @@ screen_alternate_off(struct screen *s, struct grid_cell *gc, int cursor)
|
|||||||
if (s->cy > screen_size_y(s) - 1)
|
if (s->cy > screen_size_y(s) - 1)
|
||||||
s->cy = screen_size_y(s) - 1;
|
s->cy = screen_size_y(s) - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Get mode as a string. */
|
||||||
|
const char *
|
||||||
|
screen_mode_to_string(int mode)
|
||||||
|
{
|
||||||
|
static char tmp[1024];
|
||||||
|
|
||||||
|
if (mode == 0)
|
||||||
|
return "NONE";
|
||||||
|
if (mode == ALL_MODES)
|
||||||
|
return "ALL";
|
||||||
|
|
||||||
|
*tmp = '\0';
|
||||||
|
if (mode & MODE_CURSOR)
|
||||||
|
strlcat(tmp, "CURSOR,", sizeof tmp);
|
||||||
|
if (mode & MODE_INSERT)
|
||||||
|
strlcat(tmp, "INSERT,", sizeof tmp);
|
||||||
|
if (mode & MODE_KCURSOR)
|
||||||
|
strlcat(tmp, "KCURSOR,", sizeof tmp);
|
||||||
|
if (mode & MODE_KKEYPAD)
|
||||||
|
strlcat(tmp, "KKEYPAD,", sizeof tmp);
|
||||||
|
if (mode & MODE_WRAP)
|
||||||
|
strlcat(tmp, "WRAP,", sizeof tmp);
|
||||||
|
if (mode & MODE_MOUSE_STANDARD)
|
||||||
|
strlcat(tmp, "STANDARD,", sizeof tmp);
|
||||||
|
if (mode & MODE_MOUSE_BUTTON)
|
||||||
|
strlcat(tmp, "BUTTON,", sizeof tmp);
|
||||||
|
if (mode & MODE_BLINKING)
|
||||||
|
strlcat(tmp, "BLINKING,", sizeof tmp);
|
||||||
|
if (mode & MODE_MOUSE_UTF8)
|
||||||
|
strlcat(tmp, "UTF8,", sizeof tmp);
|
||||||
|
if (mode & MODE_MOUSE_SGR)
|
||||||
|
strlcat(tmp, "SGR,", sizeof tmp);
|
||||||
|
if (mode & MODE_BRACKETPASTE)
|
||||||
|
strlcat(tmp, "BRACKETPASTE,", sizeof tmp);
|
||||||
|
if (mode & MODE_FOCUSON)
|
||||||
|
strlcat(tmp, "FOCUSON,", sizeof tmp);
|
||||||
|
if (mode & MODE_MOUSE_ALL)
|
||||||
|
strlcat(tmp, "ALL,", sizeof tmp);
|
||||||
|
if (mode & MODE_ORIGIN)
|
||||||
|
strlcat(tmp, "ORIGIN,", sizeof tmp);
|
||||||
|
if (mode & MODE_CRLF)
|
||||||
|
strlcat(tmp, "CRLF,", sizeof tmp);
|
||||||
|
if (mode & MODE_KEXTENDED)
|
||||||
|
strlcat(tmp, "KEXTENDED,", sizeof tmp);
|
||||||
|
tmp[strlen (tmp) - 1] = '\0';
|
||||||
|
return (tmp);
|
||||||
|
}
|
||||||
|
@ -1691,7 +1691,10 @@ server_client_reset_state(struct client *c)
|
|||||||
s = wp->screen;
|
s = wp->screen;
|
||||||
if (s != NULL)
|
if (s != NULL)
|
||||||
mode = s->mode;
|
mode = s->mode;
|
||||||
log_debug("%s: client %s mode %x", __func__, c->name, mode);
|
if (log_get_level() != 0) {
|
||||||
|
log_debug("%s: client %s mode %s", __func__, c->name,
|
||||||
|
screen_mode_to_string(mode));
|
||||||
|
}
|
||||||
|
|
||||||
/* Reset region and margin. */
|
/* Reset region and margin. */
|
||||||
tty_region_off(tty);
|
tty_region_off(tty);
|
||||||
|
1
tmux.h
1
tmux.h
@ -2750,6 +2750,7 @@ void screen_select_cell(struct screen *, struct grid_cell *,
|
|||||||
const struct grid_cell *);
|
const struct grid_cell *);
|
||||||
void screen_alternate_on(struct screen *, struct grid_cell *, int);
|
void screen_alternate_on(struct screen *, struct grid_cell *, int);
|
||||||
void screen_alternate_off(struct screen *, struct grid_cell *, int);
|
void screen_alternate_off(struct screen *, struct grid_cell *, int);
|
||||||
|
const char *screen_mode_to_string(int);
|
||||||
|
|
||||||
/* window.c */
|
/* window.c */
|
||||||
extern struct windows windows;
|
extern struct windows windows;
|
||||||
|
8
tty.c
8
tty.c
@ -665,8 +665,12 @@ tty_update_mode(struct tty *tty, int mode, struct screen *s)
|
|||||||
mode &= ~MODE_CURSOR;
|
mode &= ~MODE_CURSOR;
|
||||||
|
|
||||||
changed = mode ^ tty->mode;
|
changed = mode ^ tty->mode;
|
||||||
if (changed != 0)
|
if (log_get_level() != 0 && changed != 0) {
|
||||||
log_debug("%s: update mode %x to %x", c->name, tty->mode, mode);
|
log_debug("%s: current mode %s", c->name,
|
||||||
|
screen_mode_to_string(tty->mode));
|
||||||
|
log_debug("%s: setting mode %s", c->name,
|
||||||
|
screen_mode_to_string(mode));
|
||||||
|
}
|
||||||
|
|
||||||
if (s != NULL) {
|
if (s != NULL) {
|
||||||
if (strcmp(s->ccolour, tty->ccolour) != 0)
|
if (strcmp(s->ccolour, tty->ccolour) != 0)
|
||||||
|
Loading…
Reference in New Issue
Block a user