diff options
author | nicm <nicm> | 2022-05-30 13:00:18 +0000 |
---|---|---|
committer | nicm <nicm> | 2022-05-30 13:00:18 +0000 |
commit | cd89000c1d75d0cfec28cf7e81b06f80a43ea093 (patch) | |
tree | 3d7fa0df54cb6f87fa5f53a35a86ebe623f278cc /cmd-run-shell.c | |
parent | 20b0b38cf47112c0219b5bd041d61c5a28fae0fd (diff) | |
download | rtmux-cd89000c1d75d0cfec28cf7e81b06f80a43ea093.tar.gz rtmux-cd89000c1d75d0cfec28cf7e81b06f80a43ea093.tar.bz2 rtmux-cd89000c1d75d0cfec28cf7e81b06f80a43ea093.zip |
Add a way for lines added to copy mode to be passed through the parser
to handle escape sequences and use it for run-shell, GitHub issue 3156.
Diffstat (limited to 'cmd-run-shell.c')
-rw-r--r-- | cmd-run-shell.c | 20 |
1 files changed, 8 insertions, 12 deletions
diff --git a/cmd-run-shell.c b/cmd-run-shell.c index 5e914e65..db5774d2 100644 --- a/cmd-run-shell.c +++ b/cmd-run-shell.c @@ -84,22 +84,17 @@ cmd_run_shell_print(struct job *job, const char *msg) if (cdata->wp_id != -1) wp = window_pane_find_by_id(cdata->wp_id); - if (wp == NULL) { - if (cdata->item != NULL) { - cmdq_print(cdata->item, "%s", msg); - return; - } - if (cmd_find_from_nothing(&fs, 0) != 0) - return; + if (wp == NULL && cdata->item != NULL) + wp = server_client_get_pane(cdata->client); + if (wp == NULL && cmd_find_from_nothing(&fs, 0) == 0) wp = fs.wp; - if (wp == NULL) - return; - } + if (wp == NULL) + return; wme = TAILQ_FIRST(&wp->modes); if (wme == NULL || wme->mode != &window_view_mode) window_pane_set_mode(wp, NULL, &window_view_mode, NULL, NULL); - window_copy_add(wp, "%s", msg); + window_copy_add(wp, 1, "%s", msg); } static enum cmd_retval @@ -227,7 +222,8 @@ cmd_run_shell_callback(struct job *job) int retcode, status; do { - if ((line = evbuffer_readline(event->input)) != NULL) { + line = evbuffer_readln(event->input, NULL, EVBUFFER_EOL_LF); + if (line != NULL) { cmd_run_shell_print(job, line); free(line); } |