diff options
author | Nicholas Marriott <nicm@openbsd.org> | 2009-07-11 19:14:56 +0000 |
---|---|---|
committer | Nicholas Marriott <nicm@openbsd.org> | 2009-07-11 19:14:56 +0000 |
commit | 2f7198246e1074e0ff132036182c5a4050506073 (patch) | |
tree | 80ca083809957b6ecb99d60376fd5a3c6717ede6 /cmd-generic.c | |
parent | 289320a9b19e6be855756e54a545615026b099f8 (diff) |
When pasting, translate \n into \r. This matches xterm and putty's behaviour,
and makes emacs happy when pasting into some modes. A new -r (raw) flag to
paste-buffer pastes without the translation.
From Kalle Olavi Niemitalo, thanks!
Diffstat (limited to 'cmd-generic.c')
-rw-r--r-- | cmd-generic.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/cmd-generic.c b/cmd-generic.c index 01254a06..1b2e17a9 100644 --- a/cmd-generic.c +++ b/cmd-generic.c @@ -23,9 +23,9 @@ #include "tmux.h" -#define CMD_FLAGS "adDgkuU" +#define CMD_FLAGS "adDgkruU" #define CMD_FLAGMASK (CMD_AFLAG|CMD_DFLAG|CMD_BIGDFLAG|CMD_GFLAG|CMD_KFLAG| \ - CMD_UFLAG|CMD_BIGUFLAG) + CMD_RFLAG|CMD_UFLAG|CMD_BIGUFLAG) int cmd_do_flags(int, int, int *); size_t cmd_print_flags(char *, size_t, size_t, int); @@ -73,6 +73,12 @@ cmd_do_flags(int opt, int iflags, int *oflags) return (0); } return (-1); + case 'r': + if (iflags & CMD_RFLAG) { + (*oflags) |= CMD_RFLAG; + return (0); + } + return (-1); case 'u': if (iflags & CMD_UFLAG) { (*oflags) |= CMD_UFLAG; @@ -107,6 +113,8 @@ cmd_print_flags(char *buf, size_t len, size_t off, int flags) off += xsnprintf(buf + off, len - off, "g"); if (off < len && flags & CMD_KFLAG) off += xsnprintf(buf + off, len - off, "k"); + if (off < len && flags & CMD_RFLAG) + off += xsnprintf(buf + off, len - off, "r"); if (off < len && flags & CMD_UFLAG) off += xsnprintf(buf + off, len - off, "u"); if (off < len && flags & CMD_BIGUFLAG) |