From 7b819357ff5a0f014527a94ce0abb98e472ea358 Mon Sep 17 00:00:00 2001 From: nicm Date: Tue, 12 Mar 2019 12:49:46 +0000 Subject: [PATCH 1/4] Tweak target debug logging. --- cmd-find.c | 39 ++++++++++++++++++++++++++++++--------- 1 file changed, 30 insertions(+), 9 deletions(-) diff --git a/cmd-find.c b/cmd-find.c index fe5bb3e0..3cee9d14 100644 --- a/cmd-find.c +++ b/cmd-find.c @@ -971,7 +971,7 @@ cmd_find_target(struct cmd_find_state *fs, struct cmdq_item *item, { struct mouse_event *m; struct cmd_find_state current; - char *colon, *period, *copy = NULL; + char *colon, *period, *copy = NULL, tmp[256]; const char *session, *window, *pane, *s; int window_only = 0, pane_only = 0; @@ -988,11 +988,25 @@ cmd_find_target(struct cmd_find_state *fs, struct cmdq_item *item, s = "session"; else s = "unknown"; - if (target == NULL) - log_debug("%s: target none, type %s", __func__, s); - else - log_debug("%s: target %s, type %s", __func__, target, s); - log_debug("%s: item %p, flags %#x", __func__, item, flags); + *tmp = '\0'; + if (flags & CMD_FIND_PREFER_UNATTACHED) + strlcat(tmp, "PREFER_UNATTACHED,", sizeof tmp); + if (flags & CMD_FIND_QUIET) + strlcat(tmp, "QUIET,", sizeof tmp); + if (flags & CMD_FIND_WINDOW_INDEX) + strlcat(tmp, "WINDOW_INDEX,", sizeof tmp); + if (flags & CMD_FIND_DEFAULT_MARKED) + strlcat(tmp, "DEFAULT_MARKED,", sizeof tmp); + if (flags & CMD_FIND_EXACT_SESSION) + strlcat(tmp, "EXACT_SESSION,", sizeof tmp); + if (flags & CMD_FIND_EXACT_WINDOW) + strlcat(tmp, "EXACT_WINDOW,", sizeof tmp); + if (flags & CMD_FIND_CANFAIL) + strlcat(tmp, "CANFAIL,", sizeof tmp); + if (*tmp != '\0') + tmp[strlen(tmp) - 1] = '\0'; + log_debug("%s: target %s, type %s, item %p, flags %s", __func__, + target == NULL ? "none" : target, s, item, tmp); /* Clear new state. */ cmd_find_clear_state(fs, flags); @@ -1132,9 +1146,16 @@ cmd_find_target(struct cmd_find_state *fs, struct cmdq_item *item, if (pane != NULL) pane = cmd_find_map_table(cmd_find_pane_table, pane); - log_debug("%s: target %s (flags %#x): session=%s, window=%s, pane=%s", - __func__, target, flags, session == NULL ? "none" : session, - window == NULL ? "none" : window, pane == NULL ? "none" : pane); + if (session != NULL || window != NULL || pane != NULL) { + log_debug("%s: target %s is %s%s%s%s%s%s", + __func__, target, + session == NULL ? "" : "session ", + session == NULL ? "" : session, + window == NULL ? "" : "window ", + window == NULL ? "" : window, + pane == NULL ? "" : "pane ", + pane == NULL ? "" : pane); + } /* No pane is allowed if want an index. */ if (pane != NULL && (flags & CMD_FIND_WINDOW_INDEX)) { From 7804fa1b82b14a28a6bfe72d5ee7aebd03584333 Mon Sep 17 00:00:00 2001 From: nicm Date: Tue, 12 Mar 2019 12:58:40 +0000 Subject: [PATCH 2/4] Revert to not clearing history on RIS, apparently some bootloaders send this and it doesn't really do any harm. --- input.c | 1 - 1 file changed, 1 deletion(-) diff --git a/input.c b/input.c index 049b82e1..73bd099b 100644 --- a/input.c +++ b/input.c @@ -1197,7 +1197,6 @@ input_esc_dispatch(struct input_ctx *ictx) window_pane_reset_palette(ictx->wp); input_reset_cell(ictx); screen_write_reset(sctx); - screen_write_clearhistory(sctx); break; case INPUT_ESC_IND: screen_write_linefeed(sctx, 0, ictx->cell.cell.bg); From 3f0efc050aabcc68115f37764d49c1c73d98437f Mon Sep 17 00:00:00 2001 From: nicm Date: Tue, 12 Mar 2019 13:14:04 +0000 Subject: [PATCH 3/4] When asked for a window index, return it even if the window exists. --- cmd-find.c | 1 + 1 file changed, 1 insertion(+) diff --git a/cmd-find.c b/cmd-find.c index 3cee9d14..2711c26b 100644 --- a/cmd-find.c +++ b/cmd-find.c @@ -454,6 +454,7 @@ cmd_find_get_window_with_session(struct cmd_find_state *fs, const char *window) if (errstr == NULL) { fs->wl = winlink_find_by_index(&fs->s->windows, idx); if (fs->wl != NULL) { + fs->idx = fs->wl->idx; fs->w = fs->wl->window; return (0); } From 303d20a758a2779f76854b6df10f8764e44fc407 Mon Sep 17 00:00:00 2001 From: nicm Date: Tue, 12 Mar 2019 13:14:14 +0000 Subject: [PATCH 4/4] Fix wrapping after origin mode change. --- screen-write.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/screen-write.c b/screen-write.c index e8aa0973..a6e78f42 100644 --- a/screen-write.c +++ b/screen-write.c @@ -75,7 +75,7 @@ screen_write_set_cursor(struct screen_write_ctx *ctx, int cx, int cy) return; if (cx != -1) { - if ((u_int)cx > screen_size_x(s) - 1) + if ((u_int)cx > screen_size_x(s)) /* allow last column */ cx = screen_size_x(s) - 1; s->cx = cx; } @@ -1045,6 +1045,11 @@ screen_write_cursormove(struct screen_write_ctx *ctx, u_int px, u_int py) py += s->rupper; } + if (px > screen_size_x(s) - 1) + px = screen_size_x(s) - 1; + if (py > screen_size_y(s) - 1) + py = screen_size_y(s) - 1; + screen_write_set_cursor(ctx, px, py); }