Makes cursor a standard notifier.
Adds a method enabled() to the notifiers.
Adds an optional method reset() to the notifiers.
This commit is contained in:
LCD 47 2013-04-09 00:24:54 +03:00
parent 9a7db4a50b
commit 90dce6d3e7
7 changed files with 68 additions and 33 deletions

View File

@ -47,7 +47,6 @@ endif
let s:registry = g:SyntasticRegistry.Instance()
let s:notifiers = g:SyntasticNotifiers.New()
let s:cursor_notifier = g:SyntasticNotifierCursor.New()
let s:modemap = g:SyntasticModeMap.Instance()
function! s:CompleteCheckerName(argLead, cmdLine, cursorPos)
@ -68,10 +67,6 @@ highlight link SyntasticError SpellBad
highlight link SyntasticWarning SpellCap
augroup syntastic
if g:syntastic_echo_current_error
autocmd CursorMoved * call s:cursor_notifier.refresh(s:LocList())
endif
autocmd BufReadPost * if g:syntastic_check_on_open | call s:UpdateErrors(1) | endif
autocmd BufWritePost * call s:UpdateErrors(1)
@ -117,8 +112,8 @@ endfunction
"clear the loc list for the buffer
function! s:ClearCache()
call s:notifiers.reset(s:LocList())
unlet! b:syntastic_loclist
call s:cursor_notifier.resetOldLine()
endfunction
function! s:CurrentFiletypes()

View File

@ -3,14 +3,6 @@ if exists("g:loaded_syntastic_notifier_autoloclist")
endif
let g:loaded_syntastic_notifier_autoloclist=1
"TODO: this var is a hack required for the Notifiers class. This is complicated
"because this notification type doesnt use the same option naming convention
"that Notifiers assumes
"
"i.e. it uses g:syntastic_auto_loc_list which has 3 possible values rather
"than just on or off
let g:syntastic_enable_autoloclist=1
if !exists("g:syntastic_auto_loc_list")
let g:syntastic_auto_loc_list = 2
endif
@ -24,6 +16,10 @@ function! g:SyntasticNotifierAutoloclist.New()
return newObj
endfunction
function! g:SyntasticNotifierAutoloclist.enabled()
return 1 " always enabled
endfunction
function! g:SyntasticNotifierAutoloclist.refresh(loclist)
call g:SyntasticNotifierAutoloclist.AutoToggle(a:loclist)
endfunction
@ -42,3 +38,5 @@ function! g:SyntasticNotifierAutoloclist.AutoToggle(loclist)
endif
endif
endfunction
" vim: set sw=4 sts=4 et fdm=marker:

View File

@ -20,6 +20,10 @@ function! g:SyntasticNotifierBalloons.New()
return newObj
endfunction
function! g:SyntasticNotifierBalloons.enabled()
return exists('b:syntastic_enable_balloons') ? b:syntastic_enable_balloons : g:syntastic_enable_balloons
endfunction
" Update the error balloons
function! g:SyntasticNotifierBalloons.refresh(loclist)
let b:syntastic_balloons = {}

View File

@ -3,7 +3,7 @@ if exists("g:loaded_syntastic_notifier_cursor")
endif
let g:loaded_syntastic_notifier_cursor=1
if !exists("g:syntastic_echo_current_error")
if !exists('g:syntastic_echo_current_error')
let g:syntastic_echo_current_error = 1
endif
@ -13,25 +13,50 @@ let g:SyntasticNotifierCursor = {}
function! g:SyntasticNotifierCursor.New()
let newObj = copy(self)
let newObj.oldLine = -1
let b:oldLine = -1
return newObj
endfunction
function! g:SyntasticNotifierCursor.enabled()
return exists('b:syntastic_echo_current_error') ? b:syntastic_echo_current_error : g:syntastic_echo_current_error
endfunction
function! g:SyntasticNotifierCursor.refresh(loclist)
let l = line('.')
if l == self.oldLine
if g:syntastic_echo_current_error
let b:syntastic_messages = copy(a:loclist.messages())
autocmd syntastic CursorMoved * call g:SyntasticRefreshCursor()
else
autocmd! syntastic CursorMoved
endif
endfunction
function! g:SyntasticNotifierCursor.reset(loclist)
let b:oldLine = -1
endfunction
" Private methods {{{1
" The following defensive nonsense is needed because of the nature of autocmd
function! g:SyntasticRefreshCursor()
if exists('b:syntastic_messages')
" file not checked
return
endif
let self.oldLine = l
let messages = a:loclist.messages()
if has_key(messages, l)
return syntastic#util#wideMsg(messages[l])
if !exists('b:oldLine')
let b:oldLine = -1
endif
let l = line('.')
if l == b:oldLine
return
endif
let b:oldLine = l
if has_key(b:syntastic_messages, l)
return syntastic#util#wideMsg(b:syntastic_messages[l])
else
echo
endif
endfunction
function! g:SyntasticNotifierCursor.resetOldLine()
let self.oldLine = -1
endfunction
" vim: set sw=4 sts=4 et fdm=marker:

View File

@ -21,12 +21,14 @@ function! g:SyntasticNotifierHighlighting.New()
return newObj
endfunction
function! g:SyntasticNotifierHighlighting.enabled()
return exists('b:syntastic_enable_highlighting') ? b:syntastic_enable_highlighting : g:syntastic_enable_highlighting
endfunction
" The function `Syntastic_{filetype}_{checker}_GetHighlightRegex` is used
" to override default highlighting. This function must take one arg (an
" error item) and return a regex to match that item in the buffer.
function! g:SyntasticNotifierHighlighting.refresh(loclist)
call self._reset()
let fts = substitute(&ft, '-', '_', 'g')
for ft in split(fts, '\.')
@ -49,10 +51,8 @@ function! g:SyntasticNotifierHighlighting.refresh(loclist)
endfor
endfunction
" Private functions {{{1
" Remove all error highlights from the window
function! g:SyntasticNotifierHighlighting._reset()
function! g:SyntasticNotifierHighlighting.reset(loclist)
for match in getmatches()
if stridx(match['group'], 'Syntastic') == 0
call matchdelete(match['id'])

View File

@ -5,7 +5,7 @@ let g:loaded_syntastic_notifiers=1
let g:SyntasticNotifiers = {}
let s:notifier_types = ['signs', 'balloons', 'highlighting', 'autoloclist']
let s:notifier_types = ['signs', 'balloons', 'highlighting', 'cursor', 'autoloclist']
" Public methods {{{1
@ -25,10 +25,19 @@ endfunction
function! g:SyntasticNotifiers.refresh(loclist)
for type in self._enabled_types
if ( exists('b:syntastic_enable_'.type) ? b:syntastic_enable_{type} : g:syntastic_enable_{type} )
if self._notifier[type].enabled()
call self._notifier[type].refresh(a:loclist)
endif
endfor
endfunction
function! g:SyntasticNotifiers.reset(loclist)
for type in self._enabled_types
let class = substitute(type, '.*', 'SyntasticNotifier\u&', '')
if has_key(g:{class}, 'reset')
call self._notifier[type].reset(a:loclist)
endif
endfor
endfunction
" vim: set sw=4 sts=4 et fdm=marker:

View File

@ -51,6 +51,10 @@ function! g:SyntasticNotifierSigns.New()
return newObj
endfunction
function! g:SyntasticNotifierSigns.enabled()
return exists('b:syntastic_enable_signs') ? b:syntastic_enable_signs : g:syntastic_enable_signs
endfunction
" Update the error signs
function! g:SyntasticNotifierSigns.refresh(loclist)
let old_signs = copy(self._bufSignIds())