diff options
Diffstat (limited to '')
| -rw-r--r-- | README.md | 1 | ||||
| -rw-r--r-- | autoload/python/utils.vim | 21 | ||||
| -rwxr-xr-x | build | 1 | ||||
| -rw-r--r-- | compiler/python.vim | 71 | ||||
| -rw-r--r-- | extras/flow.vim | 91 | ||||
| -rw-r--r-- | extras/jsdoc.vim | 43 | ||||
| -rw-r--r-- | extras/ngdoc.vim | 7 | ||||
| -rw-r--r-- | ftdetect/polyglot.vim | 12 | 
8 files changed, 247 insertions, 0 deletions
| @@ -91,6 +91,7 @@ If you need full functionality of any plugin, please use it directly with your p  - [puppet](https://github.com/voxpupuli/vim-puppet) (syntax, indent, ftplugin, ftdetect)  - [purescript](https://github.com/raichoo/purescript-vim) (syntax, indent, ftplugin, ftdetect)  - [python](https://github.com/mitsuhiko/vim-python-combined) (syntax, indent) +- [python-compiler](https://github.com/aliev/vim-compiler-python) (compiler, autoload, ftdetect)  - [qml](https://github.com/peterhoeg/vim-qml) (syntax, indent, ftplugin, ftdetect)  - [r-lang](https://github.com/vim-scripts/R.vim) (syntax, ftplugin)  - [ragel](https://github.com/jneen/ragel.vim) (syntax) diff --git a/autoload/python/utils.vim b/autoload/python/utils.vim new file mode 100644 index 00000000..51ba9ef1 --- /dev/null +++ b/autoload/python/utils.vim @@ -0,0 +1,21 @@ +if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'python-compiler') == -1 +   +" Sometimes Python issues debugging messages +" which don't belong to a call stack context +" this function filters these messages +function! python#utils#fix_qflist() " {{{ +  let l:traceback = [] +  let l:qflist = getqflist() + +  for l:item in l:qflist +    if !empty(l:item.type) +      call add(l:traceback, l:item) +    endif +  endfor + +  if !empty(l:traceback) +    call setqflist(l:traceback) +  endif +endfunction " }}} + +endif @@ -161,6 +161,7 @@ PACKS="    puppet:voxpupuli/vim-puppet    purescript:raichoo/purescript-vim    python:mitsuhiko/vim-python-combined +  python-compiler:aliev/vim-compiler-python    qml:peterhoeg/vim-qml    r-lang:vim-scripts/R.vim    ragel:jneen/ragel.vim diff --git a/compiler/python.vim b/compiler/python.vim new file mode 100644 index 00000000..844c9785 --- /dev/null +++ b/compiler/python.vim @@ -0,0 +1,71 @@ +if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'python-compiler') == -1 +   +" Vim compiler file +" Compiler:	Unit testing tool for Python +" Maintainer:	Ali Aliev <ali@aliev.me> +" Last Change: 2015 Nov 2 + +if exists("current_compiler") +  finish +endif + +let current_compiler = "python" + +if exists(":CompilerSet") != 2		" older Vim always used :setlocal +  command -nargs=* CompilerSet setlocal <args> +endif + +" Disable Python warnings +if !exists('$PYTHONWARNINGS') +  let $PYTHONWARNINGS="ignore" +endif + +" For Flake8 first +CompilerSet efm  =%E%f:%l:\ could\ not\ compile, +CompilerSet efm +=%-Z%p^, +CompilerSet efm +=%A%f:%l:%c:\ %t%n\ %m, +CompilerSet efm +=%A%f:%l:\ %t%n\ %m, + +" Python errors are multi-lined. They often start with 'Traceback', so +" we want to capture that (with +G) and show it in the quickfix window +" because it explains the order of error messages. + +CompilerSet efm +=%+GTraceback%.%#, + +" The error message itself starts with a line with 'File' in it. There +" are a couple of variations, and we need to process a line beginning +" with whitespace followed by File, the filename in "", a line number, +" and optional further text. %E here indicates the start of a multi-line +" error message. The %\C at the end means that a case-sensitive search is +" required. +CompilerSet efm +=%E\ \ File\ \"%f\"\\,\ line\ %l\\,%m%\\C, +CompilerSet efm +=%E\ \ File\ \"%f\"\\,\ line\ %l%\\C, + +" The possible continutation lines are idenitifed to Vim by %C. We deal +" with these in order of most to least specific to ensure a proper +" match. A pointer (^) identifies the column in which the error occurs +" (but will not be entirely accurate due to indention of Python code). +CompilerSet efm +=%C%p^, + +" Any text, indented by more than two spaces contain useful information. +" We want this to appear in the quickfix window, hence %+. +CompilerSet efm +=%+C\ \ \ \ %.%#, +CompilerSet efm +=%+C\ \ %.%#, + +" The last line (%Z) does not begin with any whitespace. We use a zero +" width lookahead (\&) to check this. The line contains the error +" message itself (%m) +CompilerSet efm +=%Z%\\S%\\&%m, + +" We can ignore any other lines (%-G) +CompilerSet efm +=%-G%.%# + +if filereadable("Makefile") +  CompilerSet makeprg=make +else +  CompilerSet makeprg=python +endif + +" vim:foldmethod=marker:foldlevel=0 + +endif diff --git a/extras/flow.vim b/extras/flow.vim index 6e7420f8..9fb7ad50 100644 --- a/extras/flow.vim +++ b/extras/flow.vim @@ -410,3 +410,94 @@ if version >= 508 || !exists("did_javascript_syn_inits")  endif  endif +if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'javascript') == -1 +   +syntax region  jsFlowDefinition     contained                        start=/:/    end=/\%(\s*[,=;)\n]\)\@=/ contains=@jsFlowCluster containedin=jsParen +syntax region  jsFlowArgumentDef    contained                        start=/:/    end=/\%(\s*[,)]\|=>\@!\)\@=/ contains=@jsFlowCluster +syntax region  jsFlowArray          contained matchgroup=jsFlowNoise start=/\[/   end=/\]/        contains=@jsFlowCluster +syntax region  jsFlowObject         contained matchgroup=jsFlowNoise start=/{/    end=/}/         contains=@jsFlowCluster +syntax region  jsFlowParens         contained matchgroup=jsFlowNoise start=/(/  end=/)/ contains=@jsFlowCluster +syntax match   jsFlowNoise          contained /[:;,<>]/ +syntax keyword jsFlowType           contained boolean number string null void any mixed JSON array function object array bool class +syntax keyword jsFlowTypeof         contained typeof skipempty skipempty nextgroup=jsFlowTypeCustom,jsFlowType +syntax match   jsFlowTypeCustom     contained /\k*/ skipwhite skipempty nextgroup=jsFlowGroup +syntax region  jsFlowGroup          contained matchgroup=jsFlowNoise start=/</ end=/>/ contains=@jsFlowCluster +syntax region  jsFlowArrowArguments contained matchgroup=jsFlowNoise start=/(/  end=/)\%(\s*=>\)\@=/ oneline skipwhite skipempty nextgroup=jsFlowArrow contains=@jsFlowCluster +syntax match   jsFlowArrow          contained /=>/ skipwhite skipempty nextgroup=jsFlowType,jsFlowTypeCustom,jsFlowParens +syntax match   jsFlowMaybe          contained /?/ skipwhite skipempty nextgroup=jsFlowType,jsFlowTypeCustom,jsFlowParens,jsFlowArrowArguments +syntax match   jsFlowObjectKey      contained /[0-9a-zA-Z_$?]*\(\s*:\)\@=/ contains=jsFunctionKey,jsFlowMaybe skipwhite skipempty nextgroup=jsObjectValue containedin=jsObject +syntax match   jsFlowOrOperator     contained /|/ skipwhite skipempty nextgroup=@jsFlowCluster + +syntax match   jsFlowReturn         contained /:\s*/ contains=jsFlowNoise skipwhite skipempty nextgroup=@jsFlowReturnCluster +syntax region  jsFlowReturnObject   contained matchgroup=jsFlowNoise start=/{/    end=/}/  contains=@jsFlowCluster skipwhite skipempty nextgroup=jsFuncBlock,jsFlowReturnOrOp +syntax region  jsFlowReturnArray    contained matchgroup=jsFlowNoise start=/\[/   end=/\]/ contains=@jsFlowCluster skipwhite skipempty nextgroup=jsFuncBlock,jsFlowReturnOrOp +syntax region  jsFlowReturnParens   contained matchgroup=jsFlowNoise start=/(/    end=/)/  contains=@jsFlowCluster skipwhite skipempty nextgroup=jsFuncBlock,jsFlowReturnOrOp +syntax match   jsFlowReturnKeyword  contained /\k\+/ contains=jsFlowType,jsFlowTypeCustom skipwhite skipempty nextgroup=jsFlowReturnGroup,jsFuncBlock,jsFlowReturnOrOp +syntax match   jsFlowReturnMaybe    contained /?/ skipwhite skipempty nextgroup=jsFlowReturnKeyword +syntax region  jsFlowReturnGroup    contained matchgroup=jsFlowNoise start=/</ end=/>/ contains=@jsFlowCluster skipwhite skipempty nextgroup=jsFuncBlock,jsFlowReturnOrOp +syntax match   jsFlowReturnOrOp     contained /\s*|\s*/ skipwhite skipempty nextgroup=@jsFlowReturnCluster + +syntax region  jsFlowFunctionGroup  contained matchgroup=jsFlowNoise start=/</ end=/>/ contains=@jsFlowCluster skipwhite skipempty nextgroup=jsFuncArgs +syntax region  jsFlowClassGroup     contained matchgroup=jsFlowNoise start=/</ end=/>/ contains=@jsFlowCluster skipwhite skipempty nextgroup=jsClassBlock + +syntax region  jsFlowTypeStatement                                   start=/type/    end=/=\@=/ contains=jsFlowTypeOperator oneline skipwhite skipempty nextgroup=jsFlowTypeValue keepend +syntax region  jsFlowTypeValue      contained                        start=/=/       end=/[;\n]/ contains=@jsExpression,jsFlowGroup,jsFlowMaybe +syntax match   jsFlowTypeOperator   contained /=/ +syntax keyword jsFlowTypeKeyword    contained type + +syntax keyword jsFlowDeclare                  declare skipwhite skipempty nextgroup=jsFlowTypeStatement,jsClassDefinition,jsStorageClass,jsFlowModule,jsFlowInterface +syntax match   jsFlowClassProperty  contained /\<[0-9a-zA-Z_$]*\>:\@=/ skipwhite skipempty nextgroup=jsFlowClassDef containedin=jsClassBlock +syntax region  jsFlowClassDef       contained start=/:/    end=/\%(\s*[,=;)\n]\)\@=/ contains=@jsFlowCluster skipwhite skipempty nextgroup=jsClassValue + +syntax region  jsFlowModule         contained start=/module/ end=/{\@=/ skipempty skipempty nextgroup=jsFlowDeclareBlock contains=jsString +syntax region  jsFlowInterface      contained start=/interface/ end=/{\@=/ skipempty skipempty nextgroup=jsFlowInterfaceBlock contains=@jsFlowCluster +syntax region  jsFlowDeclareBlock   contained matchgroup=jsFlowNoise start=/{/ end=/}/ contains=jsFlowDeclare,jsFlowNoise + +syntax region jsFlowInterfaceBlock  contained matchgroup=jsFlowNoise start=/{/ end=/}/ contains=jsObjectKey,jsObjectKeyString,jsObjectKeyComputed,jsObjectSeparator,jsObjectFuncName,jsObjectMethodType,jsGenerator,jsComment,jsObjectStringKey,jsSpreadExpression,jsFlowNoise keepend + +syntax cluster jsFlowReturnCluster            contains=jsFlowNoise,jsFlowReturnObject,jsFlowReturnArray,jsFlowReturnKeyword,jsFlowReturnGroup,jsFlowReturnMaybe,jsFlowReturnOrOp +syntax cluster jsFlowCluster                  contains=jsFlowArray,jsFlowObject,jsFlowNoise,jsFlowTypeof,jsFlowType,jsFlowGroup,jsFlowArrowArguments,jsFlowMaybe,jsFlowParens,jsFlowOrOperator + +if version >= 508 || !exists("did_javascript_syn_inits") +  if version < 508 +    let did_javascript_syn_inits = 1 +    command -nargs=+ HiLink hi link <args> +  else +    command -nargs=+ HiLink hi def link <args> +  endif +  HiLink jsFlowDefinition         PreProc +  HiLink jsFlowClassDef           jsFlowDefinition +  HiLink jsFlowArgumentDef        jsFlowDefinition +  HiLink jsFlowType               Type +  HiLink jsFlowTypeCustom         PreProc +  HiLink jsFlowTypeof             PreProc +  HiLink jsFlowArray              PreProc +  HiLink jsFlowObject             PreProc +  HiLink jsFlowParens             PreProc +  HiLink jsFlowGroup              PreProc +  HiLink jsFlowReturn             PreProc +  HiLink jsFlowReturnObject       jsFlowReturn +  HiLink jsFlowReturnArray        jsFlowArray +  HiLink jsFlowReturnParens       jsFlowParens +  HiLink jsFlowReturnGroup        jsFlowGroup +  HiLink jsFlowFunctionGroup      PreProc +  HiLink jsFlowClassGroup         PreProc +  HiLink jsFlowArrowArguments     PreProc +  HiLink jsFlowArrow              PreProc +  HiLink jsFlowTypeStatement      PreProc +  HiLink jsFlowTypeKeyword        PreProc +  HiLink jsFlowTypeOperator       PreProc +  HiLink jsFlowMaybe              PreProc +  HiLink jsFlowReturnMaybe        PreProc +  HiLink jsFlowClassProperty      jsClassProperty +  HiLink jsFlowDeclare            PreProc +  HiLink jsFlowModule             PreProc +  HiLink jsFlowInterface          PreProc +  HiLink jsFlowNoise              Noise +  HiLink jsFlowObjectKey          jsObjectKey +  HiLink jsFlowOrOperator         PreProc +  HiLink jsFlowReturnOrOp         jsFlowOrOperator +  delcommand HiLink +endif + +endif diff --git a/extras/jsdoc.vim b/extras/jsdoc.vim index 5317cb4b..20e7cbdd 100644 --- a/extras/jsdoc.vim +++ b/extras/jsdoc.vim @@ -299,3 +299,46 @@ if version >= 508 || !exists("did_javascript_syn_inits")  endif  endif +if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'javascript') == -1 +   +"" syntax coloring for javadoc comments (HTML) +syntax region jsComment    matchgroup=jsComment start="/\*\s*"  end="\*/" contains=jsDocTags,jsCommentTodo,jsCvsTag,@jsHtml,@Spell fold + +" tags containing a param +syntax match  jsDocTags         contained "@\(alias\|api\|augments\|borrows\|class\|constructs\|default\|defaultvalue\|emits\|exception\|exports\|extends\|fires\|kind\|link\|listens\|member\|member[oO]f\|mixes\|module\|name\|namespace\|requires\|template\|throws\|var\|variation\|version\)\>" skipwhite nextgroup=jsDocParam +" tags containing type and param +syntax match  jsDocTags         contained "@\(arg\|argument\|cfg\|param\|property\|prop\)\>" skipwhite nextgroup=jsDocType +" tags containing type but no param +syntax match  jsDocTags         contained "@\(callback\|define\|enum\|external\|implements\|this\|type\|typedef\|return\|returns\)\>" skipwhite nextgroup=jsDocTypeNoParam +" tags containing references +syntax match  jsDocTags         contained "@\(lends\|see\|tutorial\)\>" skipwhite nextgroup=jsDocSeeTag +" other tags (no extra syntax) +syntax match  jsDocTags         contained "@\(abstract\|access\|accessor\|author\|classdesc\|constant\|const\|constructor\|copyright\|deprecated\|desc\|description\|dict\|event\|example\|file\|file[oO]verview\|final\|function\|global\|ignore\|inheritDoc\|inner\|instance\|interface\|license\|localdoc\|method\|mixin\|nosideeffects\|override\|overview\|preserve\|private\|protected\|public\|readonly\|since\|static\|struct\|todo\|summary\|undocumented\|virtual\)\>" + +syntax region jsDocType         contained matchgroup=jsDocTypeBrackets start="{" end="}" contains=jsDocTypeRecord oneline skipwhite nextgroup=jsDocParam +syntax match  jsDocType         contained "\%(#\|\"\|\w\|\.\|:\|\/\)\+" skipwhite nextgroup=jsDocParam +syntax region jsDocTypeRecord   contained start=/{/ end=/}/ contains=jsDocTypeRecord extend +syntax region jsDocTypeRecord   contained start=/\[/ end=/\]/ contains=jsDocTypeRecord extend +syntax region jsDocTypeNoParam  contained start="{" end="}" oneline +syntax match  jsDocTypeNoParam  contained "\%(#\|\"\|\w\|\.\|:\|\/\)\+" +syntax match  jsDocParam        contained "\%(#\|\$\|-\|'\|\"\|{.\{-}}\|\w\|\.\|:\|\/\|\[.{-}]\|=\)\+" +syntax region jsDocSeeTag       contained matchgroup=jsDocSeeTag start="{" end="}" contains=jsDocTags + +if version >= 508 || !exists("did_javascript_syn_inits") +  if version < 508 +    let did_javascript_syn_inits = 1 +    command -nargs=+ HiLink hi link <args> +  else +    command -nargs=+ HiLink hi def link <args> +  endif +  HiLink jsDocTags              Special +  HiLink jsDocSeeTag            Function +  HiLink jsDocType              Type +  HiLink jsDocTypeBrackets      jsDocType +  HiLink jsDocTypeRecord        jsDocType +  HiLink jsDocTypeNoParam       Type +  HiLink jsDocParam             Label +  delcommand HiLink +endif + +endif diff --git a/extras/ngdoc.vim b/extras/ngdoc.vim index 88a6e94e..379619e5 100644 --- a/extras/ngdoc.vim +++ b/extras/ngdoc.vim @@ -47,3 +47,10 @@ syntax match  jsDocType         contained "\%(#\|\$\|\w\|\"\|-\|\.\|:\|\/\)\+" n  syntax match  jsDocParam        contained "\%(#\|\$\|\w\|\"\|-\|\.\|:\|{\|}\|\/\|\[\|]\|=\)\+"  endif +if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'javascript') == -1 +   +syntax match  jsDocTags         contained /@\(link\|method[oO]f\|ngdoc\|ng[iI]nject\|restrict\)/ nextgroup=jsDocParam skipwhite +syntax match  jsDocType         contained "\%(#\|\$\|\w\|\"\|-\|\.\|:\|\/\)\+" nextgroup=jsDocParam skipwhite +syntax match  jsDocParam        contained "\%(#\|\$\|\w\|\"\|-\|\.\|:\|{\|}\|\/\|\[\|]\|=\)\+" + +endif diff --git a/ftdetect/polyglot.vim b/ftdetect/polyglot.vim index 6e25fd4e..5eb3f089 100644 --- a/ftdetect/polyglot.vim +++ b/ftdetect/polyglot.vim @@ -688,6 +688,18 @@ au FileType purescript let &l:commentstring='{--%s--}'  endif +" ftdetect/python.vim +if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'python-compiler') == -1 +   +" Vim compiler file +" Compiler:	Unit testing tool for Python +" Maintainer:	Ali Aliev <ali@aliev.me> +" Last Change: 2015 Nov 2 + +autocmd FileType python compiler python + +endif +  " ftdetect/qml.vim  if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'qml') == -1 | 
