2013-08-07 20:41:50 +03:00
|
|
|
"============================================================================
|
|
|
|
"File: verilator.vim
|
2017-09-15 21:04:16 +03:00
|
|
|
"Description: Syntax checking plugin for syntastic
|
2013-08-07 20:41:50 +03:00
|
|
|
"Maintainer: Kocha <kocha dot lsifrontend at gmail dot com>
|
|
|
|
"============================================================================
|
|
|
|
|
2015-03-25 18:44:34 +02:00
|
|
|
if exists('g:loaded_syntastic_verilog_verilator_checker')
|
2013-08-07 20:41:50 +03:00
|
|
|
finish
|
|
|
|
endif
|
|
|
|
let g:loaded_syntastic_verilog_verilator_checker = 1
|
|
|
|
|
2014-02-08 09:45:51 +02:00
|
|
|
if !exists('g:syntastic_verilog_compiler_options')
|
|
|
|
let g:syntastic_verilog_compiler_options = '-Wall'
|
2013-08-07 20:41:50 +03:00
|
|
|
endif
|
|
|
|
|
|
|
|
let s:save_cpo = &cpo
|
|
|
|
set cpo&vim
|
|
|
|
|
2013-10-28 17:30:25 +02:00
|
|
|
function! SyntaxCheckers_verilog_verilator_IsAvailable() dict
|
2014-02-08 09:45:51 +02:00
|
|
|
if !exists('g:syntastic_verilog_compiler')
|
|
|
|
let g:syntastic_verilog_compiler = self.getExec()
|
|
|
|
endif
|
2014-10-06 22:15:44 +03:00
|
|
|
call self.log('g:syntastic_verilog_compiler =', g:syntastic_verilog_compiler)
|
2015-01-04 09:01:55 +02:00
|
|
|
return executable(expand(g:syntastic_verilog_compiler, 1))
|
2013-08-07 20:41:50 +03:00
|
|
|
endfunction
|
|
|
|
|
2013-10-28 13:53:33 +02:00
|
|
|
function! SyntaxCheckers_verilog_verilator_GetLocList() dict
|
2013-08-07 20:41:50 +03:00
|
|
|
return syntastic#c#GetLocList('verilog', 'verilator', {
|
|
|
|
\ 'errorformat':
|
|
|
|
\ '%%%trror-%\=%\w%#: %f:%l: %m,' .
|
|
|
|
\ '%%%tarning-%\=%\w%#: %f:%l: %m',
|
|
|
|
\ 'main_flags': '--lint-only' })
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
call g:SyntasticRegistry.CreateAndRegisterChecker({
|
|
|
|
\ 'filetype': 'verilog',
|
2014-02-08 09:45:51 +02:00
|
|
|
\ 'name': 'verilator' })
|
2013-08-07 20:41:50 +03:00
|
|
|
|
|
|
|
let &cpo = s:save_cpo
|
|
|
|
unlet s:save_cpo
|
|
|
|
|
2015-01-04 12:46:54 +02:00
|
|
|
" vim: set sw=4 sts=4 et fdm=marker:
|