diff options
author | Jacques Germishuys <jacquesg@striata.com> | 2019-11-04 17:33:07 +0000 |
---|---|---|
committer | Jan Edmund Lazo <jan.lazo@mail.utoronto.ca> | 2020-01-20 19:43:59 -0500 |
commit | c25b5a1576eca912671d5f2fe47043055fbca2b0 (patch) | |
tree | 4bdb269f52e9e04be6d4e27572aa113966874cba | |
parent | 4faf30de3ea72bd188c8894eb10f0c971ff28e90 (diff) | |
download | rneovim-c25b5a1576eca912671d5f2fe47043055fbca2b0.tar.gz rneovim-c25b5a1576eca912671d5f2fe47043055fbca2b0.tar.bz2 rneovim-c25b5a1576eca912671d5f2fe47043055fbca2b0.zip |
remote plugins: add support for perl hosts
-rw-r--r-- | runtime/autoload/provider/perl.vim | 73 | ||||
-rw-r--r-- | runtime/autoload/remote/host.vim | 4 |
2 files changed, 77 insertions, 0 deletions
diff --git a/runtime/autoload/provider/perl.vim b/runtime/autoload/provider/perl.vim new file mode 100644 index 0000000000..4546a85100 --- /dev/null +++ b/runtime/autoload/provider/perl.vim @@ -0,0 +1,73 @@ +if exists('s:loaded_perl_provider') + finish +endif + +let s:loaded_perl_provider = 1 + +function! provider#perl#Detect() abort + " use g:perl_host_prof if set or check if perl is on the path + let prog = get(g:, 'perl_host_prog', executable('perl') ? 'perl' : '') + + " if perl is available, make sure the required module is available + if prog != '' + let job_id = jobstart(prog.' -MNeovim::Ext -e "exit 0"', {'stdout_buffered': v:true}) + let result = jobwait([job_id]) + if result[0] != 0 + let prog = '' + endif + endif + + return prog +endfunction + +function! provider#perl#Prog() abort + return s:prog +endfunction + +function! provider#perl#Require(host) abort + if s:err != '' + echoerr s:err + return + endif + + let prog = provider#perl#Prog() + let args = [s:prog, '-e', 'use Neovim::Ext; start_host();'] + + " Collect registered perl plugins into args + let perl_plugins = remote#host#PluginsForHost(a:host.name) + for plugin in perl_plugins + call add(args, plugin.path) + endfor + + return provider#Poll(args, a:host.orig_name, '$NVIM_PERL_LOG_FILE') +endfunction + +function! provider#perl#Call(method, args) abort + if s:err != '' + echoerr s:err + return + endif + + if !exists('s:host') + try + let s:host = remote#host#Require('perl') + catch + let s:err = v:exception + echohl WarningMsg + echomsg v:exception + echohl None + return + endtry + endif + return call('rpcrequest', insert(insert(a:args, 'perl_'.a:method), s:host)) +endfunction + +let s:err = '' +let s:prog = provider#perl#Detect() +let g:loaded_perl_provider = empty(s:prog) ? 1 : 2 + +if g:loaded_perl_provider != 2 + let s:err = 'Cannot find perl or the required perl module' +endif + +call remote#host#RegisterPlugin('perl-provider', 'perl', []) diff --git a/runtime/autoload/remote/host.vim b/runtime/autoload/remote/host.vim index 1cf328e08d..c34ff4bee7 100644 --- a/runtime/autoload/remote/host.vim +++ b/runtime/autoload/remote/host.vim @@ -203,3 +203,7 @@ call remote#host#Register('ruby', '*.rb', " nodejs call remote#host#Register('node', '*', \ function('provider#node#Require')) + +" perl +call remote#host#Register('perl', '*', + \ function('provider#perl#Require')) |