2019-03-04 09:28:35 +01:00
|
|
|
if exists('g:polyglot_disabled') && index(g:polyglot_disabled, 'jsx') != -1
|
|
|
|
finish
|
|
|
|
endif
|
|
|
|
|
2015-07-18 22:50:09 +02:00
|
|
|
"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
|
|
|
|
" Vim syntax file
|
|
|
|
"
|
|
|
|
" Language: JSX (JavaScript)
|
|
|
|
" Maintainer: Max Wang <mxawng@gmail.com>
|
|
|
|
" Depends: pangloss/vim-javascript
|
|
|
|
"
|
|
|
|
" CREDITS: Inspired by Facebook.
|
|
|
|
"
|
|
|
|
"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
|
|
|
|
|
|
|
|
" Prologue; load in XML syntax.
|
|
|
|
if exists('b:current_syntax')
|
|
|
|
let s:current_syntax=b:current_syntax
|
|
|
|
unlet b:current_syntax
|
|
|
|
endif
|
|
|
|
syn include @XMLSyntax syntax/xml.vim
|
|
|
|
if exists('s:current_syntax')
|
|
|
|
let b:current_syntax=s:current_syntax
|
|
|
|
endif
|
|
|
|
|
2015-12-06 11:31:38 +01:00
|
|
|
" Officially, vim-jsx depends on the pangloss/vim-javascript syntax package
|
|
|
|
" (and is tested against it exclusively). However, in practice, we make some
|
|
|
|
" effort towards compatibility with other packages.
|
|
|
|
"
|
|
|
|
" These are the plugin-to-syntax-element correspondences:
|
|
|
|
"
|
|
|
|
" - pangloss/vim-javascript: jsBlock, jsExpression
|
|
|
|
" - jelera/vim-javascript-syntax: javascriptBlock
|
|
|
|
" - othree/yajs.vim: javascriptNoReserved
|
|
|
|
|
|
|
|
|
2016-05-02 10:42:37 +02:00
|
|
|
" JSX attributes should color as JS. Note the trivial end pattern; we let
|
|
|
|
" jsBlock take care of ending the region.
|
|
|
|
syn region xmlString contained start=+{+ end=++ contains=jsBlock,javascriptBlock
|
|
|
|
|
2018-10-08 19:00:59 +02:00
|
|
|
" JSX comments inside XML tag should color as comment. Note the trivial end pattern; we let
|
|
|
|
" jsComment take care of ending the region.
|
|
|
|
syn region xmlString contained start=+//+ end=++ contains=jsComment
|
|
|
|
|
2016-05-02 10:42:37 +02:00
|
|
|
" JSX child blocks behave just like JSX attributes, except that (a) they are
|
|
|
|
" syntactically distinct, and (b) they need the syn-extend argument, or else
|
|
|
|
" nested XML end-tag patterns may end the outer jsxRegion.
|
|
|
|
syn region jsxChild contained start=+{+ end=++ contains=jsBlock,javascriptBlock
|
|
|
|
\ extend
|
|
|
|
|
2015-07-18 22:50:09 +02:00
|
|
|
" Highlight JSX regions as XML; recursively match.
|
2015-12-06 11:31:38 +01:00
|
|
|
"
|
|
|
|
" Note that we prohibit JSX tags from having a < or word character immediately
|
|
|
|
" preceding it, to avoid conflicts with, respectively, the left shift operator
|
|
|
|
" and generic Flow type annotations (http://flowtype.org/).
|
2016-05-02 10:42:37 +02:00
|
|
|
syn region jsxRegion
|
2016-07-30 13:18:40 +02:00
|
|
|
\ contains=@Spell,@XMLSyntax,jsxRegion,jsxChild,jsBlock,javascriptBlock
|
2018-10-08 19:00:59 +02:00
|
|
|
\ start=+\%(<\|\w\)\@<!<\z([a-zA-Z_][a-zA-Z0-9:\-.]*\>[:,]\@!\)\([^>]*>(\)\@!+
|
2015-07-18 22:50:09 +02:00
|
|
|
\ skip=+<!--\_.\{-}-->+
|
|
|
|
\ end=+</\z1\_\s\{-}>+
|
|
|
|
\ end=+/>+
|
|
|
|
\ keepend
|
|
|
|
\ extend
|
|
|
|
|
2019-03-04 10:46:19 +01:00
|
|
|
" Shorthand fragment support
|
|
|
|
"
|
|
|
|
" Note that since the main jsxRegion contains @XMLSyntax, we cannot simply
|
|
|
|
" adjust the regex above since @XMLSyntax will highlight the opening `<` as an
|
|
|
|
" XMLError. Instead we create a new group with the same name that does not
|
|
|
|
" include @XMLSyntax and instead uses matchgroup to get the same highlighting.
|
|
|
|
syn region jsxRegion
|
|
|
|
\ contains=@Spell,jsxRegion,jsxChild,jsBlock,javascriptBlock
|
|
|
|
\ matchgroup=xmlTag
|
|
|
|
\ start=/<>/
|
|
|
|
\ end=/<\/>/
|
|
|
|
\ keepend
|
|
|
|
\ extend
|
|
|
|
|
2015-07-18 22:50:09 +02:00
|
|
|
" Add jsxRegion to the lowest-level JS syntax cluster.
|
|
|
|
syn cluster jsExpression add=jsxRegion
|
2015-07-18 23:05:45 +02:00
|
|
|
|
2015-10-18 16:07:12 +02:00
|
|
|
" Allow jsxRegion to contain reserved words.
|
|
|
|
syn cluster javascriptNoReserved add=jsxRegion
|