summaryrefslogtreecommitdiff
path: root/autoload/ale.vim
diff options
context:
space:
mode:
authorw0rp <devw0rp@gmail.com>2018-07-04 23:54:14 +0100
committerw0rp <devw0rp@gmail.com>2018-07-04 23:54:14 +0100
commit13a8f9c06110c065086ce7e569bab68d0e222398 (patch)
treea20f312df929d82d81a96adc4061772602ae7b80 /autoload/ale.vim
parent9ddf1b6a050bea6706bd51f2fd5f252c735bc1cc (diff)
downloadale-13a8f9c06110c065086ce7e569bab68d0e222398.zip
Optimise ale#Var a little
Diffstat (limited to 'autoload/ale.vim')
-rw-r--r--autoload/ale.vim11
1 files changed, 4 insertions, 7 deletions
diff --git a/autoload/ale.vim b/autoload/ale.vim
index dcc12150..8aa8bbd9 100644
--- a/autoload/ale.vim
+++ b/autoload/ale.vim
@@ -191,15 +191,12 @@ endfunction
"
" Every variable name will be prefixed with 'ale_'.
function! ale#Var(buffer, variable_name) abort
- let l:nr = str2nr(a:buffer)
let l:full_name = 'ale_' . a:variable_name
+ let l:vars = getbufvar(str2nr(a:buffer), '', 0)
- if bufexists(l:nr)
- let l:vars = getbufvar(l:nr, '')
- elseif has_key(g:, 'ale_fix_buffer_data')
- let l:vars = get(g:ale_fix_buffer_data, l:nr, {'vars': {}}).vars
- else
- let l:vars = {}
+ if l:vars is 0
+ " Look for variables from deleted buffers, saved from :ALEFix
+ let l:vars = get(get(g:ale_fix_buffer_data, a:buffer, {}), 'vars', {})
endif
return get(l:vars, l:full_name, g:[l:full_name])