diff options
| author | Björn Linse <bjorn.linse@gmail.com> | 2017-11-27 11:06:43 +0100 |
|---|---|---|
| committer | Björn Linse <bjorn.linse@gmail.com> | 2017-11-27 11:07:49 +0100 |
| commit | df019cebd59a456d6f7dc5948703fdd2059c4b04 (patch) | |
| tree | 1e49476224e41237250bff1bf2ff00d744a3d55c /runtime/autoload/provider/node.vim | |
| parent | a043899ba255524b7421579b9bd6112801f09247 (diff) | |
| download | rneovim-df019cebd59a456d6f7dc5948703fdd2059c4b04.tar.gz rneovim-df019cebd59a456d6f7dc5948703fdd2059c4b04.tar.bz2 rneovim-df019cebd59a456d6f7dc5948703fdd2059c4b04.zip | |
Revert "provider: delete vimL stderr collector, now that it exists builtin"
This change exposed a memory issue with buffered channels, possibly
involving GC. Revert until it has been fixed.
This reverts commit 0de019b6a65c6dd5141b7e002343df3689065ce7.
Diffstat (limited to 'runtime/autoload/provider/node.vim')
| -rw-r--r-- | runtime/autoload/provider/node.vim | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/runtime/autoload/provider/node.vim b/runtime/autoload/provider/node.vim index 419dd517cd..b08ad4f316 100644 --- a/runtime/autoload/provider/node.vim +++ b/runtime/autoload/provider/node.vim @@ -3,7 +3,7 @@ if exists('g:loaded_node_provider') endif let g:loaded_node_provider = 1 -let s:job_opts = {'rpc': v:true, 'stderr_buffered': v:true} +let s:job_opts = {'rpc': v:true, 'on_stderr': function('provider#stderr_collector')} function! provider#node#Detect() abort return has('win32') ? exepath('neovim-node-host.cmd') : exepath('neovim-node-host') @@ -32,18 +32,19 @@ function! provider#node#Require(host) abort endif try - let job = copy(s:job_opts) - let channel_id = jobstart(args, job) + let channel_id = jobstart(args, s:job_opts) if rpcrequest(channel_id, 'poll') ==# 'ok' return channel_id endif catch echomsg v:throwpoint echomsg v:exception - for row in job.stderr + for row in provider#get_stderr(channel_id) echomsg row endfor endtry + finally + call provider#clear_stderr(channel_id) endtry throw remote#host#LoadErrorForHost(a:host.orig_name, '$NVIM_NODE_LOG_FILE') endfunction |