aboutsummaryrefslogtreecommitdiff
path: root/cmd-run-shell.c
diff options
context:
space:
mode:
authorJosh Rahm <rahm@google.com>2022-07-21 15:53:59 -0600
committerJosh Rahm <rahm@google.com>2022-07-21 15:53:59 -0600
commitb11548e3db4361cd8312ffbd27472823bdab4d62 (patch)
treea84b5cf79fb41bb60b6495c1a346bb360b224604 /cmd-run-shell.c
parent88ebf5544e995d85b2f1416a216ac7f44f719eed (diff)
parentab1d18d00febe161080b8e81331861481110809f (diff)
downloadrtmux-b11548e3db4361cd8312ffbd27472823bdab4d62.tar.gz
rtmux-b11548e3db4361cd8312ffbd27472823bdab4d62.tar.bz2
rtmux-b11548e3db4361cd8312ffbd27472823bdab4d62.zip
Merge remote-tracking branch 'origin/master' into rahm
Diffstat (limited to 'cmd-run-shell.c')
-rw-r--r--cmd-run-shell.c22
1 files changed, 9 insertions, 13 deletions
diff --git a/cmd-run-shell.c b/cmd-run-shell.c
index bf43d313..560eface 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 && cdata->client != 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
@@ -188,7 +183,7 @@ cmd_run_shell_timer(__unused int fd, __unused short events, void* arg)
cmd_run_shell_free(cdata);
return;
}
- if (job_run(cmd, 0, NULL, cdata->s, cdata->cwd, NULL,
+ if (job_run(cmd, 0, NULL, NULL, cdata->s, cdata->cwd, NULL,
cmd_run_shell_callback, cmd_run_shell_free, cdata,
cdata->flags, -1, -1) == NULL)
cmd_run_shell_free(cdata);
@@ -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);
}