diff options
author | Nicholas Marriott <nicm@openbsd.org> | 2010-06-28 22:10:42 +0000 |
---|---|---|
committer | Nicholas Marriott <nicm@openbsd.org> | 2010-06-28 22:10:42 +0000 |
commit | 76bbdeb586ad93cfb16bd12db865b4c672a9168e (patch) | |
tree | 52ecf7ef2f819396844962ffaf1edbcb4e3bf6b1 /cmd-save-buffer.c | |
parent | 07a71fd432df5873515da82d2d620ec0d986b558 (diff) | |
download | rtmux-76bbdeb586ad93cfb16bd12db865b4c672a9168e.tar.gz rtmux-76bbdeb586ad93cfb16bd12db865b4c672a9168e.tar.bz2 rtmux-76bbdeb586ad93cfb16bd12db865b4c672a9168e.zip |
Send all three of stdin, stdout, stderr from the client to the server, so that
commands can directly make use of them. This means that load-buffer and
save-buffer can have "-" as the file to read from stdin or write to stdout.
This is a protocol version bump so the tmux server will need to be restarted
after upgrade (or an older client used).
Diffstat (limited to 'cmd-save-buffer.c')
-rw-r--r-- | cmd-save-buffer.c | 33 |
1 files changed, 22 insertions, 11 deletions
diff --git a/cmd-save-buffer.c b/cmd-save-buffer.c index 22bc44f8..57c3f5f0 100644 --- a/cmd-save-buffer.c +++ b/cmd-save-buffer.c @@ -48,7 +48,7 @@ cmd_save_buffer_exec(struct cmd *self, struct cmd_ctx *ctx) struct session *s; struct paste_buffer *pb; mode_t mask; - FILE *f; + FILE *f, *close_f; if ((s = cmd_find_session(ctx, data->target)) == NULL) return (-1); @@ -65,15 +65,25 @@ cmd_save_buffer_exec(struct cmd *self, struct cmd_ctx *ctx) } } - mask = umask(S_IRWXG | S_IRWXO); - if (cmd_check_flag(data->chflags, 'a')) - f = fopen(data->arg, "ab"); - else - f = fopen(data->arg, "wb"); - umask(mask); - if (f == NULL) { - ctx->error(ctx, "%s: %s", data->arg, strerror(errno)); - return (-1); + if (strcmp(data->arg, "-") == 0) { + if (ctx->cmdclient == NULL) { + ctx->error(ctx, "%s: can't write to stdout", data->arg); + return (-1); + } + f = ctx->cmdclient->stdout_file; + close_f = NULL; + } else { + mask = umask(S_IRWXG | S_IRWXO); + if (cmd_check_flag(data->chflags, 'a')) + f = fopen(data->arg, "ab"); + else + f = fopen(data->arg, "wb"); + umask(mask); + if (f == NULL) { + ctx->error(ctx, "%s: %s", data->arg, strerror(errno)); + return (-1); + } + close_f = f; } if (fwrite(pb->data, 1, pb->size, f) != pb->size) { @@ -82,7 +92,8 @@ cmd_save_buffer_exec(struct cmd *self, struct cmd_ctx *ctx) return (-1); } - fclose(f); + if (close_f != NULL) + fclose(close_f); return (0); } |