aboutsummaryrefslogtreecommitdiff
path: root/runtime
diff options
context:
space:
mode:
authorBjörn Linse <bjorn.linse@gmail.com>2021-07-01 15:47:21 +0200
committerGitHub <noreply@github.com>2021-07-01 15:47:21 +0200
commita50a3a12d6dc877e63cc5645c68e15c512517ffb (patch)
tree363d0f219cece22fa513ddeb14e6a4c554887db5 /runtime
parentf35a5f2efc32b508ff5fc7d55b31a5bb7facfa17 (diff)
parent47a08ec72ed27ef0ba2519865ebcedf9f62abe8e (diff)
downloadrneovim-a50a3a12d6dc877e63cc5645c68e15c512517ffb.tar.gz
rneovim-a50a3a12d6dc877e63cc5645c68e15c512517ffb.tar.bz2
rneovim-a50a3a12d6dc877e63cc5645c68e15c512517ffb.zip
Merge pull request #14848 from shadmansaleh/fixup/block_paste_clipboard
fix(clipboard): Fix block paste from system clipboard not working properly
Diffstat (limited to 'runtime')
-rw-r--r--runtime/autoload/provider/clipboard.vim12
1 files changed, 11 insertions, 1 deletions
diff --git a/runtime/autoload/provider/clipboard.vim b/runtime/autoload/provider/clipboard.vim
index 07f37d604f..dea79f21f0 100644
--- a/runtime/autoload/provider/clipboard.vim
+++ b/runtime/autoload/provider/clipboard.vim
@@ -156,7 +156,14 @@ function! s:clipboard.get(reg) abort
elseif s:selections[a:reg].owner > 0
return s:selections[a:reg].data
end
- return s:try_cmd(s:paste[a:reg])
+
+ let clipboard_data = s:try_cmd(s:paste[a:reg])
+ if match(&clipboard, '\v(unnamed|unnamedplus)') >= 0 && get(s:selections[a:reg].data, 0, []) == clipboard_data
+ " When system clipboard return is same as our cache return the cache
+ " as it contains regtype information
+ return s:selections[a:reg].data
+ end
+ return clipboard_data
endfunction
function! s:clipboard.set(lines, regtype, reg) abort
@@ -175,6 +182,9 @@ function! s:clipboard.set(lines, regtype, reg) abort
if s:cache_enabled == 0
call s:try_cmd(s:copy[a:reg], a:lines)
+ "Cache it anyway we can compare it later to get regtype of the yank
+ let s:selections[a:reg] = copy(s:selection)
+ let s:selections[a:reg].data = [a:lines, a:regtype]
return 0
end