aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJacques Germishuys <jacquesg@striata.com>2019-11-04 17:33:07 +0000
committerJan Edmund Lazo <jan.lazo@mail.utoronto.ca>2020-01-20 19:43:59 -0500
commitc25b5a1576eca912671d5f2fe47043055fbca2b0 (patch)
tree4bdb269f52e9e04be6d4e27572aa113966874cba
parent4faf30de3ea72bd188c8894eb10f0c971ff28e90 (diff)
downloadrneovim-c25b5a1576eca912671d5f2fe47043055fbca2b0.tar.gz
rneovim-c25b5a1576eca912671d5f2fe47043055fbca2b0.tar.bz2
rneovim-c25b5a1576eca912671d5f2fe47043055fbca2b0.zip
remote plugins: add support for perl hosts
-rw-r--r--runtime/autoload/provider/perl.vim73
-rw-r--r--runtime/autoload/remote/host.vim4
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'))