Last active
December 30, 2015 01:39
-
-
Save MattDMo/7757336 to your computer and use it in GitHub Desktop.
`Ruby.tmLanguage` from Sublime Text 3 Build 3056, modified to support `%i` literal notation. I changed the UUID (line 2852) so it can coexist along with the default version and changed the name on line 102 to Ruby2 so it can be easily selected from the syntax menu. Check the revisions to see where I made the changes. I don't know enough about Ru…
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
<?xml version="1.0" encoding="UTF-8"?> | |
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> | |
<plist version="1.0"> | |
<dict> | |
<key>comment</key> | |
<string> | |
TODO: unresolved issues | |
text: | |
"p << end | |
print me! | |
end" | |
symptoms: | |
not recognized as a heredoc | |
solution: | |
there is no way to distinguish perfectly between the << operator and the start | |
of a heredoc. Currently, we require assignment to recognize a heredoc. More | |
refinement is possible. | |
• Heredocs with indented terminators (<<-) are always distinguishable, however. | |
• Nested heredocs are not really supportable at present | |
text: | |
print <<-'THERE' | |
This is single quoted. | |
The above used #{Time.now} | |
THERE | |
symtoms: | |
From Programming Ruby p306; should be a non-interpolated heredoc. | |
text: | |
"a\332a" | |
symptoms: | |
'\332' is not recognized as slash3.. which should be octal 332. | |
solution: | |
plain regexp.. should be easy. | |
text: | |
val?(a):p(b) | |
val?'a':'b' | |
symptoms: | |
':p' is recognized as a symbol.. its 2 things ':' and 'p'. | |
:'b' has same problem. | |
solution: | |
ternary operator rule, precedence stuff, symbol rule. | |
but also consider 'a.b?(:c)' ?? | |
</string> | |
<key>fileTypes</key> | |
<array> | |
<string>rb</string> | |
<string>rbx</string> | |
<string>rjs</string> | |
<string>Rakefile</string> | |
<string>rake</string> | |
<string>cgi</string> | |
<string>fcgi</string> | |
<string>gemspec</string> | |
<string>irbrc</string> | |
<string>capfile</string> | |
<string>Gemfile</string> | |
</array> | |
<key>firstLineMatch</key> | |
<string>^#!/.*\bruby</string> | |
<key>foldingStartMarker</key> | |
<string>(?x)^ | |
(\s*+ | |
(module|class|def(?!.*\bend\s*$) | |
|unless|if | |
|case | |
|begin | |
|for|while|until | |
|^=begin | |
|( "(\\.|[^"])*+" # eat a double quoted string | |
| '(\\.|[^'])*+' # eat a single quoted string | |
| [^#"'] # eat all but comments and strings | |
)* | |
( \s (do|begin|case) | |
| (?<!\$)[-+=&|*/~%^<>~] \s*+ (if|unless) | |
) | |
)\b | |
(?! [^;]*+ ; .*? \bend\b ) | |
|( "(\\.|[^"])*+" # eat a double quoted string | |
| '(\\.|[^'])*+' # eat a single quoted string | |
| [^#"'] # eat all but comments and strings | |
)* | |
( \{ (?! [^}]*+ \} ) | |
| \[ (?! [^\]]*+ \] ) | |
) | |
).*$ | |
| [#] .*? \(fold\) \s*+ $ # Sune’s special marker | |
</string> | |
<key>foldingStopMarker</key> | |
<string>(?x) | |
( (^|;) \s*+ end \s*+ ([#].*)? $ | |
| (^|;) \s*+ end \. .* $ | |
| ^ \s*+ [}\]] ,? \s*+ ([#].*)? $ | |
| [#] .*? \(end\) \s*+ $ # Sune’s special marker | |
| ^=end | |
)</string> | |
<key>keyEquivalent</key> | |
<string>^~R</string> | |
<key>name</key> | |
<string>Ruby2</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>keyword.control.class.ruby</string> | |
</dict> | |
<key>2</key> | |
<dict> | |
<key>name</key> | |
<string>entity.name.type.class.ruby</string> | |
</dict> | |
<key>4</key> | |
<dict> | |
<key>name</key> | |
<string>entity.other.inherited-class.ruby</string> | |
</dict> | |
<key>5</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.separator.inheritance.ruby</string> | |
</dict> | |
<key>6</key> | |
<dict> | |
<key>name</key> | |
<string>variable.other.object.ruby</string> | |
</dict> | |
<key>7</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.variable.ruby</string> | |
</dict> | |
</dict> | |
<key>match</key> | |
<string>^\s*(class)\s+(([.a-zA-Z0-9_:]+(\s*(<)\s*[.a-zA-Z0-9_:]+)?)|((<<)\s*[.a-zA-Z0-9_:]+))</string> | |
<key>name</key> | |
<string>meta.class.ruby</string> | |
</dict> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>keyword.control.module.ruby</string> | |
</dict> | |
<key>2</key> | |
<dict> | |
<key>name</key> | |
<string>entity.name.type.module.ruby</string> | |
</dict> | |
<key>3</key> | |
<dict> | |
<key>name</key> | |
<string>entity.other.inherited-class.module.first.ruby</string> | |
</dict> | |
<key>4</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.separator.inheritance.ruby</string> | |
</dict> | |
<key>5</key> | |
<dict> | |
<key>name</key> | |
<string>entity.other.inherited-class.module.second.ruby</string> | |
</dict> | |
<key>6</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.separator.inheritance.ruby</string> | |
</dict> | |
<key>7</key> | |
<dict> | |
<key>name</key> | |
<string>entity.other.inherited-class.module.third.ruby</string> | |
</dict> | |
<key>8</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.separator.inheritance.ruby</string> | |
</dict> | |
</dict> | |
<key>match</key> | |
<string>^\s*(module)\s+(([A-Z]\w*(::))?([A-Z]\w*(::))?([A-Z]\w*(::))*[A-Z]\w*)</string> | |
<key>name</key> | |
<string>meta.module.ruby</string> | |
</dict> | |
<dict> | |
<key>comment</key> | |
<string>else if is a common mistake carried over from other languages. it works if you put in a second end, but it’s never what you want.</string> | |
<key>match</key> | |
<string>(?<!\.)\belse(\s)+if\b</string> | |
<key>name</key> | |
<string>invalid.deprecated.ruby</string> | |
</dict> | |
<dict> | |
<key>comment</key> | |
<string>everything being a reserved word, not a value and needing a 'end' is a..</string> | |
<key>match</key> | |
<string>(?<!\.)\b(BEGIN|begin|case|class|else|elsif|END|end|ensure|for|if|in|module|rescue|then|unless|until|when|while)\b(?![?!])</string> | |
<key>name</key> | |
<string>keyword.control.ruby</string> | |
</dict> | |
<dict> | |
<key>comment</key> | |
<string>contextual smart pair support for block parameters</string> | |
<key>match</key> | |
<string>(?<!\.)\bdo\b\s*</string> | |
<key>name</key> | |
<string>keyword.control.start-block.ruby</string> | |
</dict> | |
<dict> | |
<key>comment</key> | |
<string>contextual smart pair support</string> | |
<key>match</key> | |
<string>(?<=\{)(\s+)</string> | |
<key>name</key> | |
<string>meta.syntax.ruby.start-block</string> | |
</dict> | |
<dict> | |
<key>comment</key> | |
<string> as above, just doesn't need a 'end' and does a logic operation</string> | |
<key>match</key> | |
<string>(?<!\.)\b(and|not|or)\b</string> | |
<key>name</key> | |
<string>keyword.operator.logical.ruby</string> | |
</dict> | |
<dict> | |
<key>comment</key> | |
<string> just as above but being not a logical operation</string> | |
<key>match</key> | |
<string>(?<!\.)\b(alias|alias_method|break|next|redo|retry|return|super|undef|yield)\b(?![?!])|\bdefined\?|\bblock_given\?</string> | |
<key>name</key> | |
<string>keyword.control.pseudo-method.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>\b(nil|true|false)\b(?![?!])</string> | |
<key>name</key> | |
<string>constant.language.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>\b(__(FILE|LINE)__|self)\b(?![?!])</string> | |
<key>name</key> | |
<string>variable.language.ruby</string> | |
</dict> | |
<dict> | |
<key>comment</key> | |
<string> everything being a method but having a special function is a..</string> | |
<key>match</key> | |
<string>\b(initialize|new|loop|include|extend|raise|attr_reader|attr_writer|attr_accessor|attr|catch|throw|private|module_function|public|protected)\b(?![?!])</string> | |
<key>name</key> | |
<string>keyword.other.special-method.ruby</string> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>\b(require|gem)\b</string> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>keyword.other.special-method.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>$|(?=#)</string> | |
<key>name</key> | |
<string>meta.require.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>$self</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.variable.ruby</string> | |
</dict> | |
</dict> | |
<key>match</key> | |
<string>(@)[a-zA-Z_]\w*</string> | |
<key>name</key> | |
<string>variable.other.readwrite.instance.ruby</string> | |
</dict> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.variable.ruby</string> | |
</dict> | |
</dict> | |
<key>match</key> | |
<string>(@@)[a-zA-Z_]\w*</string> | |
<key>name</key> | |
<string>variable.other.readwrite.class.ruby</string> | |
</dict> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.variable.ruby</string> | |
</dict> | |
</dict> | |
<key>match</key> | |
<string>(\$)[a-zA-Z_]\w*</string> | |
<key>name</key> | |
<string>variable.other.readwrite.global.ruby</string> | |
</dict> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.variable.ruby</string> | |
</dict> | |
</dict> | |
<key>match</key> | |
<string>(\$)(!|@|&|`|'|\+|\d+|~|=|/|\\|,|;|\.|<|>|_|\*|\$|\?|:|"|-[0adFiIlpv])</string> | |
<key>name</key> | |
<string>variable.other.readwrite.global.pre-defined.ruby</string> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>\b(ENV)\[</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>variable.other.constant.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\]</string> | |
<key>name</key> | |
<string>meta.environment-variable.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>$self</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>\b[A-Z]\w*(?=((\.|::)[A-Za-z]|\[))</string> | |
<key>name</key> | |
<string>support.class.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>\b[A-Z]\w*\b</string> | |
<key>name</key> | |
<string>variable.other.constant.ruby</string> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?x) | |
(?=def\b) # an optimization to help Oniguruma fail fast | |
(?<=^|\s)(def)\s+ # the def keyword | |
( (?>[a-zA-Z_]\w*(?>\.|::))? # a method name prefix | |
(?>[a-zA-Z_]\w*(?>[?!]|=(?!>))? # the method name | |
|===?|>[>=]?|<=>|<[<=]?|[%&`/\|]|\*\*?|=?~|[-+]@?|\[\]=?) ) # …or an operator method | |
\s*(\() # the openning parenthesis for arguments | |
</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>keyword.control.def.ruby</string> | |
</dict> | |
<key>2</key> | |
<dict> | |
<key>name</key> | |
<string>entity.name.function.ruby</string> | |
</dict> | |
<key>3</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.parameters.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>the method pattern comes from the symbol pattern, see there for a explaination</string> | |
<key>contentName</key> | |
<string>variable.parameter.function.ruby</string> | |
<key>end</key> | |
<string>\)</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.parameters.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>meta.function.method.with-arguments.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>$self</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?x) | |
(?=def\b) # an optimization to help Oniguruma fail fast | |
(?<=^|\s)(def)\s+ # the def keyword | |
( (?>[a-zA-Z_]\w*(?>\.|::))? # a method name prefix | |
(?>[a-zA-Z_]\w*(?>[?!]|=(?!>))? # the method name | |
|===?|>[>=]?|<=>|<[<=]?|[%&`/\|]|\*\*?|=?~|[-+]@?|\[\]=?) ) # …or an operator method | |
[ \t] # the space separating the arguments | |
(?=[ \t]*[^\s#;]) # make sure arguments and not a comment follow | |
</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>keyword.control.def.ruby</string> | |
</dict> | |
<key>2</key> | |
<dict> | |
<key>name</key> | |
<string>entity.name.function.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>same as the previous rule, but without parentheses around the arguments</string> | |
<key>contentName</key> | |
<string>variable.parameter.function.ruby</string> | |
<key>end</key> | |
<string>$</string> | |
<key>name</key> | |
<string>meta.function.method.with-arguments.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>$self</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>keyword.control.def.ruby</string> | |
</dict> | |
<key>3</key> | |
<dict> | |
<key>name</key> | |
<string>entity.name.function.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string> the optional name is just to catch the def also without a method-name</string> | |
<key>match</key> | |
<string>(?x) | |
(?=def\b) # an optimization to help Oniguruma fail fast | |
(?<=^|\s)(def)\b # the def keyword | |
( \s+ # an optional group of whitespace followed by… | |
( (?>[a-zA-Z_]\w*(?>\.|::))? # a method name prefix | |
(?>[a-zA-Z_]\w*(?>[?!]|=(?!>))? # the method name | |
|===?|>[>=]?|<=>|<[<=]?|[%&`/\|]|\*\*?|=?~|[-+]@?|\[\]=?) ) )? # …or an operator method | |
</string> | |
<key>name</key> | |
<string>meta.function.method.without-arguments.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>\b(0[xX]\h(?>_?\h)*|\d(?>_?\d)*(\.(?![^[:space:][:digit:]])(?>_?\d)*)?([eE][-+]?\d(?>_?\d)*)?|0[bB][01]+)\b</string> | |
<key>name</key> | |
<string>constant.numeric.ruby</string> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>:'</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.constant.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>'</string> | |
<key>name</key> | |
<string>constant.other.symbol.single-quoted.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>match</key> | |
<string>\\['\\]</string> | |
<key>name</key> | |
<string>constant.character.escape.ruby</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>:"</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.constant.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>"</string> | |
<key>name</key> | |
<string>constant.other.symbol.double-quoted.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>comment</key> | |
<string>Needs higher precidence than regular expressions.</string> | |
<key>match</key> | |
<string>/=</string> | |
<key>name</key> | |
<string>keyword.operator.assignment.augmented.ruby</string> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>'</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>single quoted string (does not allow interpolation)</string> | |
<key>end</key> | |
<string>'</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.quoted.single.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>match</key> | |
<string>\\'|\\\\</string> | |
<key>name</key> | |
<string>constant.character.escape.ruby</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>"</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>double quoted string (allows for interpolation)</string> | |
<key>end</key> | |
<string>"</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.quoted.double.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>`</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>execute string (allows for interpolation)</string> | |
<key>end</key> | |
<string>`</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.interpolated.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%x\{</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>execute string (allow for interpolation)</string> | |
<key>end</key> | |
<string>\}</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.interpolated.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_curly_i</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%x\[</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>execute string (allow for interpolation)</string> | |
<key>end</key> | |
<string>\]</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.interpolated.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_brackets_i</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%x\<</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>execute string (allow for interpolation)</string> | |
<key>end</key> | |
<string>\></string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.interpolated.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_ltgt_i</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%x\(</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>execute string (allow for interpolation)</string> | |
<key>end</key> | |
<string>\)</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.interpolated.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_parens_i</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%x([^\w])</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>execute string (allow for interpolation)</string> | |
<key>end</key> | |
<string>\1</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.interpolated.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?x) | |
(?: | |
^ # beginning of line | |
| (?<= # or look-behind on: | |
[=>~(?:\[,|&;] | |
| [\s;]if\s # keywords | |
| [\s;]elsif\s | |
| [\s;]while\s | |
| [\s;]unless\s | |
| [\s;]when\s | |
| [\s;]assert_match\s | |
| [\s;]or\s # boolean opperators | |
| [\s;]and\s | |
| [\s;]not\s | |
| [\s.]index\s # methods | |
| [\s.]scan\s | |
| [\s.]sub\s | |
| [\s.]sub!\s | |
| [\s.]gsub\s | |
| [\s.]gsub!\s | |
| [\s.]match\s | |
) | |
| (?<= # or a look-behind with line anchor: | |
^when\s # duplication necessary due to limits of regex | |
| ^if\s | |
| ^elsif\s | |
| ^while\s | |
| ^unless\s | |
) | |
) | |
\s*((/))(?![*+{}?]) | |
</string> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>string.regexp.classic.ruby</string> | |
</dict> | |
<key>2</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>regular expressions (normal) | |
we only start a regexp if the character before it (excluding whitespace) | |
is what we think is before a regexp | |
</string> | |
<key>contentName</key> | |
<string>string.regexp.classic.ruby</string> | |
<key>end</key> | |
<string>((/[eimnosux]*))</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#regex_sub</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%r\{</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>regular expressions (literal)</string> | |
<key>end</key> | |
<string>\}[eimnosux]*</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.regexp.mod-r.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#regex_sub</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_curly_r</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%r\[</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>regular expressions (literal)</string> | |
<key>end</key> | |
<string>\][eimnosux]*</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.regexp.mod-r.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#regex_sub</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_brackets_r</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%r\(</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>regular expressions (literal)</string> | |
<key>end</key> | |
<string>\)[eimnosux]*</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.regexp.mod-r.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#regex_sub</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_parens_r</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%r\<</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>regular expressions (literal)</string> | |
<key>end</key> | |
<string>\>[eimnosux]*</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.regexp.mod-r.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#regex_sub</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_ltgt_r</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%r([^\w])</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>regular expressions (literal)</string> | |
<key>end</key> | |
<string>\1[eimnosux]*</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.regexp.mod-r.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#regex_sub</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%[QWSR]?\(</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>literal capable of interpolation ()</string> | |
<key>end</key> | |
<string>\)</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.quoted.other.literal.upper.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_parens_i</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%[QWSR]?\[</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>literal capable of interpolation []</string> | |
<key>end</key> | |
<string>\]</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.quoted.other.literal.upper.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_brackets_i</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%[QWSR]?\<</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>literal capable of interpolation <></string> | |
<key>end</key> | |
<string>\></string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.quoted.other.literal.upper.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_ltgt_i</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%[QWSR]?\{</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>literal capable of interpolation -- {}</string> | |
<key>end</key> | |
<string>\}</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.quoted.double.ruby.mod</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_curly_i</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%[QWSR]([^\w])</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>literal capable of interpolation -- wildcard</string> | |
<key>end</key> | |
<string>\1</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.quoted.other.literal.upper.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%([^\w\s=])</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>literal capable of interpolation -- wildcard</string> | |
<key>end</key> | |
<string>\1</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.quoted.other.literal.other.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%[qwsi]\(</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>literal incapable of interpolation -- ()</string> | |
<key>end</key> | |
<string>\)</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.quoted.other.literal.lower.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>match</key> | |
<string>\\\)|\\\\</string> | |
<key>name</key> | |
<string>constant.character.escape.ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_parens</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%[qwsi]\<</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>literal incapable of interpolation -- <></string> | |
<key>end</key> | |
<string>\></string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.quoted.other.literal.lower.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>match</key> | |
<string>\\\>|\\\\</string> | |
<key>name</key> | |
<string>constant.character.escape.ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_ltgt</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%[qwsi]\[</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>literal incapable of interpolation -- []</string> | |
<key>end</key> | |
<string>\]</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.quoted.other.literal.lower.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>match</key> | |
<string>\\\]|\\\\</string> | |
<key>name</key> | |
<string>constant.character.escape.ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_brackets</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%[qwsi]\{</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>literal incapable of interpolation -- {}</string> | |
<key>end</key> | |
<string>\}</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.quoted.other.literal.lower.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>match</key> | |
<string>\\\}|\\\\</string> | |
<key>name</key> | |
<string>constant.character.escape.ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_curly</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>%[qwsi]([^\w])</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>literal incapable of interpolation -- wildcard</string> | |
<key>end</key> | |
<string>\1</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.quoted.other.literal.lower.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>comment</key> | |
<string>Cant be named because its not neccesarily an escape.</string> | |
<key>match</key> | |
<string>\\.</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.constant.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>symbols</string> | |
<key>match</key> | |
<string>(?<!:)(:)(?>[a-zA-Z_]\w*(?>[?!]|=(?![>=]))?|===?|>[>=]?|<[<=]?|<=>|[%&`/\|]|\*\*?|=?~|[-+]@?|\[\]=?|@@?[a-zA-Z_]\w*)</string> | |
<key>name</key> | |
<string>constant.other.symbol.ruby</string> | |
</dict> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.constant.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>symbols</string> | |
<key>match</key> | |
<string>(?>[a-zA-Z_]\w*(?>[?!])?)(:)(?!:)</string> | |
<key>name</key> | |
<string>constant.other.symbol.ruby.19syntax</string> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>^=begin</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.comment.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>multiline comments</string> | |
<key>end</key> | |
<string>^=end</string> | |
<key>name</key> | |
<string>comment.block.documentation.ruby</string> | |
</dict> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.comment.ruby</string> | |
</dict> | |
</dict> | |
<key>match</key> | |
<string>(?:^[ \t]+)?(#).*$\n?</string> | |
<key>name</key> | |
<string>comment.line.number-sign.ruby</string> | |
</dict> | |
<dict> | |
<key>comment</key> | |
<string> | |
matches questionmark-letters. | |
examples (1st alternation = hex): | |
?\x1 ?\x61 | |
examples (2nd alternation = octal): | |
?\0 ?\07 ?\017 | |
examples (3rd alternation = escaped): | |
?\n ?\b | |
examples (4th alternation = meta-ctrl): | |
?\C-a ?\M-a ?\C-\M-\C-\M-a | |
examples (4th alternation = normal): | |
?a ?A ?0 | |
?* ?" ?( | |
?. ?# | |
the negative lookbehind prevents against matching | |
p(42.tainted?) | |
</string> | |
<key>match</key> | |
<string>(?<!\w)\?(\\(x\h{1,2}(?!\h)\b|0[0-7]{0,2}(?![0-7])\b|[^x0MC])|(\\[MC]-)+\w|[^\s\\])</string> | |
<key>name</key> | |
<string>constant.numeric.ruby</string> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>^__END__\n</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>string.unquoted.program-block.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>__END__ marker</string> | |
<key>contentName</key> | |
<string>text.plain</string> | |
<key>end</key> | |
<string>(?=not)impossible</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>begin</key> | |
<string>(?=<?xml|<(?i:html\b)|!DOCTYPE (?i:html\b))</string> | |
<key>end</key> | |
<string>(?=not)impossible</string> | |
<key>name</key> | |
<string>text.html.embedded.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>text.html.basic</string> | |
</dict> | |
</array> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?><<-("?)((?:[_\w]+_|)HTML)\b\1)</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>heredoc with embedded HTML and indented terminator</string> | |
<key>contentName</key> | |
<string>text.html.embedded.ruby</string> | |
<key>end</key> | |
<string>\s*\2$</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.unquoted.embedded.html.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#heredoc</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>text.html.basic</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?><<-("?)((?:[_\w]+_|)SQL)\b\1)</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>heredoc with embedded SQL and indented terminator</string> | |
<key>contentName</key> | |
<string>text.sql.embedded.ruby</string> | |
<key>end</key> | |
<string>\s*\2$</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.unquoted.embedded.sql.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#heredoc</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>source.sql</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?><<-("?)((?:[_\w]+_|)CSS)\b\1)</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>heredoc with embedded css and intented terminator</string> | |
<key>contentName</key> | |
<string>text.css.embedded.ruby</string> | |
<key>end</key> | |
<string>\s*\2$</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.unquoted.embedded.css.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#heredoc</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>source.css</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?><<-("?)((?:[_\w]+_|)CPP)\b\1)</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>heredoc with embedded c++ and intented terminator</string> | |
<key>contentName</key> | |
<string>text.c++.embedded.ruby</string> | |
<key>end</key> | |
<string>\s*\2$</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.unquoted.embedded.cplusplus.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#heredoc</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>source.c++</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?><<-("?)((?:[_\w]+_|)C)\b\1)</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>heredoc with embedded c++ and intented terminator</string> | |
<key>contentName</key> | |
<string>text.c.embedded.ruby</string> | |
<key>end</key> | |
<string>\s*\2$</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.unquoted.embedded.c.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#heredoc</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>source.c</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?><<-("?)((?:[_\w]+_|)(?:JS|JAVASCRIPT))\b\1)</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>heredoc with embedded javascript and intented terminator</string> | |
<key>contentName</key> | |
<string>text.js.embedded.ruby</string> | |
<key>end</key> | |
<string>\s*\2$</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.unquoted.embedded.js.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#heredoc</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>source.js</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?><<-("?)((?:[_\w]+_|)JQUERY)\b\1)</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>heredoc with embedded javascript and intented terminator</string> | |
<key>contentName</key> | |
<string>text.js.jquery.embedded.ruby</string> | |
<key>end</key> | |
<string>\s*\2$</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.unquoted.embedded.js.jquery.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#heredoc</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>source.js.jquery</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?><<-("?)((?:[_\w]+_|)(?:SH|SHELL))\b\1)</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>heredoc with embedded shell and intented terminator</string> | |
<key>contentName</key> | |
<string>text.shell.embedded.ruby</string> | |
<key>end</key> | |
<string>\s*\2$</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.unquoted.embedded.shell.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#heredoc</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>source.shell</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?><<-("?)((?:[_\w]+_|)RUBY)\b\1)</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>heredoc with embedded ruby and intented terminator</string> | |
<key>contentName</key> | |
<string>text.ruby.embedded.ruby</string> | |
<key>end</key> | |
<string>\s*\2$</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.unquoted.embedded.ruby.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#heredoc</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>source.ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?>\=\s*<<(\w+))</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>^\1$</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.unquoted.heredoc.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#heredoc</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?><<-(\w+))</string> | |
<key>beginCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.begin.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>heredoc with indented terminator</string> | |
<key>end</key> | |
<string>\s*\1$</string> | |
<key>endCaptures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.string.end.ruby</string> | |
</dict> | |
</dict> | |
<key>name</key> | |
<string>string.unquoted.heredoc.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#heredoc</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>(?<=\{|do|\{\s|do\s)(\|)</string> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.separator.variable.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>(\|)</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>match</key> | |
<string>[_a-zA-Z][_a-zA-Z0-9]*</string> | |
<key>name</key> | |
<string>variable.other.block.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>,</string> | |
<key>name</key> | |
<string>punctuation.separator.variable.ruby</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>=></string> | |
<key>name</key> | |
<string>punctuation.separator.key-value</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string><<=|%=|&=|\*=|\*\*=|\+=|\-=|\^=|\|{1,2}=|<<</string> | |
<key>name</key> | |
<string>keyword.operator.assignment.augmented.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string><=>|<(?!<|=)|>(?!<|=|>)|<=|>=|===|==|=~|!=|!~|(?<=[ \t])\?</string> | |
<key>name</key> | |
<string>keyword.operator.comparison.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>(?<=[ \t])!+|\bnot\b|&&|\band\b|\|\||\bor\b|\^</string> | |
<key>name</key> | |
<string>keyword.operator.logical.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>(%|&|\*\*|\*|\+|\-|/)</string> | |
<key>name</key> | |
<string>keyword.operator.arithmetic.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>=</string> | |
<key>name</key> | |
<string>keyword.operator.assignment.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>\||~|>></string> | |
<key>name</key> | |
<string>keyword.operator.other.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>:</string> | |
<key>name</key> | |
<string>punctuation.separator.other.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>\;</string> | |
<key>name</key> | |
<string>punctuation.separator.statement.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>,</string> | |
<key>name</key> | |
<string>punctuation.separator.object.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>\.|::</string> | |
<key>name</key> | |
<string>punctuation.separator.method.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>\{|\}</string> | |
<key>name</key> | |
<string>punctuation.section.scope.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>\[|\]</string> | |
<key>name</key> | |
<string>punctuation.section.array.ruby</string> | |
</dict> | |
<dict> | |
<key>match</key> | |
<string>\(|\)</string> | |
<key>name</key> | |
<string>punctuation.section.function.ruby</string> | |
</dict> | |
</array> | |
<key>repository</key> | |
<dict> | |
<key>escaped_char</key> | |
<dict> | |
<key>match</key> | |
<string>\\(?:[0-7]{1,3}|x[\da-fA-F]{1,2}|.)</string> | |
<key>name</key> | |
<string>constant.character.escape.ruby</string> | |
</dict> | |
<key>heredoc</key> | |
<dict> | |
<key>begin</key> | |
<string>^<<-?\w+</string> | |
<key>end</key> | |
<string>$</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>$self</string> | |
</dict> | |
</array> | |
</dict> | |
<key>interpolated_ruby</key> | |
<dict> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.embedded.ruby</string> | |
</dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>source.ruby.embedded.source.empty</string> | |
</dict> | |
</dict> | |
<key>match</key> | |
<string>#\{(\})</string> | |
<key>name</key> | |
<string>source.ruby.embedded.source</string> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>#\{</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.embedded.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\}</string> | |
<key>name</key> | |
<string>source.ruby.embedded.source</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#nest_curly_and_self</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>$self</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.variable.ruby</string> | |
</dict> | |
</dict> | |
<key>match</key> | |
<string>(#@)[a-zA-Z_]\w*</string> | |
<key>name</key> | |
<string>variable.other.readwrite.instance.ruby</string> | |
</dict> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.variable.ruby</string> | |
</dict> | |
</dict> | |
<key>match</key> | |
<string>(#@@)[a-zA-Z_]\w*</string> | |
<key>name</key> | |
<string>variable.other.readwrite.class.ruby</string> | |
</dict> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.variable.ruby</string> | |
</dict> | |
</dict> | |
<key>match</key> | |
<string>(#\$)[a-zA-Z_]\w*</string> | |
<key>name</key> | |
<string>variable.other.readwrite.global.ruby</string> | |
</dict> | |
</array> | |
</dict> | |
<key>nest_brackets</key> | |
<dict> | |
<key>begin</key> | |
<string>\[</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.scope.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\]</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#nest_brackets</string> | |
</dict> | |
</array> | |
</dict> | |
<key>nest_brackets_i</key> | |
<dict> | |
<key>begin</key> | |
<string>\[</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.scope.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\]</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_brackets_i</string> | |
</dict> | |
</array> | |
</dict> | |
<key>nest_brackets_r</key> | |
<dict> | |
<key>begin</key> | |
<string>\[</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.scope.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\]</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#regex_sub</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_brackets_r</string> | |
</dict> | |
</array> | |
</dict> | |
<key>nest_curly</key> | |
<dict> | |
<key>begin</key> | |
<string>\{</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.scope.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\}</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#nest_curly</string> | |
</dict> | |
</array> | |
</dict> | |
<key>nest_curly_and_self</key> | |
<dict> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>begin</key> | |
<string>\{</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.scope.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\}</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#nest_curly_and_self</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>$self</string> | |
</dict> | |
</array> | |
</dict> | |
<key>nest_curly_i</key> | |
<dict> | |
<key>begin</key> | |
<string>\{</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.scope.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\}</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_curly_i</string> | |
</dict> | |
</array> | |
</dict> | |
<key>nest_curly_r</key> | |
<dict> | |
<key>begin</key> | |
<string>\{</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.scope.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\}</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#regex_sub</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_curly_r</string> | |
</dict> | |
</array> | |
</dict> | |
<key>nest_ltgt</key> | |
<dict> | |
<key>begin</key> | |
<string>\<</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.scope.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\></string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#nest_ltgt</string> | |
</dict> | |
</array> | |
</dict> | |
<key>nest_ltgt_i</key> | |
<dict> | |
<key>begin</key> | |
<string>\<</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.scope.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\></string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_ltgt_i</string> | |
</dict> | |
</array> | |
</dict> | |
<key>nest_ltgt_r</key> | |
<dict> | |
<key>begin</key> | |
<string>\<</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.scope.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\></string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#regex_sub</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_ltgt_r</string> | |
</dict> | |
</array> | |
</dict> | |
<key>nest_parens</key> | |
<dict> | |
<key>begin</key> | |
<string>\(</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.scope.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\)</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#nest_parens</string> | |
</dict> | |
</array> | |
</dict> | |
<key>nest_parens_i</key> | |
<dict> | |
<key>begin</key> | |
<string>\(</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.scope.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\)</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_parens_i</string> | |
</dict> | |
</array> | |
</dict> | |
<key>nest_parens_r</key> | |
<dict> | |
<key>begin</key> | |
<string>\(</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.section.scope.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\)</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#regex_sub</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#nest_parens_r</string> | |
</dict> | |
</array> | |
</dict> | |
<key>regex_sub</key> | |
<dict> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#interpolated_ruby</string> | |
</dict> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.arbitrary-repitition.ruby</string> | |
</dict> | |
<key>3</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.arbitrary-repitition.ruby</string> | |
</dict> | |
</dict> | |
<key>match</key> | |
<string>(\{)\d+(,\d+)?(\})</string> | |
<key>name</key> | |
<string>string.regexp.arbitrary-repitition.ruby</string> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>\[(?:\^?\])?</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.character-class.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\]</string> | |
<key>name</key> | |
<string>string.regexp.character-class.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#escaped_char</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>begin</key> | |
<string>\(</string> | |
<key>captures</key> | |
<dict> | |
<key>0</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.group.ruby</string> | |
</dict> | |
</dict> | |
<key>end</key> | |
<string>\)</string> | |
<key>name</key> | |
<string>string.regexp.group.ruby</string> | |
<key>patterns</key> | |
<array> | |
<dict> | |
<key>include</key> | |
<string>#regex_sub</string> | |
</dict> | |
</array> | |
</dict> | |
<dict> | |
<key>captures</key> | |
<dict> | |
<key>1</key> | |
<dict> | |
<key>name</key> | |
<string>punctuation.definition.comment.ruby</string> | |
</dict> | |
</dict> | |
<key>comment</key> | |
<string>We are restrictive in what we allow to go after the comment character to avoid false positives, since the availability of comments depend on regexp flags.</string> | |
<key>match</key> | |
<string>(?<=^|\s)(#)\s[[a-zA-Z0-9,. \t?!-][^\x{00}-\x{7F}]]*$</string> | |
<key>name</key> | |
<string>comment.line.number-sign.ruby</string> | |
</dict> | |
</array> | |
</dict> | |
</dict> | |
<key>scopeName</key> | |
<string>source.ruby</string> | |
<key>uuid</key> | |
<string>E7357B44-16AD-4909-B440-6E63B327A6E1</string> | |
</dict> | |
</plist> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
on line 257 at the end of your regex I think you should replace
[?!]
with[?!:]
That should allow for properly highlighted hash keys when using those key words in hashes. e.g.