Skip to content

Instantly share code, notes, and snippets.

@desandro
Created July 1, 2010 18:35
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save desandro/460360 to your computer and use it in GitHub Desktop.
Save desandro/460360 to your computer and use it in GitHub Desktop.
{ 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 = '\\.';
},
);
};
};
}
@desandro
Copy link
Author

desandro commented Jul 1, 2010

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.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment