aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/ops.c
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2016-01-01 14:38:17 -0500
committerJustin M. Keyes <justinkz@gmail.com>2016-01-01 14:38:17 -0500
commitf1344bc2198c4e433dedbc8b0662ba90cb5eaf1c (patch)
treef5d48caeb217459f82332555e852216569d30ecb /src/nvim/ops.c
parentdf4ac79761162313de4e27a265044125062013cf (diff)
parent3fd62f961294d11fff5754a3c597e982b54ca74a (diff)
downloadrneovim-f1344bc2198c4e433dedbc8b0662ba90cb5eaf1c.tar.gz
rneovim-f1344bc2198c4e433dedbc8b0662ba90cb5eaf1c.tar.bz2
rneovim-f1344bc2198c4e433dedbc8b0662ba90cb5eaf1c.zip
Merge pull request #3903 from justinmk/vim-7.4.605
vim-patch:7.4.605
Diffstat (limited to 'src/nvim/ops.c')
-rw-r--r--src/nvim/ops.c40
1 files changed, 30 insertions, 10 deletions
diff --git a/src/nvim/ops.c b/src/nvim/ops.c
index 707d20157a..c3d968ca51 100644
--- a/src/nvim/ops.c
+++ b/src/nvim/ops.c
@@ -703,17 +703,16 @@ char_u *get_expr_line_src(void)
/// @param writing allow only writable registers
bool valid_yank_reg(int regname, bool writing)
{
- if ( (regname > 0 && ASCII_ISALNUM(regname))
- || (!writing && vim_strchr((char_u *)
- "/.%#:="
- , regname) != NULL)
- || regname == '"'
- || regname == '-'
- || regname == '_'
- || regname == '*'
- || regname == '+'
- )
+ if ((regname > 0 && ASCII_ISALNUM(regname))
+ || (!writing && vim_strchr((char_u *) "/.%:=" , regname) != NULL)
+ || regname == '#'
+ || regname == '"'
+ || regname == '-'
+ || regname == '_'
+ || regname == '*'
+ || regname == '+') {
return true;
+ }
return false;
}
@@ -4658,6 +4657,27 @@ void write_reg_contents_ex(int name,
return;
}
+ if (name == '#') {
+ buf_T *buf;
+
+ if (ascii_isdigit(*str)) {
+ int num = atoi((char *)str);
+
+ buf = buflist_findnr(num);
+ if (buf == NULL) {
+ EMSGN(_(e_nobufnr), (long)num);
+ }
+ } else {
+ buf = buflist_findnr(buflist_findpat(str, str + STRLEN(str),
+ true, false, false));
+ }
+ if (buf == NULL) {
+ return;
+ }
+ curwin->w_alt_fnum = buf->b_fnum;
+ return;
+ }
+
if (name == '=') {
size_t offset = 0;
size_t totlen = (size_t) len;