Add -e flag to capture-pane to include embedded ANSI SGR escape

sequences, from George Nachman.
This commit is contained in:
Nicholas Marriott 2013-03-22 15:51:54 +00:00
parent 8a6fbfa148
commit 8478895eeb
2 changed files with 14 additions and 9 deletions

9
tmux.1
View File

@ -1036,9 +1036,9 @@ By default, it uses the format
but a different format may be specified with but a different format may be specified with
.Fl F . .Fl F .
.It Xo Ic capture-pane .It Xo Ic capture-pane
.Op Fl e
.Op Fl p .Op Fl p
.Op Fl b Ar buffer-index .Op Fl b Ar buffer-index
.Op Fl c Ar target-client
.Op Fl E Ar end-line .Op Fl E Ar end-line
.Op Fl S Ar start-line .Op Fl S Ar start-line
.Op Fl t Ar target-pane .Op Fl t Ar target-pane
@ -1047,11 +1047,12 @@ but a different format may be specified with
Capture the contents of a pane. Capture the contents of a pane.
If If
.Fl p .Fl p
is given, the output goes to is given, the output goes to stdout, otherwise to the buffer specified with
.Ar target-client
stdout, otherwise to the buffer specified with
.Fl b .Fl b
or a new buffer if omitted. or a new buffer if omitted.
If
.Fl e
is given, the output includes escape sequences for text and background attributes.
.Pp .Pp
.Fl S .Fl S
and and

10
tmux.h
View File

@ -1369,6 +1369,8 @@ struct cmd_ctx {
struct client *curclient; struct client *curclient;
struct client *cmdclient; struct client *cmdclient;
int references;
struct msg_command_data *msgdata; struct msg_command_data *msgdata;
/* gcc2 doesn't understand attributes on function pointers... */ /* gcc2 doesn't understand attributes on function pointers... */
@ -1714,13 +1716,14 @@ long long args_strtonum(
struct args *, u_char, long long, long long, char **); struct args *, u_char, long long, long long, char **);
/* cmd.c */ /* cmd.c */
struct cmd_ctx *cmd_get_ctx(void);
void cmd_free_ctx(struct cmd_ctx *);
void cmd_ref_ctx(struct cmd_ctx *);
int cmd_pack_argv(int, char **, char *, size_t); int cmd_pack_argv(int, char **, char *, size_t);
int cmd_unpack_argv(char *, size_t, int, char ***); int cmd_unpack_argv(char *, size_t, int, char ***);
char **cmd_copy_argv(int, char *const *); char **cmd_copy_argv(int, char *const *);
void cmd_free_argv(int, char **); void cmd_free_argv(int, char **);
struct cmd *cmd_parse(int, char **, char **); struct cmd *cmd_parse(int, char **, char **);
enum cmd_retval cmd_exec(struct cmd *, struct cmd_ctx *);
void cmd_free(struct cmd *);
size_t cmd_print(struct cmd *, char *, size_t); size_t cmd_print(struct cmd *, char *, size_t);
struct session *cmd_current_session(struct cmd_ctx *, int); struct session *cmd_current_session(struct cmd_ctx *, int);
struct client *cmd_current_client(struct cmd_ctx *); struct client *cmd_current_client(struct cmd_ctx *);
@ -1974,7 +1977,8 @@ void grid_clear(struct grid *, u_int, u_int, u_int, u_int);
void grid_clear_lines(struct grid *, u_int, u_int); void grid_clear_lines(struct grid *, u_int, u_int);
void grid_move_lines(struct grid *, u_int, u_int, u_int); void grid_move_lines(struct grid *, u_int, u_int, u_int);
void grid_move_cells(struct grid *, u_int, u_int, u_int, u_int); void grid_move_cells(struct grid *, u_int, u_int, u_int, u_int);
char *grid_string_cells(struct grid *, u_int, u_int, u_int); char *grid_string_cells(struct grid *, u_int, u_int, u_int,
struct grid_cell **, int);
void grid_duplicate_lines( void grid_duplicate_lines(
struct grid *, u_int, struct grid *, u_int, u_int); struct grid *, u_int, struct grid *, u_int, u_int);
u_int grid_reflow(struct grid *, struct grid *, u_int); u_int grid_reflow(struct grid *, struct grid *, u_int);