.vue support and highlighting
This commit is contained in:
parent
b6131e0868
commit
6e79c843b5
|
@ -149,7 +149,8 @@ hi! def link scssCondition CRCssAlt
|
|||
|
||||
" CSS definitions
|
||||
hi! def link cssNoise CRNoise
|
||||
hi! def link cssBraces CRNoise
|
||||
hi! def link cssBraces CssNoise
|
||||
hi! def link cssAttrComma CssNoise
|
||||
|
||||
hi! def link cssMediaKeyword CRScssMediaKeyword
|
||||
hi! def link cssKeyFrameSelector scssSelectorName
|
||||
|
@ -158,10 +159,13 @@ hi! def link cssStringQ CRCssBaseDark
|
|||
hi! def link cssStringQQ cssStringQ
|
||||
|
||||
hi! def link cssTagName CRCssSelectorBright
|
||||
hi! def link cssStyle CRCssAlt
|
||||
hi! def link cssProp CRCssAlt
|
||||
hi! def link cssAttr scssAttribute
|
||||
hi! def link cssAttrRegion cssAttr
|
||||
hi! def link cssPseudoClassId CRCssSelectorDark
|
||||
hi! def link cssMediaType CRCssSelectorDark
|
||||
hi! def link cssVendor cssNoise
|
||||
|
||||
hi! def link CRCssValue CRCssBase
|
||||
hi! def link cssColor CRCssBaseBright
|
||||
|
@ -180,6 +184,7 @@ hi! def link htmlTitle CRHtmlAlt
|
|||
hi! def link htmlTag CRNoise
|
||||
hi! def link htmlEndTag htmlTag
|
||||
hi! def link htmlTagName CRHtmlBase
|
||||
hi! def link htmlTagN CRHtmlBaseBright
|
||||
hi! def link htmlSpecialTagName CRHtmlSpecial
|
||||
hi! def link htmlArg CRHtmlBaseDark
|
||||
hi! def link htmlScriptTag htmlArg
|
||||
|
@ -221,8 +226,10 @@ hi! def link jsVariableDef Identifier
|
|||
hi! def link jsFuncCall Identifier
|
||||
hi! def link jsGlobalObjects IdentifierDark
|
||||
hi! def link jsGlobalNodeObjects jsGlobalObjects
|
||||
hi! def link jsObject IdentifierBright
|
||||
hi! def link jsObjectKey Identifier
|
||||
hi! def link jsObjectValue IdentifierDark
|
||||
hi! def link jsModuleKeyword Identifier
|
||||
|
||||
" json definitions
|
||||
hi! def link jsonKeyword Identifier
|
||||
|
|
|
@ -0,0 +1,61 @@
|
|||
" Vim syntax file
|
||||
" Language: Vue.js
|
||||
" Maintainer: Eduardo San Martin Morote
|
||||
|
||||
if exists("b:current_syntax")
|
||||
finish
|
||||
endif
|
||||
|
||||
runtime! syntax/html_custom.vim
|
||||
unlet! b:current_syntax
|
||||
|
||||
""
|
||||
" Get the pattern for a HTML {name} attribute with {value}.
|
||||
function! s:attr(name, value)
|
||||
return a:name . '=\("\|''\)[^\1]*' . a:value . '[^\1]*\1'
|
||||
endfunction
|
||||
|
||||
""
|
||||
" Check whether a syntax file for a given {language} exists.
|
||||
function! s:syntax_available(language)
|
||||
return !empty(globpath(&runtimepath, 'syntax/' . a:language . '.vim'))
|
||||
endfunction
|
||||
|
||||
""
|
||||
" Register {language} for a given {tag}. If [attr_override] is given and not
|
||||
" empty, it will be used for the attribute pattern.
|
||||
function! s:register_language(language, tag, ...)
|
||||
let attr_override = a:0 ? a:1 : ''
|
||||
let attr = !empty(attr_override) ? attr_override : s:attr('lang', a:language)
|
||||
|
||||
if s:syntax_available(a:language)
|
||||
execute 'syntax include @' . a:language . ' syntax/' . a:language . '.vim'
|
||||
unlet! b:current_syntax
|
||||
execute 'syntax region vue_' . a:language
|
||||
\ 'keepend'
|
||||
\ 'start=/<' . a:tag . ' \_[^>]*' . attr . '\_[^>]*>/'
|
||||
\ 'end="</' . a:tag . '>"me=s-1'
|
||||
\ 'contains=@' . a:language . ',vueSurroundingTag'
|
||||
\ 'fold'
|
||||
endif
|
||||
endfunction
|
||||
|
||||
if !exists("g:vue_disable_pre_processors") || !g:vue_disable_pre_processors
|
||||
call s:register_language('pug', 'template', s:attr('lang', '\%(pug\|jade\)'))
|
||||
call s:register_language('slm', 'template')
|
||||
call s:register_language('handlebars', 'template')
|
||||
call s:register_language('haml', 'template')
|
||||
call s:register_language('typescript', 'script', '\%(lang=\("\|''\)[^\1]*\(ts\|typescript\)[^\1]*\1\|ts\)')
|
||||
call s:register_language('coffee', 'script')
|
||||
call s:register_language('stylus', 'style')
|
||||
call s:register_language('sass', 'style')
|
||||
call s:register_language('scss', 'style')
|
||||
call s:register_language('less', 'style')
|
||||
endif
|
||||
|
||||
syn region vueSurroundingTag contained start=+<\(script\|style\|template\)+ end=+>+ fold contains=htmlTagN,htmlString,htmlArg,htmlValue,htmlTagError,htmlEvent
|
||||
syn keyword htmlSpecialTagName contained template
|
||||
syn keyword htmlArg contained scoped ts
|
||||
syn match htmlArg "[@v:][-:.0-9_a-z]*\>" contained
|
||||
|
||||
let b:current_syntax = "vue"
|
10
vimrc
10
vimrc
|
@ -67,6 +67,11 @@ Plugin 'shawncplus/phpcomplete.vim'
|
|||
" https://github.com/joseluis/wordpress.vim-generator
|
||||
"Plugin 'dsawardekar/wordpress.vim'
|
||||
" disabled - doesn't support universal ctags?
|
||||
" vim-vue
|
||||
" https://github.com/posva/vim-vue
|
||||
Plugin 'posva/vim-vue'
|
||||
|
||||
|
||||
|
||||
" All of your Plugins must be added before the following line
|
||||
call vundle#end() " required
|
||||
|
@ -224,7 +229,7 @@ set showmode
|
|||
" set custom syntax highlighting
|
||||
autocmd BufNewFile,BufRead *.html set syntax=html_custom
|
||||
autocmd BufNewFile,BufRead *.php set syntax=php_custom
|
||||
|
||||
autocmd BufNewFile,BufRead *.vue set syntax=vue_custom
|
||||
|
||||
" fix higlight problems such as vertical-align etc
|
||||
augroup VimCSS3Syntax
|
||||
|
@ -268,6 +273,9 @@ nnoremap <leader>p :echom SyntaxItem()<CR>
|
|||
|
||||
" plugins stuff
|
||||
|
||||
" vue-vim
|
||||
" disable preprocessor checking for vue files - increases speed
|
||||
let g:vue_disable_pre_processors=1
|
||||
|
||||
" MUcomplete
|
||||
set completeopt+=menuone
|
||||
|
|
Loading…
Reference in New Issue