mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
clipboard: support separate '+' and '*' clipboards
This commit is contained in:
parent
8fc710110f
commit
c1854d2433
@ -1,8 +1,8 @@
|
||||
" The clipboard provider uses shell commands to communicate with the clipboard.
|
||||
" The provider function will only be registered if one of the supported
|
||||
" commands are available.
|
||||
let s:copy = ''
|
||||
let s:paste = ''
|
||||
let s:copy = {}
|
||||
let s:paste = {}
|
||||
|
||||
function! s:try_cmd(cmd, ...)
|
||||
let out = a:0 ? systemlist(a:cmd, a:1) : systemlist(a:cmd)
|
||||
@ -14,14 +14,20 @@ function! s:try_cmd(cmd, ...)
|
||||
endfunction
|
||||
|
||||
if executable('pbcopy')
|
||||
let s:copy = 'pbcopy'
|
||||
let s:paste = 'pbpaste'
|
||||
elseif executable('xsel')
|
||||
let s:copy = 'xsel -i -b'
|
||||
let s:paste = 'xsel -o -b'
|
||||
let s:copy['+'] = 'pbcopy'
|
||||
let s:paste['+'] = 'pbpaste'
|
||||
let s:copy['*'] = s:copy['+']
|
||||
let s:paste['*'] = s:paste['+']
|
||||
elseif executable('xclip')
|
||||
let s:copy = 'xclip -i -selection clipboard'
|
||||
let s:paste = 'xclip -o -selection clipboard'
|
||||
let s:copy['+'] = 'xclip -i -selection clipboard'
|
||||
let s:paste['+'] = 'xclip -o -selection clipboard'
|
||||
let s:copy['*'] = 'xclip -i -selection primary'
|
||||
let s:paste['*'] = 'xclip -o -selection primary'
|
||||
elseif executable('xsel')
|
||||
let s:copy['+'] = 'xsel -i -b'
|
||||
let s:paste['+'] = 'xsel -o -b'
|
||||
let s:copy['*'] = 'xsel -i -p'
|
||||
let s:paste['*'] = 'xsel -o -p'
|
||||
else
|
||||
echom 'clipboard: No shell command for communicating with the clipboard found.'
|
||||
finish
|
||||
@ -29,14 +35,14 @@ endif
|
||||
|
||||
let s:clipboard = {}
|
||||
|
||||
function! s:clipboard.get(...)
|
||||
return s:try_cmd(s:paste)
|
||||
function! s:clipboard.get(reg)
|
||||
return s:try_cmd(s:paste[a:reg])
|
||||
endfunction
|
||||
|
||||
function! s:clipboard.set(...)
|
||||
call s:try_cmd(s:copy, a:1)
|
||||
function! s:clipboard.set(lines, reg)
|
||||
call s:try_cmd(s:copy[a:reg], a:lines)
|
||||
endfunction
|
||||
|
||||
function! provider#clipboard#Call(method, args)
|
||||
return s:clipboard[a:method](a:args)
|
||||
return call(s:clipboard[a:method],a:args,s:clipboard)
|
||||
endfunction
|
||||
|
@ -5118,6 +5118,20 @@ void list_append_tv(list_T *l, typval_T *tv)
|
||||
list_append(l, li);
|
||||
}
|
||||
|
||||
/*
|
||||
* Add a list to a list.
|
||||
*/
|
||||
void list_append_list(list_T *list, list_T *itemlist)
|
||||
{
|
||||
listitem_T *li = listitem_alloc();
|
||||
|
||||
li->li_tv.v_type = VAR_LIST;
|
||||
li->li_tv.v_lock = 0;
|
||||
li->li_tv.vval.v_list = itemlist;
|
||||
list_append(list, li);
|
||||
++list->lv_refcount;
|
||||
}
|
||||
|
||||
/*
|
||||
* Add a dictionary to a list. Used by getqflist().
|
||||
*/
|
||||
|
@ -5244,7 +5244,11 @@ static void get_clipboard(int name)
|
||||
|
||||
struct yankreg *reg = &y_regs[CLIP_REGISTER];
|
||||
free_register(reg);
|
||||
|
||||
list_T *args = list_alloc();
|
||||
char_u regname = (char_u)name;
|
||||
list_append_string(args, ®name, 1);
|
||||
|
||||
typval_T result = eval_call_provider("clipboard", "get", args);
|
||||
|
||||
if (result.v_type != VAR_LIST) {
|
||||
@ -5294,6 +5298,7 @@ static void set_clipboard(int name)
|
||||
if (!name && p_unc) {
|
||||
// copy from the unnamed register
|
||||
copy_register(reg, &y_regs[0]);
|
||||
name = '+';
|
||||
}
|
||||
|
||||
list_T *lines = list_alloc();
|
||||
@ -5302,5 +5307,11 @@ static void set_clipboard(int name)
|
||||
list_append_string(lines, reg->y_array[i], -1);
|
||||
}
|
||||
|
||||
(void)eval_call_provider("clipboard", "set", lines);
|
||||
list_T *args = list_alloc();
|
||||
list_append_list(args, lines);
|
||||
|
||||
char_u regname = (char_u)name;
|
||||
list_append_string(args, ®name, 1);
|
||||
|
||||
(void)eval_call_provider("clipboard", "set", args);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user