Created
July 1, 2010 18:35
-
-
Save desandro/460360 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
{ scopeName = 'source.css'; | |
comment = ''; | |
fileTypes = ( 'css', 'css.erb' ); | |
foldingStartMarker = '/\*\*(?!\*)|\{\s*($|/\*(?!.*?\*/.*\S))'; | |
foldingStopMarker = '(?<!\*)\*\*/|^\s*\}'; | |
patterns = ( | |
{ name = 'meta.selector.css'; | |
begin = '^(?=\s*[:.*#a-zA-Z])'; | |
end = '(?=\{)'; | |
patterns = ( | |
{ include = '#comment-block'; }, | |
{ name = 'entity.name.tag.css'; | |
match = '\b(a|abbr|acronym|address|area|article|aside|audio|b|base|big|blockquote|body|br|button|canvas|caption|cite|code|col|colgroup|dd|del|details|dfn|div|dl|dt|em|fieldset|figcaption|figure|footer|form|frame|frameset|(h[1-6])|head|header|hgroup|hr|html|i|iframe|img|input|ins|kbd|label|legend|li|link|map|mark|menu|meta|nav|noframes|noscript|object|ol|optgroup|option|p|param|pre|q|samp|script|section|select|small|span|strike|strong|style|sub|summary|sup|table|tbody|td|textarea|time|tfoot|th|thead|title|tr|tt|ul|var|video)\b'; | |
}, | |
{ name = 'entity.other.attribute-name.class.css'; | |
match = '(\.)[a-zA-Z0-9_-]+'; | |
captures = { 1 = { name = 'punctuation.definition.entity.css'; }; }; | |
}, | |
{ name = 'entity.other.attribute-name.id.css'; | |
match = '(#)[a-zA-Z][a-zA-Z0-9_-]*'; | |
captures = { 1 = { name = 'punctuation.definition.entity.css'; }; }; | |
}, | |
{ name = 'entity.name.tag.wildcard.css'; | |
match = '\*'; | |
}, | |
{ name = 'entity.other.attribute-name.pseudo-element.css'; | |
match = '(:+)\b(after|before|first-child|first-letter|first-line|selection)\b'; | |
captures = { 1 = { name = 'punctuation.definition.entity.css'; }; }; | |
}, | |
{ name = 'entity.other.attribute-name.pseudo-class.css'; | |
match = '(:)\b(active|hover|link|visited|focus|nth-child|nth-of-type|valid|invalid)\b'; | |
captures = { 1 = { name = 'punctuation.definition.entity.css'; }; }; | |
}, | |
{ name = 'meta.attribute-selector.css'; | |
match = '(?i)(\[)\s*(-?[_a-z\\[[:^ascii:]]][_a-z0-9\-\\[[:^ascii:]]]*)(?:\s*([~|^$*]?=)\s*(?:(-?[_a-z\\[[:^ascii:]]][_a-z0-9\-\\[[:^ascii:]]]*)|((?>([''"])(?:[^\\]|\\.)*?(\6)))))?\s*(\])'; | |
captures = { | |
1 = { name = 'punctuation.definition.entity.css'; }; | |
2 = { name = 'entity.other.attribute-name.attribute.css'; }; | |
3 = { name = 'punctuation.separator.operator.css'; }; | |
4 = { name = 'string.unquoted.attribute-value.css'; }; | |
5 = { name = 'string.quoted.double.attribute-value.css'; }; | |
6 = { name = 'punctuation.definition.string.begin.css'; }; | |
7 = { name = 'punctuation.definition.string.end.css'; }; | |
}; | |
}, | |
); | |
}, | |
{ include = '#comment-block'; }, | |
{ name = 'meta.at-rule.import.css'; | |
begin = '^\s*((@)import\b)'; | |
end = '\s*((?=;|\}))'; | |
captures = { | |
1 = { name = 'keyword.control.at-rule.import.css'; }; | |
2 = { name = 'punctuation.definition.keyword.css'; }; | |
}; | |
patterns = ( | |
{ include = '#string-double'; }, | |
{ begin = '(url)\s*(\()\s*'; | |
end = '\s*(\))\s*'; | |
beginCaptures = { | |
1 = { name = 'support.function.url.css'; }; | |
2 = { name = 'punctuation.section.function.css'; }; | |
}; | |
endCaptures = { 1 = { name = 'punctuation.section.function.css'; }; }; | |
patterns = ( | |
{ name = 'variable.parameter.url.css'; | |
match = '[^''") \t]+'; | |
}, | |
{ include = '#string-single'; }, | |
{ include = '#string-double'; }, | |
); | |
}, | |
); | |
}, | |
{ name = 'meta.at-rule.media.css'; | |
begin = '^\s*((@)media)\s+(((all|aural|braille|embossed|handheld|print|projection|screen|tty|tv)\s*,?\s*)+)\s*{'; | |
end = '\s*((?=;|\}))'; | |
captures = { | |
1 = { name = 'keyword.control.at-rule.media.css'; }; | |
2 = { name = 'punctuation.definition.keyword.css'; }; | |
3 = { name = 'support.constant.media.css'; }; | |
}; | |
patterns = ( { include = '$self'; } ); | |
}, | |
{ name = 'meta.property-list.css'; | |
begin = '\{'; | |
end = '\}'; | |
captures = { 0 = { name = 'punctuation.section.property-list.css'; }; }; | |
patterns = ( | |
{ include = '#comment-block'; }, | |
{ name = 'meta.property-name.css'; | |
begin = '(?<![-a-z])(?=[-a-z])'; | |
end = '$|(?![-a-z])'; | |
patterns = ( | |
{ name = 'support.type.property-name.css'; | |
match = '\b(animation-fill-mode|animation-name|animation-duration|animation-iteration-count|animation-timing-function|animation|azimuth|background-attachment|background-color|background-image|backface-visibility|background-position|background-repeat|background|border-bottom-color|border-bottom-style|border-bottom-width|border-bottom|border-collapse|border-color|border-image|border-left-color|border-left-style|border-left-width|border-left|border-radius|border-right-color|border-right-style|border-right-width|border-right|border-spacing|border-style|border-top-color|border-top-style|border-top-width|border-top|border-width|border|bottom|box-reflect|box-shadow|box-sizing|caption-side|clear|clip|color|content|counter-increment|counter-reset|cue-after|cue-before|cue|cursor|direction|display|elevation|empty-cells|float|font-family|font-size-adjust|font-size|font-smoothing|font-stretch|font-style|font-variant|font-weight|font|height|left|letter-spacing|line-height|list-style-image|list-style-position|list-style-type|list-style|margin-bottom|margin-left|margin-right|margin-top|marker-offset|margin|marks|max-height|max-width|min-height|min-width|moz|opacity|orphans|outline-color|outline-style|outline-width|outline|overflow(-[xy])?|padding-bottom|padding-left|padding-right|padding-top|padding|page-break-after|page-break-before|page-break-inside|page|pause-after|pause-before|pause|perspective|pitch-range|pitch|play-during|pointer-events|position|quotes|richness|right|size|speak-header|speak-numeral|speak-punctuation|speech-rate|speak|stress|table-layout|tap-highlight-color|text-align|text-decoration|text-indent|text-overflow|text-shadow|text-transform|top|touch-callout|transition-delay|transition-duration|transition-property|transition-timing-function|transition|transform-origin-z|transform-origin|transform-style|transform|unicode-bidi|user-drag|user-select|vertical-align|visibility|voice-family|volume|webkit|white-space|widows|width|word-spacing|word-wrap|z-index)\b'; | |
}, | |
); | |
}, | |
{ name = 'meta.property-value.css'; | |
begin = '(:)\s*'; | |
end = '\s*(;|(?=\}))'; | |
beginCaptures = { 1 = { name = 'punctuation.separator.key-value.css'; }; }; | |
endCaptures = { 1 = { name = 'punctuation.terminator.rule.css'; }; }; | |
patterns = ( | |
{ name = 'support.constant.property-value.css'; | |
match = '\b(absolute|all-scroll|always|antialiased|armenian|auto|avoid|baseline|below|bidi-override|block|bold|bolder|both|bottom|break-all|break-word|capitalize|center|char|circle|cjk-ideographic|col-resize|collapse|crosshair|dashed|decimal-leading-zero|decimal|default|disabled|disc|distribute-all-lines|distribute-letter|distribute-space|distribute|dotted|double|e-resize|ellipsis|fixed|georgian|groove|hand|hebrew|help|hidden|hiragana-iroha|hiragana|horizontal|ideograph-alpha|ideograph-numeric|ideograph-parenthesis|ideograph-space|inactive|inherit|inline-block|inline|inset|inside|inter-ideograph|inter-word|italic|justify|katakana-iroha|katakana|keep-all|left|lighter|line-edge|line-through|line|list-item|loose|lower-alpha|lower-greek|lower-latin|lower-roman|lowercase|lr-tb|ltr|medium|middle|move|n-resize|ne-resize|newspaper|no-drop|no-repeat|nw-resize|none|normal|not-allowed|nowrap|oblique|outset|outside|overline|pointer|preserve-3d|pre-line|pre-wrap|pre|progress|relative|repeat-x|repeat-y|repeat|right|ridge|row-resize|rtl|s-resize|scroll|se-resize|separate|small-caps|solid|square|static|strict|super|sw-resize|table-footer-group|table-header-group|tb-rl|text-bottom|text-top|text|thick|thin|top|transparent|underline|upper-alpha|upper-latin|upper-roman|uppercase|vertical-ideographic|vertical-text|visible|w-resize|wait|whitespace|zero)\b'; | |
}, | |
{ name = 'support.constant.font-name.css'; | |
match = '(\b(?i:arial|century|comic|courier|garamond|georgia|helvetica|impact|lucida|symbol|system|tahoma|times|trebuchet|utopia|verdana|webdings|sans-serif|serif|monospace)\b)'; | |
}, | |
{ name = 'support.constant.color.w3c-standard-color-name.css'; | |
comment = 'http://www.w3.org/TR/CSS21/syndata.html#value-def-color'; | |
match = '\b(aqua|black|blue|fuchsia|gray|green|lime|maroon|navy|olive|orange|purple|red|silver|teal|white|yellow)\b'; | |
}, | |
{ name = 'invalid.deprecated.color.w3c-non-standard-color-name.css'; | |
comment = 'These colours are mostly recognised but will not validate. ref: http://www.w3schools.com/css/css_colornames.asp'; | |
match = '\b(aliceblue|antiquewhite|aquamarine|azure|beige|bisque|blanchedalmond|blueviolet|brown|burlywood|cadetblue|chartreuse|chocolate|coral|cornflowerblue|cornsilk|crimson|cyan|darkblue|darkcyan|darkgoldenrod|darkgray|darkgreen|darkgrey|darkkhaki|darkmagenta|darkolivegreen|darkorange|darkorchid|darkred|darksalmon|darkseagreen|darkslateblue|darkslategray|darkslategrey|darkturquoise|darkviolet|deeppink|deepskyblue|dimgray|dimgrey|dodgerblue|firebrick|floralwhite|forestgreen|gainsboro|ghostwhite|gold|goldenrod|greenyellow|grey|honeydew|hotpink|indianred|indigo|ivory|khaki|lavender|lavenderblush|lawngreen|lemonchiffon|lightblue|lightcoral|lightcyan|lightgoldenrodyellow|lightgray|lightgreen|lightgrey|lightpink|lightsalmon|lightseagreen|lightskyblue|lightslategray|lightslategrey|lightsteelblue|lightyellow|limegreen|linen|magenta|mediumaquamarine|mediumblue|mediumorchid|mediumpurple|mediumseagreen|mediumslateblue|mediumspringgreen|mediumturquoise|mediumvioletred|midnightblue|mintcream|mistyrose|moccasin|navajowhite|oldlace|olivedrab|orangered|orchid|palegoldenrod|palegreen|paleturquoise|palevioletred|papayawhip|peachpuff|peru|pink|plum|powderblue|rosybrown|royalblue|saddlebrown|salmon|sandybrown|seagreen|seashell|sienna|skyblue|slateblue|slategray|slategrey|snow|springgreen|steelblue|tan|thistle|tomato|turquoise|violet|wheat|whitesmoke|yellowgreen)\b'; | |
}, | |
{ name = 'constant.numeric.css'; | |
match = '(-|\+)?\s*[0-9]+(\.[0-9]+)?'; | |
}, | |
{ name = 'keyword.other.unit.css'; | |
match = '(?<=[\d])(deg|px|pt|cm|mm|in|em|ex|pc|rad|s|ms)\b|%'; | |
}, | |
{ name = 'constant.other.color.rgb-value.css'; | |
match = '(#)([0-9a-fA-F]{3}|[0-9a-fA-F]{6})\b'; | |
captures = { 1 = { name = 'punctuation.definition.constant.css'; }; }; | |
}, | |
{ include = '#string-double'; }, | |
{ include = '#string-single'; }, | |
{ begin = '(hsl|hsla|rgb|rgba|url|attr|counter|counters|rotateX|rotateY|rotateZ|translate|translate3d|translateZ)\s*(\()'; | |
end = '(\))'; | |
beginCaptures = { | |
1 = { name = 'support.function.misc.css'; }; | |
2 = { name = 'punctuation.section.function.css'; }; | |
}; | |
endCaptures = { 1 = { name = 'punctuation.section.function.css'; }; }; | |
patterns = ( | |
{ include = '#string-single'; }, | |
{ include = '#string-double'; }, | |
{ name = 'constant.other.color.rgb-value.css'; | |
match = '(\b0*((1?[0-9]{1,2})|(2([0-4][0-9]|5[0-5])))\s*,\s*)(0*((1?[0-9]{1,2})|(2([0-4][0-9]|5[0-5])))\s*,\s*)(0*((1?[0-9]{1,2})|(2([0-4][0-9]|5[0-5])))\b)'; | |
}, | |
{ name = 'constant.other.color.rgb-percentage.css'; | |
match = '\b([0-9]{1,2}|100)\s*%,\s*([0-9]{1,2}|100)\s*%,\s*([0-9]{1,2}|100)\s*%'; | |
}, | |
{ name = 'variable.parameter.misc.css'; | |
match = '[^''") \t]+'; | |
}, | |
); | |
}, | |
{ name = 'keyword.other.important.css'; | |
match = '\!\s*important'; | |
}, | |
); | |
}, | |
); | |
}, | |
); | |
repository = { | |
comment-block = { | |
name = 'comment.block.css'; | |
begin = '/\*'; | |
end = '\*/'; | |
captures = { 0 = { name = 'punctuation.definition.comment.css'; }; }; | |
}; | |
string-double = { | |
name = 'string.quoted.double.css'; | |
begin = '"'; | |
end = '"'; | |
beginCaptures = { 0 = { name = 'punctuation.definition.string.begin.css'; }; }; | |
endCaptures = { 0 = { name = 'punctuation.definition.string.end.css'; }; }; | |
patterns = ( | |
{ name = 'constant.character.escape.css'; | |
match = '\\.'; | |
}, | |
); | |
}; | |
string-single = { | |
name = 'string.quoted.single.css'; | |
begin = "'"; | |
end = "'"; | |
beginCaptures = { 0 = { name = 'punctuation.definition.string.begin.css'; }; }; | |
endCaptures = { 0 = { name = 'punctuation.definition.string.end.css'; }; }; | |
patterns = ( | |
{ name = 'constant.character.escape.css'; | |
match = '\\.'; | |
}, | |
); | |
}; | |
}; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
CSS Language Grammer for Textmate. To edit yours go to Bundles Editor, expand CSS, and find (L) CSS, and paste it in.
More details at See http://manual.macromates.com/en/language_grammars#language%5Fgrammars
Very hacky right now, still needs some work.