.vue support and highlighting
This commit is contained in:
		
							parent
							
								
									b6131e0868
								
							
						
					
					
						commit
						6e79c843b5
					
				|  | @ -149,7 +149,8 @@ hi! def link scssCondition						CRCssAlt | ||||||
| 
 | 
 | ||||||
| " CSS definitions | " CSS definitions | ||||||
| hi! def link cssNoise									CRNoise | 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 cssMediaKeyword					CRScssMediaKeyword  | ||||||
| hi! def link cssKeyFrameSelector			scssSelectorName | hi! def link cssKeyFrameSelector			scssSelectorName | ||||||
|  | @ -158,10 +159,13 @@ hi! def link cssStringQ								CRCssBaseDark | ||||||
| hi! def link cssStringQQ							cssStringQ | hi! def link cssStringQQ							cssStringQ | ||||||
| 
 | 
 | ||||||
| hi! def link cssTagName								CRCssSelectorBright | hi! def link cssTagName								CRCssSelectorBright | ||||||
|  | hi! def link cssStyle                  CRCssAlt | ||||||
| hi! def link cssProp									CRCssAlt | hi! def link cssProp									CRCssAlt | ||||||
| hi! def link cssAttr									scssAttribute | hi! def link cssAttr									scssAttribute | ||||||
|  | hi! def link cssAttrRegion						cssAttr | ||||||
| hi! def link cssPseudoClassId					CRCssSelectorDark | hi! def link cssPseudoClassId					CRCssSelectorDark | ||||||
| hi! def link cssMediaType							CRCssSelectorDark | hi! def link cssMediaType							CRCssSelectorDark | ||||||
|  | hi! def link cssVendor                cssNoise | ||||||
| 
 | 
 | ||||||
| hi! def link CRCssValue								CRCssBase | hi! def link CRCssValue								CRCssBase | ||||||
| hi! def link cssColor									CRCssBaseBright | hi! def link cssColor									CRCssBaseBright | ||||||
|  | @ -180,6 +184,7 @@ hi! def link htmlTitle					CRHtmlAlt | ||||||
| hi! def link htmlTag						CRNoise | hi! def link htmlTag						CRNoise | ||||||
| hi! def link htmlEndTag					htmlTag | hi! def link htmlEndTag					htmlTag | ||||||
| hi! def link htmlTagName				CRHtmlBase | hi! def link htmlTagName				CRHtmlBase | ||||||
|  | hi! def link htmlTagN           CRHtmlBaseBright | ||||||
| hi! def link htmlSpecialTagName CRHtmlSpecial | hi! def link htmlSpecialTagName CRHtmlSpecial | ||||||
| hi! def link htmlArg						CRHtmlBaseDark | hi! def link htmlArg						CRHtmlBaseDark | ||||||
| hi! def link htmlScriptTag			htmlArg | hi! def link htmlScriptTag			htmlArg | ||||||
|  | @ -221,8 +226,10 @@ hi! def link jsVariableDef			Identifier | ||||||
| hi! def link jsFuncCall					Identifier | hi! def link jsFuncCall					Identifier | ||||||
| hi! def link jsGlobalObjects		IdentifierDark | hi! def link jsGlobalObjects		IdentifierDark | ||||||
| hi! def link jsGlobalNodeObjects jsGlobalObjects | hi! def link jsGlobalNodeObjects jsGlobalObjects | ||||||
|  | hi! def link jsObject           IdentifierBright | ||||||
| hi! def link jsObjectKey				Identifier | hi! def link jsObjectKey				Identifier | ||||||
| hi! def link jsObjectValue			IdentifierDark | hi! def link jsObjectValue			IdentifierDark | ||||||
|  | hi! def link jsModuleKeyword    Identifier | ||||||
| 
 | 
 | ||||||
| " json definitions | " json definitions | ||||||
| hi! def link jsonKeyword				Identifier | 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 | "   https://github.com/joseluis/wordpress.vim-generator | ||||||
| "Plugin 'dsawardekar/wordpress.vim' | "Plugin 'dsawardekar/wordpress.vim' | ||||||
| " disabled - doesn't support universal ctags? | " 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 | " All of your Plugins must be added before the following line | ||||||
| call vundle#end()            " required | call vundle#end()            " required | ||||||
|  | @ -224,7 +229,7 @@ set showmode | ||||||
| " set custom syntax highlighting | " set custom syntax highlighting | ||||||
| autocmd BufNewFile,BufRead *.html set syntax=html_custom | autocmd BufNewFile,BufRead *.html set syntax=html_custom | ||||||
| autocmd BufNewFile,BufRead *.php set syntax=php_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 | " fix higlight problems such as vertical-align etc | ||||||
| augroup VimCSS3Syntax | augroup VimCSS3Syntax | ||||||
|  | @ -268,6 +273,9 @@ nnoremap <leader>p :echom SyntaxItem()<CR> | ||||||
| 
 | 
 | ||||||
| " plugins stuff | " plugins stuff | ||||||
| 
 | 
 | ||||||
|  | " vue-vim | ||||||
|  | " disable preprocessor checking for vue files - increases speed | ||||||
|  | let g:vue_disable_pre_processors=1 | ||||||
| 
 | 
 | ||||||
| " MUcomplete | " MUcomplete | ||||||
| set completeopt+=menuone | set completeopt+=menuone | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue