Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 1 | " Vim syntax file |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 2 | " Language: Cascading Style Sheets |
| 3 | " Previous Contributor List: |
| 4 | " Claudio Fleiner <claudio@fleiner.com> (Maintainer) |
| 5 | " Yeti (Add full CSS2, HTML4 support) |
| 6 | " Nikolai Weibull (Add CSS2 support) |
| 7 | " Maintainer: Jules Wang <w.jq0722@gmail.com> |
Bram Moolenaar | 3a0d809 | 2012-10-21 03:02:54 +0200 | [diff] [blame] | 8 | " URL: https://github.com/JulesWang/css.vim |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 9 | " Last Change: 2015 Apr.17 |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 10 | |
| 11 | " For version 5.x: Clear all syntax items |
| 12 | " For version 6.x: Quit when a syntax file was already loaded |
| 13 | if !exists("main_syntax") |
| 14 | if version < 600 |
| 15 | syntax clear |
| 16 | elseif exists("b:current_syntax") |
Bram Moolenaar | e2db695 | 2013-07-24 19:53:36 +0200 | [diff] [blame] | 17 | finish |
| 18 | endif |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 19 | let main_syntax = 'css' |
Bram Moolenaar | e2db695 | 2013-07-24 19:53:36 +0200 | [diff] [blame] | 20 | elseif exists("b:current_syntax") && b:current_syntax == "css" |
| 21 | finish |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 22 | endif |
| 23 | |
Bram Moolenaar | 0c5fa7d | 2012-10-05 22:26:30 +0200 | [diff] [blame] | 24 | let s:cpo_save = &cpo |
| 25 | set cpo&vim |
| 26 | |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 27 | syn case ignore |
| 28 | |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 29 | " HTML4 tags |
| 30 | syn keyword cssTagName abbr address area a b base |
| 31 | syn keyword cssTagName bdo blockquote body br button |
| 32 | syn keyword cssTagName caption cite code col colgroup dd del |
| 33 | syn keyword cssTagName dfn div dl dt em fieldset form |
| 34 | syn keyword cssTagName h1 h2 h3 h4 h5 h6 head hr html img i |
| 35 | syn keyword cssTagName iframe input ins isindex kbd label legend li |
| 36 | syn keyword cssTagName link map menu meta noscript ol optgroup |
| 37 | syn keyword cssTagName option p param pre q s samp script small |
| 38 | syn keyword cssTagName span strong sub sup tbody td |
| 39 | syn keyword cssTagName textarea tfoot th thead title tr ul u var |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 40 | syn keyword cssTagName object svg |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 41 | syn match cssTagName /\<select\>\|\<style\>\|\<table\>/ |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 42 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 43 | " 34 HTML5 tags |
| 44 | syn keyword cssTagName article aside audio bdi canvas command data |
| 45 | syn keyword cssTagName datalist details dialog embed figcaption figure footer |
| 46 | syn keyword cssTagName header hgroup keygen main mark menuitem meter nav |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 47 | syn keyword cssTagName output progress rt rp ruby section |
| 48 | syn keyword cssTagName source summary time track video wbr |
| 49 | |
| 50 | " Tags not supported in HTML5 |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 51 | " acronym applet basefont big center dir |
| 52 | " font frame frameset noframes strike tt |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 53 | |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 54 | syn match cssTagName "\*" |
| 55 | |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 56 | " selectors |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 57 | syn match cssSelectorOp "[,>+~]" |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 58 | syn match cssSelectorOp2 "[~|^$*]\?=" contained |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 59 | syn region cssAttributeSelector matchgroup=cssSelectorOp start="\[" end="]" contains=cssUnicodeEscape,cssSelectorOp2,cssStringQ,cssStringQQ |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 60 | |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 61 | " .class and #id |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 62 | syn match cssClassName "\.[A-Za-z][A-Za-z0-9_-]\+" contains=cssClassNameDot |
| 63 | syn match cssClassNameDot contained '\.' |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 64 | |
Bram Moolenaar | a5792f5 | 2005-11-23 21:25:05 +0000 | [diff] [blame] | 65 | try |
Bram Moolenaar | 293ee4d | 2004-12-09 21:34:53 +0000 | [diff] [blame] | 66 | syn match cssIdentifier "#[A-Za-zÀ-ÿ_@][A-Za-zÀ-ÿ0-9_@-]*" |
Bram Moolenaar | a5792f5 | 2005-11-23 21:25:05 +0000 | [diff] [blame] | 67 | catch /^.*/ |
| 68 | syn match cssIdentifier "#[A-Za-z_@][A-Za-z0-9_@-]*" |
| 69 | endtry |
| 70 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 71 | " digits |
| 72 | syn match cssValueInteger contained "[-+]\=\d\+" contains=cssUnitDecorators |
| 73 | syn match cssValueNumber contained "[-+]\=\d\+\(\.\d*\)\=" contains=cssUnitDecorators |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 74 | syn match cssValueLength contained "[-+]\=\d\+\(\.\d*\)\=\(%\|mm\|cm\|in\|pt\|pc\|em\|ex\|px\|rem\|dpi\|dppx\|dpcm\)\>" contains=cssUnitDecorators |
| 75 | syn match cssValueAngle contained "[-+]\=\d\+\(\.\d*\)\=\(deg\|grad\|rad\)\>" contains=cssUnitDecorators |
| 76 | syn match cssValueTime contained "+\=\d\+\(\.\d*\)\=\(ms\|s\)\>" contains=cssUnitDecorators |
| 77 | syn match cssValueFrequency contained "+\=\d\+\(\.\d*\)\=\(Hz\|kHz\)\>" contains=cssUnitDecorators |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 78 | |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 79 | |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 80 | syn match cssIncludeKeyword /@\(-[a-z]\+-\)\=\(media\|keyframes\|import\|charset\|namespace\|page\)/ contained |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 81 | " @media |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 82 | syn region cssInclude start=/@media\>/ end=/\ze{/ skipwhite skipnl contains=cssMediaProp,cssValueLength,cssMediaKeyword,cssValueInteger,cssMediaAttr,cssVendor,cssMediaType,cssIncludeKeyword,cssMediaComma,cssComment nextgroup=cssMediaBlock |
Bram Moolenaar | 18441ae | 2013-09-24 23:30:38 +0200 | [diff] [blame] | 83 | syn keyword cssMediaType contained screen print aural braille embossed handheld projection tty tv speech all contained skipwhite skipnl |
| 84 | syn keyword cssMediaKeyword only not and contained |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 85 | syn region cssMediaBlock transparent matchgroup=cssBraces start='{' end='}' contains=css.*Attr,css.*Prop,cssComment,cssValue.*,cssColor,cssURL,cssImportant,cssError,cssStringQ,cssStringQQ,cssFunction,cssUnicodeEscape,cssVendor,cssDefinition,cssTagName,cssClassName,cssIdentifier,cssPseudoClass,cssSelectorOp,cssSelectorOp2,cssAttributeSelector fold |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 86 | syn match cssMediaComma "," skipwhite skipnl contained |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 87 | |
| 88 | " Reference: http://www.w3.org/TR/css3-mediaqueries/ |
Bram Moolenaar | 18441ae | 2013-09-24 23:30:38 +0200 | [diff] [blame] | 89 | syn keyword cssMediaProp contained width height orientation scan grid |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 90 | syn match cssMediaProp contained /\(\(max\|min\)-\)\=\(\(device\)-\)\=aspect-ratio/ |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 91 | syn match cssMediaProp contained /\(\(max\|min\)-\)\=device-pixel-ratio/ |
| 92 | syn match cssMediaProp contained /\(\(max\|min\)-\)\=device-\(height\|width\)/ |
Bram Moolenaar | 18441ae | 2013-09-24 23:30:38 +0200 | [diff] [blame] | 93 | syn match cssMediaProp contained /\(\(max\|min\)-\)\=\(height\|width\|resolution\|monochrome\|color\(-index\)\=\)/ |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 94 | syn keyword cssMediaAttr contained portrait landscape progressive interlace |
| 95 | |
| 96 | " @page |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 97 | " http://www.w3.org/TR/css3-page/ |
| 98 | syn match cssPage "@page\>[^{]*{\@=" contains=cssPagePseudo,cssIncludeKeyword nextgroup=cssPageWrap transparent skipwhite skipnl |
| 99 | syn match cssPagePseudo /:\(left\|right\|first\|blank\)/ contained skipwhite skipnl |
| 100 | syn region cssPageWrap contained transparent matchgroup=cssBraces start="{" end="}" contains=cssPageMargin,cssPageProp,cssAttrRegion,css.*Prop,cssComment,cssValue.*,cssColor,cssURL,cssImportant,cssError,cssStringQ,cssStringQQ,cssFunction,cssUnicodeEscape,cssVendor,cssDefinition,cssHacks |
| 101 | syn match cssPageMargin /@\(\(top\|left\|right\|bottom\)-\(left\|center\|right\|middle\|bottom\)\)\(-corner\)\=/ contained nextgroup=cssDefinition skipwhite skipnl |
| 102 | syn keyword cssPageProp contained content size |
| 103 | " http://www.w3.org/TR/CSS2/page.html#break-inside |
| 104 | syn keyword cssPageProp contained orphans widows |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 105 | |
| 106 | " @keyframe |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 107 | " http://www.w3.org/TR/css3-animations/#keyframes |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 108 | syn match cssKeyFrame "@\(-[a-z]\+-\)\=keyframes\>[^{]*{\@=" nextgroup=cssKeyFrameWrap contains=cssVendor,cssIncludeKeyword skipwhite skipnl transparent |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 109 | syn region cssKeyFrameWrap contained transparent matchgroup=cssBraces start="{" end="}" contains=cssKeyFrameSelector |
| 110 | syn match cssKeyFrameSelector /\(\d*%\|from\|to\)\=/ contained skipwhite skipnl nextgroup=cssDefinition |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 111 | |
| 112 | " @import |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 113 | syn region cssInclude start=/@import\>/ end=/\ze;/ transparent contains=cssStringQ,cssStringQQ,cssUnicodeEscape,cssComment,cssIncludeKeyword,cssURL,cssMediaProp,cssValueLength,cssMediaKeyword,cssValueInteger,cssMediaAttr,cssVendor,cssMediaType |
| 114 | syn region cssInclude start=/@charset\>/ end=/\ze;/ transparent contains=cssStringQ,cssStringQQ,cssUnicodeEscape,cssComment,cssIncludeKeyword |
| 115 | syn region cssInclude start=/@namespace\>/ end=/\ze;/ transparent contains=cssStringQ,cssStringQQ,cssUnicodeEscape,cssComment,cssIncludeKeyword |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 116 | |
| 117 | " @font-face |
| 118 | " http://www.w3.org/TR/css3-fonts/#at-font-face-rule |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 119 | syn match cssFontDescriptor "@font-face\>" nextgroup=cssFontDescriptorBlock skipwhite skipnl |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 120 | syn region cssFontDescriptorBlock contained transparent matchgroup=cssBraces start="{" end="}" contains=cssComment,cssError,cssUnicodeEscape,cssCommonAttr,cssFontDescriptorProp,cssValue.*,cssFontDescriptorFunction,cssFontDescriptorAttr,cssNoise |
| 121 | |
| 122 | syn match cssFontDescriptorProp contained "\<font-family\>" |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 123 | syn keyword cssFontDescriptorProp contained src |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 124 | syn match cssFontDescriptorProp contained "\<font-\(style\|weight\|stretch\)\>" |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 125 | syn match cssFontDescriptorProp contained "\<unicode-range\>" |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 126 | syn match cssFontDescriptorProp contained "\<font-\(variant\|feature-settings\)\>" |
| 127 | |
| 128 | " src functions |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 129 | syn region cssFontDescriptorFunction contained matchgroup=cssFunctionName start="\<\(uri\|url\|local\|format\)\s*(" end=")" contains=cssStringQ,cssStringQQ oneline keepend |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 130 | " font-sytle and font-weight attributes |
| 131 | syn keyword cssFontDescriptorAttr contained normal italic oblique bold |
| 132 | " font-stretch attributes |
| 133 | syn match cssFontDescriptorAttr contained "\<\(\(ultra\|extra\|semi\)-\)\=\(condensed\|expanded\)\>" |
| 134 | " unicode-range attributes |
| 135 | syn match cssFontDescriptorAttr contained "U+[0-9A-Fa-f?]\+" |
| 136 | syn match cssFontDescriptorAttr contained "U+\x\+-\x\+" |
| 137 | " font-feature-settings attributes |
| 138 | syn keyword cssFontDescriptorAttr contained on off |
| 139 | |
| 140 | |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 141 | |
Bram Moolenaar | 3a0d809 | 2012-10-21 03:02:54 +0200 | [diff] [blame] | 142 | " The 16 basic color names |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 143 | syn keyword cssColor contained aqua black blue fuchsia gray green lime maroon navy olive purple red silver teal yellow |
Bram Moolenaar | 3a0d809 | 2012-10-21 03:02:54 +0200 | [diff] [blame] | 144 | |
| 145 | " 130 more color names |
| 146 | syn keyword cssColor contained aliceblue antiquewhite aquamarine azure |
| 147 | syn keyword cssColor contained beige bisque blanchedalmond blueviolet brown burlywood |
| 148 | syn keyword cssColor contained cadetblue chartreuse chocolate coral cornflowerblue cornsilk crimson cyan |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 149 | syn match cssColor contained /\<dark\(blue\|cyan\|goldenrod\|gray\|green\|grey\|khaki\)\>/ |
| 150 | syn match cssColor contained /\<dark\(magenta\|olivegreen\|orange\|orchid\|red\|salmon\|seagreen\)\>/ |
| 151 | syn match cssColor contained /\<darkslate\(blue\|gray\|grey\)\>/ |
| 152 | syn match cssColor contained /\<dark\(turquoise\|violet\)\>/ |
Bram Moolenaar | 3a0d809 | 2012-10-21 03:02:54 +0200 | [diff] [blame] | 153 | syn keyword cssColor contained deeppink deepskyblue dimgray dimgrey dodgerblue firebrick |
| 154 | syn keyword cssColor contained floralwhite forestgreen gainsboro ghostwhite gold |
| 155 | syn keyword cssColor contained goldenrod greenyellow grey honeydew hotpink |
| 156 | syn keyword cssColor contained indianred indigo ivory khaki lavender lavenderblush lawngreen |
| 157 | syn keyword cssColor contained lemonchiffon limegreen linen magenta |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 158 | syn match cssColor contained /\<light\(blue\|coral\|cyan\|goldenrodyellow\|gray\|green\)\>/ |
| 159 | syn match cssColor contained /\<light\(grey\|pink\|salmon\|seagreen\|skyblue\|yellow\)\>/ |
| 160 | syn match cssColor contained /\<light\(slategray\|slategrey\|steelblue\)\>/ |
| 161 | syn match cssColor contained /\<medium\(aquamarine\|blue\|orchid\|purple\|seagreen\)\>/ |
| 162 | syn match cssColor contained /\<medium\(slateblue\|springgreen\|turquoise\|violetred\)\>/ |
Bram Moolenaar | 3a0d809 | 2012-10-21 03:02:54 +0200 | [diff] [blame] | 163 | syn keyword cssColor contained midnightblue mintcream mistyrose moccasin navajowhite |
| 164 | syn keyword cssColor contained oldlace olivedrab orange orangered orchid |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 165 | syn match cssColor contained /\<pale\(goldenrod\|green\|turquoise\|violetred\)\>/ |
Bram Moolenaar | 3a0d809 | 2012-10-21 03:02:54 +0200 | [diff] [blame] | 166 | syn keyword cssColor contained papayawhip peachpuff peru pink plum powderblue |
| 167 | syn keyword cssColor contained rosybrown royalblue saddlebrown salmon sandybrown |
| 168 | syn keyword cssColor contained seagreen seashell sienna skyblue slateblue |
| 169 | syn keyword cssColor contained slategray slategrey snow springgreen steelblue tan |
| 170 | syn keyword cssColor contained thistle tomato turquoise violet wheat |
| 171 | syn keyword cssColor contained whitesmoke yellowgreen |
| 172 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 173 | " FIXME: These are actually case-insensitive too, but (a) specs recommend using |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 174 | " mixed-case (b) it's hard to highlight the word `Background' correctly in |
| 175 | " all situations |
| 176 | syn case match |
| 177 | syn keyword cssColor contained ActiveBorder ActiveCaption AppWorkspace ButtonFace ButtonHighlight ButtonShadow ButtonText CaptionText GrayText Highlight HighlightText InactiveBorder InactiveCaption InactiveCaptionText InfoBackground InfoText Menu MenuText Scrollbar ThreeDDarkShadow ThreeDFace ThreeDHighlight ThreeDLightShadow ThreeDShadow Window WindowFrame WindowText Background |
| 178 | syn case ignore |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 179 | |
| 180 | syn match cssImportant contained "!\s*important\>" |
| 181 | |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 182 | syn match cssColor contained "\<transparent\>" |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 183 | syn match cssColor contained "\<currentColor\>" |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 184 | syn match cssColor contained "\<white\>" |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 185 | syn match cssColor contained "#[0-9A-Fa-f]\{3\}\>" contains=cssUnitDecorators |
| 186 | syn match cssColor contained "#[0-9A-Fa-f]\{6\}\>" contains=cssUnitDecorators |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 187 | |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 188 | syn region cssURL contained matchgroup=cssFunctionName start="\<url\s*(" end=")" contains=cssStringQ,cssStringQQ oneline |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 189 | syn region cssFunction contained matchgroup=cssFunctionName start="\<\(rgb\|clip\|attr\|counter\|rect\|cubic-bezier\|steps\)\s*(" end=")" oneline contains=cssValueInteger,cssValueNumber,cssValueLength,cssFunctionComma |
| 190 | syn region cssFunction contained matchgroup=cssFunctionName start="\<\(rgba\|hsl\|hsla\|color-stop\|from\|to\)\s*(" end=")" oneline contains=cssColor,cssValueInteger,cssValueNumber,cssValueLength,cssFunctionComma,cssFunction |
| 191 | syn region cssFunction contained matchgroup=cssFunctionName start="\<\(linear-\|radial-\)\=\gradient\s*(" end=")" oneline contains=cssColor,cssValueInteger,cssValueNumber,cssValueLength,cssFunction,cssGradientAttr,cssFunctionComma |
| 192 | syn region cssFunction contained matchgroup=cssFunctionName start="\<\(matrix\(3d\)\=\|scale\(3d\|X\|Y\|Z\)\=\|translate\(3d\|X\|Y\|Z\)\=\|skew\(X\|Y\)\=\|rotate\(3d\|X\|Y\|Z\)\=\|perspective\)\s*(" end=")" oneline contains=cssValueInteger,cssValueNumber,cssValueLength,cssValueAngle,cssFunctionComma |
| 193 | syn keyword cssGradientAttr contained top bottom left right cover center middle ellipse at |
| 194 | syn match cssFunctionComma contained "," |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 195 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 196 | " Common Prop and Attr |
| 197 | syn keyword cssCommonAttr contained auto none inherit all default normal |
| 198 | syn keyword cssCommonAttr contained top bottom center stretch hidden visible |
| 199 | "------------------------------------------------ |
| 200 | " CSS Animations |
| 201 | " http://www.w3.org/TR/css3-animations/ |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 202 | syn match cssAnimationProp contained "\<animation\(-\(delay\|direction\|duration\|fill-mode\|name\|play-state\|timing-function\|iteration-count\)\)\=\>" |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 203 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 204 | " animation-direction attributes |
| 205 | syn keyword cssAnimationAttr contained alternate reverse |
| 206 | syn match cssAnimationAttr contained "\<alternate-reverse\>" |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 207 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 208 | " animation-fill-mode attributes |
| 209 | syn keyword cssAnimationAttr contained forwards backwards both |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 210 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 211 | " animation-play-state attributes |
| 212 | syn keyword cssAnimationAttr contained running paused |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 213 | |
| 214 | " animation-iteration-count attributes |
| 215 | syn keyword cssAnimationAttr contained infinite |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 216 | "------------------------------------------------ |
| 217 | " CSS Backgrounds and Borders Module Level 3 |
| 218 | " http://www.w3.org/TR/css3-background/ |
| 219 | syn match cssBackgroundProp contained "\<background\(-\(attachment\|clip\|color\|image\|origin\|position\|repeat\|size\)\)\=\>" |
| 220 | " background-attachment attributes |
| 221 | syn keyword cssBackgroundAttr contained scroll fixed local |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 222 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 223 | " background-position attributes |
| 224 | syn keyword cssBackgroundAttr contained left center right top bottom |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 225 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 226 | " background-repeat attributes |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 227 | syn match cssBackgroundAttr contained "\<no-repeat\>" |
| 228 | syn match cssBackgroundAttr contained "\<repeat\(-[xy]\)\=\>" |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 229 | syn keyword cssBackgroundAttr contained space round |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 230 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 231 | " background-size attributes |
| 232 | syn keyword cssBackgroundAttr contained cover contain |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 233 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 234 | syn match cssBorderProp contained "\<border\(-\(top\|right\|bottom\|left\)\)\=\(-\(width\|color\|style\)\)\=\>" |
| 235 | syn match cssBorderProp contained "\<border\(-\(top\|bottom\)-\(left\|right\)\)\=-radius\>" |
| 236 | syn match cssBorderProp contained "\<border-image\(-\(outset\|repeat\|slice\|source\|width\)\)\=\>" |
| 237 | syn match cssBorderProp contained "\<box-decoration-break\>" |
| 238 | syn match cssBorderProp contained "\<box-shadow\>" |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 239 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 240 | " border-image attributes |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 241 | syn keyword cssBorderAttr contained stretch round space fill |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 242 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 243 | " border-style attributes |
| 244 | syn keyword cssBorderAttr contained dotted dashed solid double groove ridge inset outset |
| 245 | |
| 246 | " border-width attributes |
| 247 | syn keyword cssBorderAttr contained thin thick medium |
| 248 | |
| 249 | " box-decoration-break attributes |
| 250 | syn keyword cssBorderAttr contained clone slice |
| 251 | "------------------------------------------------ |
| 252 | |
| 253 | syn match cssBoxProp contained "\<padding\(-\(top\|right\|bottom\|left\)\)\=\>" |
| 254 | syn match cssBoxProp contained "\<margin\(-\(top\|right\|bottom\|left\)\)\=\>" |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 255 | syn match cssBoxProp contained "\<overflow\(-\(x\|y\|style\)\)\=\>" |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 256 | syn match cssBoxProp contained "\<rotation\(-point\)\=\>" |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 257 | syn keyword cssBoxAttr contained visible hidden scroll auto |
| 258 | syn match cssBoxAttr contained "\<no-\(display\|content\)\>" |
| 259 | |
| 260 | syn keyword cssColorProp contained opacity |
| 261 | syn match cssColorProp contained "\<color-profile\>" |
| 262 | syn match cssColorProp contained "\<rendering-intent\>" |
| 263 | |
| 264 | |
| 265 | syn match cssDimensionProp contained "\<\(min\|max\)-\(width\|height\)\>" |
| 266 | syn keyword cssDimensionProp contained height |
| 267 | syn keyword cssDimensionProp contained width |
| 268 | |
| 269 | " shadow and sizing are in other property groups |
| 270 | syn match cssFlexibleBoxProp contained "\<box-\(align\|direction\|flex\|ordinal-group\|orient\|pack\|shadow\|sizing\)\>" |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 271 | syn keyword cssFlexibleBoxAttr contained start end baseline |
| 272 | syn keyword cssFlexibleBoxAttr contained reverse |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 273 | syn keyword cssFlexibleBoxAttr contained single multiple |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 274 | syn keyword cssFlexibleBoxAttr contained horizontal |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 275 | syn match cssFlexibleBoxAttr contained "\<vertical\(-align\)\@!\>" "escape vertical-align |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 276 | syn match cssFlexibleBoxAttr contained "\<\(inline\|block\)-axis\>" |
| 277 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 278 | " CSS Fonts Module Level 3 |
| 279 | " http://www.w3.org/TR/css-fonts-3/ |
| 280 | syn match cssFontProp contained "\<font\(-\(family\|\|feature-settings\|kerning\|language-override\|size\(-adjust\)\=\|stretch\|style\|synthesis\|variant\(-\(alternates\|caps\|east-asian\|ligatures\|numeric\|position\)\)\=\|weight\)\)\=\>" |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 281 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 282 | " font attributes |
| 283 | syn keyword cssFontAttr contained icon menu caption |
| 284 | syn match cssFontAttr contained "\<small-\(caps\|caption\)\>" |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 285 | syn match cssFontAttr contained "\<message-box\>" |
| 286 | syn match cssFontAttr contained "\<status-bar\>" |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 287 | syn keyword cssFontAttr contained larger smaller |
| 288 | syn match cssFontAttr contained "\<\(x\{1,2\}-\)\=\(large\|small\)\>" |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 289 | " font-family attributes |
| 290 | syn match cssFontAttr contained "\<\(sans-\)\=serif\>" |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 291 | syn keyword cssFontAttr contained Antiqua Arial Black Book Charcoal Comic Courier Dingbats Gadget Geneva Georgia Grande Helvetica Impact Linotype Lucida MS Monaco Neue New Palatino Roboto Roman Symbol Tahoma Times Trebuchet Verdana Webdings Wingdings York Zapf |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 292 | syn keyword cssFontAttr contained cursive fantasy monospace |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 293 | " font-feature-settings attributes |
| 294 | syn keyword cssFontAttr contained on off |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 295 | " font-stretch attributes |
| 296 | syn match cssFontAttr contained "\<\(\(ultra\|extra\|semi\)-\)\=\(condensed\|expanded\)\>" |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 297 | " font-style attributes |
| 298 | syn keyword cssFontAttr contained italic oblique |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 299 | " font-synthesis attributes |
| 300 | syn keyword cssFontAttr contained weight style |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 301 | " font-weight attributes |
| 302 | syn keyword cssFontAttr contained bold bolder lighter |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 303 | " TODO: font-variant-* attributes |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 304 | "------------------------------------------------ |
| 305 | |
| 306 | " Webkit specific property/attributes |
| 307 | syn match cssFontProp contained "\<font-smooth\>" |
| 308 | syn match cssFontAttr contained "\<\(subpixel-\)\=\antialiased\>" |
| 309 | |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 310 | |
| 311 | " CSS Multi-column Layout Module |
| 312 | " http://www.w3.org/TR/css3-multicol/ |
| 313 | syn match cssMultiColumnProp contained "\<break-\(after\|before\|inside\)\>" |
| 314 | syn match cssMultiColumnProp contained "\<column-\(count\|fill\|gap\|rule\(-\(color\|style\|width\)\)\=\|span\|width\)\>" |
| 315 | syn keyword cssMultiColumnProp contained columns |
| 316 | syn keyword cssMultiColumnAttr contained balance medium |
| 317 | syn keyword cssMultiColumnAttr contained always avoid left right page column |
| 318 | syn match cssMultiColumnAttr contained "\<avoid-\(page\|column\)\>" |
| 319 | |
| 320 | " http://www.w3.org/TR/css3-break/#page-break |
| 321 | syn match cssMultiColumnProp contained "\<page\(-break-\(before\|after\|inside\)\)\=\>" |
| 322 | |
| 323 | " TODO find following items in w3c docs. |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 324 | syn keyword cssGeneratedContentProp contained quotes crop |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 325 | syn match cssGeneratedContentProp contained "\<counter-\(reset\|increment\)\>" |
| 326 | syn match cssGeneratedContentProp contained "\<move-to\>" |
| 327 | syn match cssGeneratedContentProp contained "\<page-policy\>" |
| 328 | syn match cssGeneratedContentAttr contained "\<\(no-\)\=\(open\|close\)-quote\>" |
| 329 | |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 330 | syn match cssGridProp contained "\<grid-\(columns\|rows\)\>" |
| 331 | |
| 332 | syn match cssHyerlinkProp contained "\<target\(-\(name\|new\|position\)\)\=\>" |
| 333 | |
| 334 | syn match cssListProp contained "\<list-style\(-\(type\|position\|image\)\)\=\>" |
| 335 | syn match cssListAttr contained "\<\(lower\|upper\)-\(roman\|alpha\|greek\|latin\)\>" |
| 336 | syn match cssListAttr contained "\<\(hiragana\|katakana\)\(-iroha\)\=\>" |
| 337 | syn match cssListAttr contained "\<\(decimal\(-leading-zero\)\=\|cjk-ideographic\)\>" |
| 338 | syn keyword cssListAttr contained disc circle square hebrew armenian georgian |
| 339 | syn keyword cssListAttr contained inside outside |
| 340 | |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 341 | syn keyword cssPositioningProp contained bottom clear clip display float left |
| 342 | syn keyword cssPositioningProp contained position right top visibility |
| 343 | syn match cssPositioningProp contained "\<z-index\>" |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 344 | syn keyword cssPositioningAttr contained block compact |
| 345 | syn match cssPositioningAttr contained "\<table\(-\(row-group\|\(header\|footer\)-group\|row\|column\(-group\)\=\|cell\|caption\)\)\=\>" |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 346 | syn keyword cssPositioningAttr contained left right both |
| 347 | syn match cssPositioningAttr contained "\<list-item\>" |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 348 | syn match cssPositioningAttr contained "\<inline\(-\(block\|box\|table\)\)\=\>" |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 349 | syn keyword cssPositioningAttr contained static relative absolute fixed |
| 350 | |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 351 | syn keyword cssPrintAttr contained landscape portrait crop cross always avoid |
| 352 | |
| 353 | syn match cssTableProp contained "\<\(caption-side\|table-layout\|border-collapse\|border-spacing\|empty-cells\)\>" |
| 354 | syn keyword cssTableAttr contained fixed collapse separate show hide once always |
| 355 | |
| 356 | |
| 357 | syn keyword cssTextProp contained color direction |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 358 | syn match cssTextProp "\<\(\(word\|letter\)-spacing\|text\(-\(decoration\|transform\|align\|index\|shadow\)\)\=\|vertical-align\|unicode-bidi\|line-height\)\>" |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 359 | syn match cssTextProp contained "\<text-\(justify\|outline\|warp\|align-last\|size-adjust\|rendering\|stroke\|indent\)\>" |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 360 | syn match cssTextProp contained "\<word-\(break\|\wrap\)\>" |
| 361 | syn match cssTextProp contained "\<white-space\>" |
| 362 | syn match cssTextProp contained "\<hanging-punctuation\>" |
| 363 | syn match cssTextProp contained "\<punctuation-trim\>" |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 364 | syn match cssTextAttr contained "\<line-through\>" |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 365 | syn match cssTextAttr contained "\<\(text-\)\=\(top\|bottom\)\>" |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 366 | syn keyword cssTextAttr contained ltr rtl embed nowrap |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 367 | syn keyword cssTextAttr contained underline overline blink sub super middle |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 368 | syn keyword cssTextAttr contained capitalize uppercase lowercase |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 369 | syn keyword cssTextAttr contained justify baseline sub super |
| 370 | syn keyword cssTextAttr contained optimizeLegibility optimizeSpeed |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 371 | syn match cssTextAttr contained "\<pre\(-\(line\|wrap\)\)\=\>" |
| 372 | syn match cssTextAttr contained "\<\(allow\|force\)-end\>" |
| 373 | syn keyword cssTextAttr contained start end adjacent |
| 374 | syn match cssTextAttr contained "\<inter-\(word\|ideographic\|cluster\)\>" |
| 375 | syn keyword cssTextAttr contained distribute kashida first last |
| 376 | syn keyword cssTextAttr contained clip ellipsis unrestricted suppress |
| 377 | syn match cssTextAttr contained "\<break-all\>" |
| 378 | syn match cssTextAttr contained "\<break-word\>" |
| 379 | syn keyword cssTextAttr contained hyphenate |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 380 | syn match cssTextAttr contained "\<bidi-override\>" |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 381 | |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 382 | syn match cssTransformProp contained "\<transform\(-\(origin\|style\)\)\=\>" |
| 383 | syn match cssTransformProp contained "\<perspective\(-origin\)\=\>" |
| 384 | syn match cssTransformProp contained "\<backface-visibility\>" |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 385 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 386 | " CSS Transitions |
| 387 | " http://www.w3.org/TR/css3-transitions/ |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 388 | syn match cssTransitionProp contained "\<transition\(-\(delay\|duration\|property\|timing-function\)\)\=\>" |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 389 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 390 | " transition-time-function attributes |
| 391 | syn match cssTransitionAttr contained "\<linear\(-gradient\)\@!\>" |
| 392 | syn match cssTransitionAttr contained "\<ease\(-\(in-out\|out\|in\)\)\=\>" |
| 393 | syn match cssTransitionAttr contained "\<step\(-start\|-end\)\=\>" |
| 394 | "------------------------------------------------ |
| 395 | " CSS Basic User Interface Module Level 3 (CSS3 UI) |
| 396 | " http://www.w3.org/TR/css3-ui/ |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 397 | syn match cssUIProp contained "\<box-sizing\>" |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 398 | syn match cssUIAttr contained "\<\(content\|padding\|border\)\(-box\)\=\>" |
| 399 | |
| 400 | syn keyword cssUIProp contained cursor |
| 401 | syn match cssUIAttr contained "\<\(\([ns]\=[ew]\=\)\|col\|row\|nesw\|nwse\)-resize\>" |
| 402 | syn keyword cssUIAttr contained crosshair help move pointer alias copy |
| 403 | syn keyword cssUIAttr contained progress wait text cell move |
| 404 | syn match cssUIAttr contained "\<context-menu\>" |
| 405 | syn match cssUIAttr contained "\<no-drop\>" |
| 406 | syn match cssUIAttr contained "\<not-allowed\>" |
| 407 | syn match cssUIAttr contained "\<all-scroll\>" |
| 408 | syn match cssUIAttr contained "\<\(vertical-\)\=text\>" |
| 409 | syn match cssUIAttr contained "\<zoom\(-in\|-out\)\=\>" |
| 410 | |
| 411 | syn match cssUIProp contained "\<ime-mode\>" |
| 412 | syn keyword cssUIAttr contained active inactive disabled |
| 413 | |
| 414 | syn match cssUIProp contained "\<nav-\(down\|index\|left\|right\|up\)\=\>" |
| 415 | syn match cssUIProp contained "\<outline\(-\(width\|style\|color\|offset\)\)\=\>" |
| 416 | syn keyword cssUIAttr contained invert |
| 417 | |
| 418 | syn keyword cssUIProp contained icon resize |
| 419 | syn keyword cssUIAttr contained both horizontal vertical |
| 420 | |
| 421 | syn match cssUIProp contained "\<text-overflow\>" |
| 422 | syn keyword cssUIAttr contained clip ellipsis |
| 423 | |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 424 | " Already highlighted Props: font content |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 425 | "------------------------------------------------ |
| 426 | " Webkit/iOS specific attributes |
| 427 | syn match cssUIAttr contained '\(preserve-3d\)' |
| 428 | " IE specific attributes |
| 429 | syn match cssIEUIAttr contained '\(bicubic\)' |
| 430 | |
| 431 | " Webkit/iOS specific properties |
| 432 | syn match cssUIProp contained '\(tap-highlight-color\|user-select\|touch-callout\)' |
| 433 | " IE specific properties |
| 434 | syn match cssIEUIProp contained '\(interpolation-mode\|zoom\|filter\)' |
| 435 | |
| 436 | " Webkit/Firebox specific properties/attributes |
| 437 | syn keyword cssUIProp contained appearance |
| 438 | syn keyword cssUIAttr contained window button field icon document menu |
| 439 | |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 440 | |
| 441 | syn match cssAuralProp contained "\<\(pause\|cue\)\(-\(before\|after\)\)\=\>" |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 442 | syn match cssAuralProp contained "\<\(play-during\|speech-rate\|voice-family\|pitch\(-range\)\=\|speak\(-\(punctuation\|numeral\|header\)\)\=\)\>" |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 443 | syn keyword cssAuralProp contained volume during azimuth elevation stress richness |
| 444 | syn match cssAuralAttr contained "\<\(x-\)\=\(soft\|loud\)\>" |
| 445 | syn keyword cssAuralAttr contained silent |
| 446 | syn match cssAuralAttr contained "\<spell-out\>" |
| 447 | syn keyword cssAuralAttr contained non mix |
| 448 | syn match cssAuralAttr contained "\<\(left\|right\)-side\>" |
| 449 | syn match cssAuralAttr contained "\<\(far\|center\)-\(left\|center\|right\)\>" |
| 450 | syn keyword cssAuralAttr contained leftwards rightwards behind |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 451 | syn keyword cssAuralAttr contained below level above lower higher |
| 452 | syn match cssAuralAttr contained "\<\(x-\)\=\(slow\|fast\|low\|high\)\>" |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 453 | syn keyword cssAuralAttr contained faster slower |
| 454 | syn keyword cssAuralAttr contained male female child code digits continuous |
| 455 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 456 | " mobile text |
| 457 | syn match cssMobileTextProp contained "\<text-size-adjust\>" |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 458 | |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 459 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 460 | |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 461 | syn match cssBraces contained "[{}]" |
| 462 | syn match cssError contained "{@<>" |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 463 | syn region cssDefinition transparent matchgroup=cssBraces start='{' end='}' contains=cssAttrRegion,css.*Prop,cssComment,cssValue.*,cssColor,cssURL,cssImportant,cssError,cssStringQ,cssStringQQ,cssFunction,cssUnicodeEscape,cssVendor,cssDefinition,cssHacks,cssNoise fold |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 464 | syn match cssBraceError "}" |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 465 | syn match cssAttrComma "," |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 466 | |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 467 | " Pseudo class |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 468 | " http://www.w3.org/TR/css3-selectors/ |
| 469 | syn match cssPseudoClass ":[A-Za-z0-9_-]*" contains=cssNoise,cssPseudoClassId,cssUnicodeEscape,cssVendor,cssPseudoClassFn |
| 470 | syn keyword cssPseudoClassId contained link visited active hover before after left right |
| 471 | syn keyword cssPseudoClassId contained root empty target enable disabled checked invalid |
| 472 | syn match cssPseudoClassId contained "\<first-\(line\|letter\)\>" |
| 473 | syn match cssPseudoClassId contained "\<\(first\|last\|only\)-\(of-type\|child\)\>" |
| 474 | syn region cssPseudoClassFn contained matchgroup=cssFunctionName start="\<\(not\|lang\|\(nth\|nth-last\)-\(of-type\|child\)\)(" end=")" |
| 475 | " ------------------------------------ |
| 476 | " Vendor specific properties |
| 477 | syn match cssPseudoClassId contained "\<selection\>" |
| 478 | syn match cssPseudoClassId contained "\<focus\(-inner\)\=\>" |
| 479 | syn match cssPseudoClassId contained "\<\(input-\)\=placeholder\>" |
| 480 | |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 481 | " Misc highlight groups |
| 482 | syntax match cssUnitDecorators /\(#\|-\|%\|mm\|cm\|in\|pt\|pc\|em\|ex\|px\|ch\|rem\|vh\|vw\|vmin\|vmax\|dpi\|dppx\|dpcm\|Hz\|kHz\|s\|ms\|deg\|grad\|rad\)/ contained |
| 483 | syntax match cssNoise contained /\(:\|;\|\/\)/ |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 484 | |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 485 | " Comment |
Bram Moolenaar | 18441ae | 2013-09-24 23:30:38 +0200 | [diff] [blame] | 486 | syn region cssComment start="/\*" end="\*/" contains=@Spell fold |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 487 | |
| 488 | syn match cssUnicodeEscape "\\\x\{1,6}\s\?" |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 489 | syn match cssSpecialCharQQ +\\\\\|\\"+ contained |
| 490 | syn match cssSpecialCharQ +\\\\\|\\'+ contained |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 491 | syn region cssStringQQ start=+"+ skip=+\\\\\|\\"+ end=+"+ contains=cssUnicodeEscape,cssSpecialCharQQ |
| 492 | syn region cssStringQ start=+'+ skip=+\\\\\|\\'+ end=+'+ contains=cssUnicodeEscape,cssSpecialCharQ |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 493 | |
| 494 | " Vendor Prefix |
| 495 | syn match cssVendor contained "\(-\(webkit\|moz\|o\|ms\)-\)" |
| 496 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 497 | " Various CSS Hack characters |
| 498 | " In earlier versions of IE (6 and 7), one can prefix property names |
| 499 | " with a _ or * to isolate those definitions to particular versions of IE |
| 500 | " This is purely decorative and therefore we assign to the same highlight |
| 501 | " group to cssVendor, for more information: |
| 502 | " http://www.paulirish.com/2009/browser-specific-css-hacks/ |
| 503 | syn match cssHacks contained /\(_\|*\)/ |
| 504 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 505 | " Attr Enhance |
| 506 | " Some keywords are both Prop and Attr, so we have to handle them |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 507 | syn region cssAttrRegion start=/:/ end=/\ze\(;\|)\|}\)/ contained contains=css.*Attr,cssColor,cssImportant,cssValue.*,cssFunction,cssString.*,cssURL,cssComment,cssUnicodeEscape,cssVendor,cssError,cssAttrComma,cssNoise |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 508 | |
| 509 | " Hack for transition |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 510 | " 'transition' has Props after ':'. |
| 511 | syn region cssAttrRegion start=/transition\s*:/ end=/\ze\(;\|)\|}\)/ contained contains=css.*Prop,css.*Attr,cssColor,cssImportant,cssValue.*,cssFunction,cssString.*,cssURL,cssComment,cssUnicodeEscape,cssVendor,cssError,cssAttrComma,cssNoise |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 512 | |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 513 | |
| 514 | if main_syntax == "css" |
| 515 | syn sync minlines=10 |
| 516 | endif |
| 517 | |
| 518 | " Define the default highlighting. |
| 519 | " For version 5.7 and earlier: only when not done already |
| 520 | " For version 5.8 and later: only when an item doesn't have highlighting yet |
| 521 | if version >= 508 || !exists("did_css_syn_inits") |
| 522 | if version < 508 |
| 523 | let did_css_syn_inits = 1 |
| 524 | command -nargs=+ HiLink hi link <args> |
| 525 | else |
| 526 | command -nargs=+ HiLink hi def link <args> |
| 527 | endif |
| 528 | |
| 529 | HiLink cssComment Comment |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 530 | HiLink cssVendor Comment |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 531 | HiLink cssHacks Comment |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 532 | HiLink cssTagName Statement |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 533 | HiLink cssDeprecated Error |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 534 | HiLink cssSelectorOp Special |
| 535 | HiLink cssSelectorOp2 Special |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 536 | HiLink cssAttrComma Special |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 537 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 538 | HiLink cssAnimationProp cssProp |
| 539 | HiLink cssBackgroundProp cssProp |
| 540 | HiLink cssBorderProp cssProp |
| 541 | HiLink cssBoxProp cssProp |
| 542 | HiLink cssColorProp cssProp |
| 543 | HiLink cssContentForPagedMediaProp cssProp |
| 544 | HiLink cssDimensionProp cssProp |
| 545 | HiLink cssFlexibleBoxProp cssProp |
| 546 | HiLink cssFontProp cssProp |
| 547 | HiLink cssGeneratedContentProp cssProp |
| 548 | HiLink cssGridProp cssProp |
| 549 | HiLink cssHyerlinkProp cssProp |
| 550 | HiLink cssLineboxProp cssProp |
| 551 | HiLink cssListProp cssProp |
| 552 | HiLink cssMarqueeProp cssProp |
| 553 | HiLink cssMultiColumnProp cssProp |
| 554 | HiLink cssPagedMediaProp cssProp |
| 555 | HiLink cssPositioningProp cssProp |
| 556 | HiLink cssPrintProp cssProp |
| 557 | HiLink cssRubyProp cssProp |
| 558 | HiLink cssSpeechProp cssProp |
| 559 | HiLink cssTableProp cssProp |
| 560 | HiLink cssTextProp cssProp |
| 561 | HiLink cssTransformProp cssProp |
| 562 | HiLink cssTransitionProp cssProp |
| 563 | HiLink cssUIProp cssProp |
| 564 | HiLink cssIEUIProp cssProp |
| 565 | HiLink cssAuralProp cssProp |
| 566 | HiLink cssRenderProp cssProp |
| 567 | HiLink cssMobileTextProp cssProp |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 568 | |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 569 | HiLink cssAnimationAttr cssAttr |
| 570 | HiLink cssBackgroundAttr cssAttr |
| 571 | HiLink cssBorderAttr cssAttr |
| 572 | HiLink cssBoxAttr cssAttr |
| 573 | HiLink cssContentForPagedMediaAttr cssAttr |
| 574 | HiLink cssDimensionAttr cssAttr |
| 575 | HiLink cssFlexibleBoxAttr cssAttr |
| 576 | HiLink cssFontAttr cssAttr |
| 577 | HiLink cssGeneratedContentAttr cssAttr |
| 578 | HiLink cssGridAttr cssAttr |
| 579 | HiLink cssHyerlinkAttr cssAttr |
| 580 | HiLink cssLineboxAttr cssAttr |
| 581 | HiLink cssListAttr cssAttr |
| 582 | HiLink cssMarginAttr cssAttr |
| 583 | HiLink cssMarqueeAttr cssAttr |
| 584 | HiLink cssMultiColumnAttr cssAttr |
| 585 | HiLink cssPaddingAttr cssAttr |
| 586 | HiLink cssPagedMediaAttr cssAttr |
| 587 | HiLink cssPositioningAttr cssAttr |
| 588 | HiLink cssGradientAttr cssAttr |
| 589 | HiLink cssPrintAttr cssAttr |
| 590 | HiLink cssRubyAttr cssAttr |
| 591 | HiLink cssSpeechAttr cssAttr |
| 592 | HiLink cssTableAttr cssAttr |
| 593 | HiLink cssTextAttr cssAttr |
| 594 | HiLink cssTransformAttr cssAttr |
| 595 | HiLink cssTransitionAttr cssAttr |
| 596 | HiLink cssUIAttr cssAttr |
| 597 | HiLink cssIEUIAttr cssAttr |
| 598 | HiLink cssAuralAttr cssAttr |
| 599 | HiLink cssRenderAttr cssAttr |
| 600 | HiLink cssCommonAttr cssAttr |
Bram Moolenaar | d09acef | 2012-09-21 14:54:30 +0200 | [diff] [blame] | 601 | |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 602 | HiLink cssPseudoClassId PreProc |
| 603 | HiLink cssPseudoClassLang Constant |
| 604 | HiLink cssValueLength Number |
| 605 | HiLink cssValueInteger Number |
| 606 | HiLink cssValueNumber Number |
| 607 | HiLink cssValueAngle Number |
| 608 | HiLink cssValueTime Number |
| 609 | HiLink cssValueFrequency Number |
| 610 | HiLink cssFunction Constant |
| 611 | HiLink cssURL String |
| 612 | HiLink cssFunctionName Function |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 613 | HiLink cssFunctionComma Function |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 614 | HiLink cssColor Constant |
| 615 | HiLink cssIdentifier Function |
| 616 | HiLink cssInclude Include |
Bram Moolenaar | 18441ae | 2013-09-24 23:30:38 +0200 | [diff] [blame] | 617 | HiLink cssIncludeKeyword atKeyword |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 618 | HiLink cssImportant Special |
| 619 | HiLink cssBraces Function |
| 620 | HiLink cssBraceError Error |
| 621 | HiLink cssError Error |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 622 | HiLink cssUnicodeEscape Special |
| 623 | HiLink cssStringQQ String |
| 624 | HiLink cssStringQ String |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 625 | HiLink cssAttributeSelector String |
Bram Moolenaar | 18441ae | 2013-09-24 23:30:38 +0200 | [diff] [blame] | 626 | HiLink cssMedia atKeyword |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 627 | HiLink cssMediaType Special |
| 628 | HiLink cssMediaComma Normal |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 629 | HiLink cssMediaKeyword Statement |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 630 | HiLink cssMediaProp cssProp |
| 631 | HiLink cssMediaAttr cssAttr |
Bram Moolenaar | 18441ae | 2013-09-24 23:30:38 +0200 | [diff] [blame] | 632 | HiLink cssPage atKeyword |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 633 | HiLink cssPagePseudo PreProc |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 634 | HiLink cssPageMargin atKeyword |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 635 | HiLink cssPageProp cssProp |
Bram Moolenaar | 18441ae | 2013-09-24 23:30:38 +0200 | [diff] [blame] | 636 | HiLink cssKeyFrame atKeyword |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 637 | HiLink cssKeyFrameSelector Constant |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 638 | HiLink cssFontDescriptor Special |
| 639 | HiLink cssFontDescriptorFunction Constant |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 640 | HiLink cssFontDescriptorProp cssProp |
| 641 | HiLink cssFontDescriptorAttr cssAttr |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 642 | HiLink cssUnicodeRange Constant |
Bram Moolenaar | 29c3472 | 2007-05-12 15:34:06 +0000 | [diff] [blame] | 643 | HiLink cssClassName Function |
Bram Moolenaar | dfb1841 | 2013-12-11 18:53:29 +0100 | [diff] [blame] | 644 | HiLink cssClassNameDot Function |
Bram Moolenaar | baca7f7 | 2013-09-22 14:42:24 +0200 | [diff] [blame] | 645 | HiLink cssProp StorageClass |
| 646 | HiLink cssAttr Constant |
| 647 | HiLink cssUnitDecorators Number |
| 648 | HiLink cssNoise Noise |
Bram Moolenaar | f2571c6 | 2015-06-09 19:44:55 +0200 | [diff] [blame] | 649 | HiLink atKeyword PreProc |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 650 | delcommand HiLink |
| 651 | endif |
| 652 | |
| 653 | let b:current_syntax = "css" |
| 654 | |
| 655 | if main_syntax == 'css' |
| 656 | unlet main_syntax |
| 657 | endif |
| 658 | |
Bram Moolenaar | 0c5fa7d | 2012-10-05 22:26:30 +0200 | [diff] [blame] | 659 | let &cpo = s:cpo_save |
| 660 | unlet s:cpo_save |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 661 | " vim: ts=8 |
| 662 | |