Fix some broken logic gathering highlights
Before, we would break the loop if we hit a highlight group with an empty name. In that case, we should actually continue the loop. I moved the loop index increment to the beginning of the loop to make this easier.
This commit is contained in:
parent
7b00efcb8f
commit
94d110f5a5
@ -182,12 +182,19 @@ endfunction
|
|||||||
function! s:Highlights()
|
function! s:Highlights()
|
||||||
let rv = {}
|
let rv = {}
|
||||||
|
|
||||||
let i = 1
|
let i = 0
|
||||||
while 1
|
while 1
|
||||||
if synIDtrans(i) == 0 || !len(synIDattr(synIDtrans(i), "name"))
|
let i += 1
|
||||||
|
" Only interested in groups that exist and aren't linked
|
||||||
|
if synIDtrans(i) == 0
|
||||||
break
|
break
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
" Handle vim bug allowing groups with name == "" to be created
|
||||||
|
if synIDtrans(i) != i || len(synIDattr(i, "name")) == 0
|
||||||
|
continue
|
||||||
|
endif
|
||||||
|
|
||||||
if !has_key(rv, synIDtrans(i))
|
if !has_key(rv, synIDtrans(i))
|
||||||
let group = {}
|
let group = {}
|
||||||
let group.name = synIDattr(synIDtrans(i), "name")
|
let group.name = synIDattr(synIDtrans(i), "name")
|
||||||
@ -218,8 +225,6 @@ function! s:Highlights()
|
|||||||
|
|
||||||
let rv[synIDtrans(i)] = group
|
let rv[synIDtrans(i)] = group
|
||||||
endif
|
endif
|
||||||
|
|
||||||
let i += 1
|
|
||||||
endwhile
|
endwhile
|
||||||
|
|
||||||
return rv
|
return rv
|
||||||
|
Loading…
x
Reference in New Issue
Block a user