github-linguist-grammars 4.6.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (335) hide show
  1. checksums.yaml +7 -0
  2. data/grammars/file.lasso.json +713 -0
  3. data/grammars/module.ceylon.json +54 -0
  4. data/grammars/objdump.x86asm.json +73 -0
  5. data/grammars/source.Inform7.json +45 -0
  6. data/grammars/source.Kotlin.json +774 -0
  7. data/grammars/source.LS.json +104 -0
  8. data/grammars/source.MCPOST.json +68 -0
  9. data/grammars/source.MOD.json +70 -0
  10. data/grammars/source.abap.json +176 -0
  11. data/grammars/source.abl.json +138 -0
  12. data/grammars/source.actionscript.3.json +1571 -0
  13. data/grammars/source.acucobol.json +16 -0
  14. data/grammars/source.ada.json +140 -0
  15. data/grammars/source.agda.json +254 -0
  16. data/grammars/source.ahk.json +171 -0
  17. data/grammars/source.alloy.json +44 -0
  18. data/grammars/source.ampl.json +157 -0
  19. data/grammars/source.antlr.json +300 -0
  20. data/grammars/source.apache-config.json +352 -0
  21. data/grammars/source.apache-config.mod_perl.json +70 -0
  22. data/grammars/source.apl.json +442 -0
  23. data/grammars/source.applescript.json +1385 -0
  24. data/grammars/source.apt.json +25 -0
  25. data/grammars/source.asm.x86.json +182 -0
  26. data/grammars/source.asp.json +157 -0
  27. data/grammars/source.aspectj.json +963 -0
  28. data/grammars/source.ats.json +170 -0
  29. data/grammars/source.autoit.3.json +132 -0
  30. data/grammars/source.awk.json +388 -0
  31. data/grammars/source.befunge.json +38 -0
  32. data/grammars/source.bf.json +36 -0
  33. data/grammars/source.bison.json +59 -0
  34. data/grammars/source.blitzmax.json +912 -0
  35. data/grammars/source.boo.json +452 -0
  36. data/grammars/source.brightauthorproject.json +29 -0
  37. data/grammars/source.brightscript.json +158 -0
  38. data/grammars/source.bro.json +409 -0
  39. data/grammars/source.bsv.json +283 -0
  40. data/grammars/source.c++.json +364 -0
  41. data/grammars/source.c++.qt.json +37 -0
  42. data/grammars/source.c.ec.json +39 -0
  43. data/grammars/source.c.json +727 -0
  44. data/grammars/source.c.platform.json +154 -0
  45. data/grammars/source.cache.cmake.json +75 -0
  46. data/grammars/source.cake.json +16 -0
  47. data/grammars/source.camlp4.ocaml.json +63 -0
  48. data/grammars/source.capnp.json +93 -0
  49. data/grammars/source.ceylon.json +77 -0
  50. data/grammars/source.cfscript.cfc.json +170 -0
  51. data/grammars/source.cfscript.json +744 -0
  52. data/grammars/source.chapel.json +240 -0
  53. data/grammars/source.cirru.json +66 -0
  54. data/grammars/source.clarion.json +159 -0
  55. data/grammars/source.clips.json +80 -0
  56. data/grammars/source.clojure.json +397 -0
  57. data/grammars/source.cm.json +54 -0
  58. data/grammars/source.cmake.json +181 -0
  59. data/grammars/source.cobol.json +528 -0
  60. data/grammars/source.coffee.json +678 -0
  61. data/grammars/source.compiled-papyrus.json +11 -0
  62. data/grammars/source.cool.json +103 -0
  63. data/grammars/source.coq.json +62 -0
  64. data/grammars/source.crystal.json +2760 -0
  65. data/grammars/source.cs.json +556 -0
  66. data/grammars/source.css.json +630 -0
  67. data/grammars/source.css.less.json +276 -0
  68. data/grammars/source.css.mss.json +256 -0
  69. data/grammars/source.csx.json +16 -0
  70. data/grammars/source.cuda-c++.json +137 -0
  71. data/grammars/source.cython.json +2108 -0
  72. data/grammars/source.d.json +722 -0
  73. data/grammars/source.dart.json +763 -0
  74. data/grammars/source.desktop.json +90 -0
  75. data/grammars/source.diff.json +162 -0
  76. data/grammars/source.dockerfile.json +89 -0
  77. data/grammars/source.dosbatch.json +70 -0
  78. data/grammars/source.dot.json +126 -0
  79. data/grammars/source.dylan.json +217 -0
  80. data/grammars/source.eiffel.json +138 -0
  81. data/grammars/source.elixir.json +737 -0
  82. data/grammars/source.elm.json +355 -0
  83. data/grammars/source.erazor.json +126 -0
  84. data/grammars/source.erlang.json +1674 -0
  85. data/grammars/source.essl.json +50 -0
  86. data/grammars/source.factor.json +260 -0
  87. data/grammars/source.fan.json +188 -0
  88. data/grammars/source.fancy.json +270 -0
  89. data/grammars/source.fish.json +214 -0
  90. data/grammars/source.forth.json +101 -0
  91. data/grammars/source.fortran.json +499 -0
  92. data/grammars/source.fortran.modern.json +226 -0
  93. data/grammars/source.fsharp.json +403 -0
  94. data/grammars/source.gap.json +167 -0
  95. data/grammars/source.gcode.json +25 -0
  96. data/grammars/source.gdscript.json +154 -0
  97. data/grammars/source.gfm.json +1270 -0
  98. data/grammars/source.glsl.json +71 -0
  99. data/grammars/source.gnuplot.json +276 -0
  100. data/grammars/source.go.json +552 -0
  101. data/grammars/source.golo.json +182 -0
  102. data/grammars/source.gosu.2.json +163 -0
  103. data/grammars/source.grace.json +679 -0
  104. data/grammars/source.groovy.gradle.json +73 -0
  105. data/grammars/source.groovy.json +1385 -0
  106. data/grammars/source.harbour.json +450 -0
  107. data/grammars/source.haskell.json +449 -0
  108. data/grammars/source.haxe.2.json +1243 -0
  109. data/grammars/source.hss.1.json +464 -0
  110. data/grammars/source.httpspec.json +287 -0
  111. data/grammars/source.hxml.json +26 -0
  112. data/grammars/source.hy.json +270 -0
  113. data/grammars/source.idl-dlm.json +112 -0
  114. data/grammars/source.idl.json +267 -0
  115. data/grammars/source.idris.json +537 -0
  116. data/grammars/source.ini.json +113 -0
  117. data/grammars/source.inno.json +65 -0
  118. data/grammars/source.io.json +164 -0
  119. data/grammars/source.ioke.json +272 -0
  120. data/grammars/source.isabelle.root.json +68 -0
  121. data/grammars/source.isabelle.theory.json +106 -0
  122. data/grammars/source.j.json +49 -0
  123. data/grammars/source.jade.json +1009 -0
  124. data/grammars/source.jasmin.json +299 -0
  125. data/grammars/source.java-properties.json +97 -0
  126. data/grammars/source.java.json +1026 -0
  127. data/grammars/source.jcl.json +49 -0
  128. data/grammars/source.jflex.json +490 -0
  129. data/grammars/source.jq.json +218 -0
  130. data/grammars/source.js.json +948 -0
  131. data/grammars/source.js.jsx.json +2937 -0
  132. data/grammars/source.js.objj.json +424 -0
  133. data/grammars/source.js.regexp.json +150 -0
  134. data/grammars/source.js.regexp.replacement.json +30 -0
  135. data/grammars/source.json.json +149 -0
  136. data/grammars/source.julia.json +407 -0
  137. data/grammars/source.lean.json +145 -0
  138. data/grammars/source.lid.json +23 -0
  139. data/grammars/source.lilypond.json +623 -0
  140. data/grammars/source.lisp.json +111 -0
  141. data/grammars/source.litcoffee.json +669 -0
  142. data/grammars/source.livescript.json +616 -0
  143. data/grammars/source.llvm.json +71 -0
  144. data/grammars/source.logos.json +31 -0
  145. data/grammars/source.logtalk.json +315 -0
  146. data/grammars/source.loomscript.json +214 -0
  147. data/grammars/source.lsl.json +216 -0
  148. data/grammars/source.lua.json +191 -0
  149. data/grammars/source.makefile.json +474 -0
  150. data/grammars/source.makegen.json +13 -0
  151. data/grammars/source.man.json +53 -0
  152. data/grammars/source.mask.json +701 -0
  153. data/grammars/source.mata.json +133 -0
  154. data/grammars/source.mathematica.json +429 -0
  155. data/grammars/source.matlab.json +776 -0
  156. data/grammars/source.mercury.json +251 -0
  157. data/grammars/source.ml.json +291 -0
  158. data/grammars/source.modelica.json +142 -0
  159. data/grammars/source.modula2.json +103 -0
  160. data/grammars/source.monkey.json +701 -0
  161. data/grammars/source.moonscript.json +149 -0
  162. data/grammars/source.mupad.json +149 -0
  163. data/grammars/source.nant-build.json +86 -0
  164. data/grammars/source.ncl.json +66 -0
  165. data/grammars/source.nemerle.json +137 -0
  166. data/grammars/source.nesc.json +27 -0
  167. data/grammars/source.netlinx.erb.json +47 -0
  168. data/grammars/source.netlinx.json +768 -0
  169. data/grammars/source.nginx.json +797 -0
  170. data/grammars/source.nim.json +1150 -0
  171. data/grammars/source.nim_filter.json +133 -0
  172. data/grammars/source.nimcfg.json +116 -0
  173. data/grammars/source.ninja.json +66 -0
  174. data/grammars/source.nit.json +238 -0
  175. data/grammars/source.nix.json +1200 -0
  176. data/grammars/source.nmml.json +87 -0
  177. data/grammars/source.nsis.json +150 -0
  178. data/grammars/source.objc++.json +19 -0
  179. data/grammars/source.objc.json +918 -0
  180. data/grammars/source.objc.platform.json +277 -0
  181. data/grammars/source.ocaml.json +1426 -0
  182. data/grammars/source.ocamllex.json +305 -0
  183. data/grammars/source.ocamlyacc.json +346 -0
  184. data/grammars/source.octave.json +451 -0
  185. data/grammars/source.ooc.json +692 -0
  186. data/grammars/source.opa.json +206 -0
  187. data/grammars/source.opal.json +415 -0
  188. data/grammars/source.opalsysdefs.json +70 -0
  189. data/grammars/source.opencobol.json +65 -0
  190. data/grammars/source.ox.json +97 -0
  191. data/grammars/source.oz.json +84 -0
  192. data/grammars/source.papyrus-assembly.json +266 -0
  193. data/grammars/source.papyrus.json +231 -0
  194. data/grammars/source.parrot.pir.json +117 -0
  195. data/grammars/source.pascal.json +150 -0
  196. data/grammars/source.perl.6.json +310 -0
  197. data/grammars/source.perl.json +2413 -0
  198. data/grammars/source.php.zephir.json +362 -0
  199. data/grammars/source.pig_latin.json +172 -0
  200. data/grammars/source.pike.json +62 -0
  201. data/grammars/source.plsql.oracle.json +642 -0
  202. data/grammars/source.po.json +232 -0
  203. data/grammars/source.pogoscript.json +85 -0
  204. data/grammars/source.postscript.json +231 -0
  205. data/grammars/source.powershell.json +755 -0
  206. data/grammars/source.processing.json +885 -0
  207. data/grammars/source.prolog.eclipse.json +206 -0
  208. data/grammars/source.prolog.json +292 -0
  209. data/grammars/source.protobuf.json +395 -0
  210. data/grammars/source.pubspec.json +13 -0
  211. data/grammars/source.puppet.json +494 -0
  212. data/grammars/source.purescript.json +818 -0
  213. data/grammars/source.pyjade.json +1010 -0
  214. data/grammars/source.python.django.json +34 -0
  215. data/grammars/source.python.json +1960 -0
  216. data/grammars/source.python.salt.json +13 -0
  217. data/grammars/source.qmake.json +217 -0
  218. data/grammars/source.qml.json +195 -0
  219. data/grammars/source.r.json +203 -0
  220. data/grammars/source.racket.json +119 -0
  221. data/grammars/source.rebol.json +647 -0
  222. data/grammars/source.red.json +652 -0
  223. data/grammars/source.regexp.babel.json +190 -0
  224. data/grammars/source.regexp.python.json +187 -0
  225. data/grammars/source.regexp.spin.json +188 -0
  226. data/grammars/source.ruby.json +1956 -0
  227. data/grammars/source.ruby.rspec.cucumber.steps.json +274 -0
  228. data/grammars/source.rust.json +269 -0
  229. data/grammars/source.sas.json +322 -0
  230. data/grammars/source.sas_log.json +26 -0
  231. data/grammars/source.sass.json +248 -0
  232. data/grammars/source.sbt.json +36 -0
  233. data/grammars/source.scad.json +152 -0
  234. data/grammars/source.scala.json +739 -0
  235. data/grammars/source.scaml.json +466 -0
  236. data/grammars/source.scheme.json +370 -0
  237. data/grammars/source.scilab.json +103 -0
  238. data/grammars/source.scss.json +1321 -0
  239. data/grammars/source.shell.json +1212 -0
  240. data/grammars/source.smali.json +1668 -0
  241. data/grammars/source.smalltalk.json +135 -0
  242. data/grammars/source.smt.json +173 -0
  243. data/grammars/source.sp.json +118 -0
  244. data/grammars/source.sparql.json +23 -0
  245. data/grammars/source.spin.json +936 -0
  246. data/grammars/source.sqf.json +112 -0
  247. data/grammars/source.sql.json +473 -0
  248. data/grammars/source.stata.json +208 -0
  249. data/grammars/source.strings.json +53 -0
  250. data/grammars/source.stylus.json +1021 -0
  251. data/grammars/source.swift.json +965 -0
  252. data/grammars/source.systemverilog.json +1050 -0
  253. data/grammars/source.tcl.json +277 -0
  254. data/grammars/source.tea.json +180 -0
  255. data/grammars/source.thrift.json +704 -0
  256. data/grammars/source.toml.json +327 -0
  257. data/grammars/source.ts.json +1094 -0
  258. data/grammars/source.tsx.json +1324 -0
  259. data/grammars/source.turtle.json +505 -0
  260. data/grammars/source.txl.json +62 -0
  261. data/grammars/source.ucfconstraints.json +72 -0
  262. data/grammars/source.vala.json +814 -0
  263. data/grammars/source.varnish.vcl.json +343 -0
  264. data/grammars/source.vbnet.json +338 -0
  265. data/grammars/source.verilog.json +302 -0
  266. data/grammars/source.vhdl.json +1349 -0
  267. data/grammars/source.viml.json +224 -0
  268. data/grammars/source.webidl.json +814 -0
  269. data/grammars/source.x10.json +68 -0
  270. data/grammars/source.x86asm.json +47 -0
  271. data/grammars/source.xc.json +379 -0
  272. data/grammars/source.xq.json +241 -0
  273. data/grammars/source.xquery.json +193 -0
  274. data/grammars/source.xtend.json +733 -0
  275. data/grammars/source.yaml.json +334 -0
  276. data/grammars/source.yaml.salt.json +348 -0
  277. data/grammars/text.bibtex.json +251 -0
  278. data/grammars/text.cfml.basic.json +736 -0
  279. data/grammars/text.dart-analysis-output.json +162 -0
  280. data/grammars/text.dart-doccomments.json +19 -0
  281. data/grammars/text.elixir.json +45 -0
  282. data/grammars/text.gherkin.feature.json +135 -0
  283. data/grammars/text.groff.json +113 -0
  284. data/grammars/text.haml.json +299 -0
  285. data/grammars/text.html.abl.json +24 -0
  286. data/grammars/text.html.asciidoc.json +492 -0
  287. data/grammars/text.html.asdoc.json +541 -0
  288. data/grammars/text.html.asp.json +58 -0
  289. data/grammars/text.html.basic.json +552 -0
  290. data/grammars/text.html.cfm.json +811 -0
  291. data/grammars/text.html.creole.json +329 -0
  292. data/grammars/text.html.django.json +69 -0
  293. data/grammars/text.html.elixir.json +18 -0
  294. data/grammars/text.html.erb.json +157 -0
  295. data/grammars/text.html.erlang.yaws.json +72 -0
  296. data/grammars/text.html.factor.json +27 -0
  297. data/grammars/text.html.handlebars.json +783 -0
  298. data/grammars/text.html.jsp.json +1203 -0
  299. data/grammars/text.html.liquid.json +35 -0
  300. data/grammars/text.html.mako.json +729 -0
  301. data/grammars/text.html.markdown.source.gfm.apib.json +1297 -0
  302. data/grammars/text.html.markdown.source.gfm.mson.json +1165 -0
  303. data/grammars/text.html.mediawiki.json +972 -0
  304. data/grammars/text.html.php.json +2607 -0
  305. data/grammars/text.html.slash.json +313 -0
  306. data/grammars/text.html.smarty.json +216 -0
  307. data/grammars/text.html.ssp.json +49 -0
  308. data/grammars/text.html.tcl.json +44 -0
  309. data/grammars/text.html.twig.json +1353 -0
  310. data/grammars/text.html.vue.json +642 -0
  311. data/grammars/text.idl-idldoc.json +14 -0
  312. data/grammars/text.junit-test-report.json +92 -0
  313. data/grammars/text.log.latex.json +86 -0
  314. data/grammars/text.python.console.json +25 -0
  315. data/grammars/text.python.traceback.json +46 -0
  316. data/grammars/text.rdoc.json +48 -0
  317. data/grammars/text.restructuredtext.json +561 -0
  318. data/grammars/text.robot.json +73 -0
  319. data/grammars/text.shell-session.json +48 -0
  320. data/grammars/text.slim.json +527 -0
  321. data/grammars/text.tex.json +271 -0
  322. data/grammars/text.tex.latex.beamer.json +63 -0
  323. data/grammars/text.tex.latex.haskell.json +56 -0
  324. data/grammars/text.tex.latex.json +1013 -0
  325. data/grammars/text.tex.latex.memoir.json +99 -0
  326. data/grammars/text.tex.latex.rd.json +117 -0
  327. data/grammars/text.xml.ant.json +202 -0
  328. data/grammars/text.xml.flex-config.json +2634 -0
  329. data/grammars/text.xml.genshi.json +34 -0
  330. data/grammars/text.xml.json +364 -0
  331. data/grammars/text.xml.pom.json +774 -0
  332. data/grammars/text.xml.xsl.json +94 -0
  333. data/grammars/text.zone_file.json +72 -0
  334. data/lib/linguist/grammars.rb +13 -0
  335. metadata +389 -0
@@ -0,0 +1,145 @@
1
+ {
2
+ "fileTypes": [
3
+ "lean",
4
+ "hlean"
5
+ ],
6
+ "name": "Lean",
7
+ "patterns": [
8
+ {
9
+ "include": "#dashComment"
10
+ },
11
+ {
12
+ "include": "#blockComment"
13
+ },
14
+ {
15
+ "begin": "^\\s*(import)\\b",
16
+ "beginCaptures": {
17
+ "1": {
18
+ "name": "keyword.other.lean"
19
+ }
20
+ },
21
+ "end": "$",
22
+ "name": "meta.import.lean",
23
+ "patterns": [
24
+
25
+ ]
26
+ },
27
+ {
28
+ "begin": "\\b(inductive|structure|record|theorem|proposition|axiom|axioms|lemma|hypothesis|definition|constant)\\b[ \\t\\n\\r({\\[]+([^ \\t\\n\\r{(\\[]*)",
29
+ "beginCaptures": {
30
+ "1": {
31
+ "name": "keyword.other.lean"
32
+ },
33
+ "2": {
34
+ "name": "variable.language.lean"
35
+ }
36
+ },
37
+ "end": "[ \\t\\n\\r{(\\[]",
38
+ "name": "meta.names.lean",
39
+ "pattern": [
40
+
41
+ ]
42
+ },
43
+ {
44
+ "begin": "\"",
45
+ "end": "\"",
46
+ "name": "string.quoted.double.lean",
47
+ "patterns": [
48
+ {
49
+ "match": "\\\\.",
50
+ "name": "constant.character.escape.lean"
51
+ }
52
+ ]
53
+ },
54
+ {
55
+ "match": "\\b(Prop|Type[\\'₊₀-₉]?)",
56
+ "name": "storage.type.lean"
57
+ },
58
+ {
59
+ "match": "\\[persistent\\]|\\[notation\\]|\\[visible\\]|\\[instance\\]|\\[class\\]|\\[parsing-only\\]|\\[coercion\\]|\\[reducible\\]|\\[irreducible\\]|\\[wf\\]|\\[whnf\\]|\\[multiple-instances\\]|\\[decls\\]|\\[declarations\\]|\\[all-transparent\\]|\\[constructor\\]|\\[symm\\]|\\[refl\\]|\\[trans\\]|\\[recursor\\]|\\[unfold\\]|\\[unfold-all\\]|\\[congr\\]|\\[simp\\]|\\[coercions\\]|\\[classes\\]|\\[notations\\]|\\[abbreviations\\]|\\[begin-end-hints\\]|\\[tactic-hints\\]|\\[reduce-hints\\]",
60
+ "name": "storage.modifier.lean"
61
+ },
62
+ {
63
+ "match": "\\b(import|prelude|tactic_hint|theory|protected|private|noncomputable|opaque|definition|renaming|hiding|exposing|parameter|parameters|begin|proof|qed|conjecture|constant|constants|hypothesis|lemma|corollary|variable|variables|premise|premises|print|theorem|example|abbreviation|context|open|as|export|axiom|inductive|with|structure|record|universe|universes|alias|help|environment|options|override|precedence|reserve|postfix|prefix|match|infix|infixl|infixr|notation|eval|check|exit|coercion|end|using|namespace|section|fields|find_decl|attribute|local|set_option|add_rewrite|extends|include|omit|classes|instances|coercions|metaclasses|raw)\\b",
64
+ "name": "keyword.other.lean"
65
+ },
66
+ {
67
+ "match": "\\b(calc|have|assert|suppose|this|obtains|suffices|show|by|in|at|let|forall|fun|exists|if|dif|then|else|assume|take|obtain|from)\\b",
68
+ "name": "keyword.other.lean"
69
+ },
70
+ {
71
+ "match": "(->|==|:=|<->|\\\\/|/\\\\|<=|>=|⁻¹)",
72
+ "name": "constant.language.lua"
73
+ },
74
+ {
75
+ "match": "[#@∼↔/=∧∨≠<>≤≥¬⬝▸+*-]",
76
+ "name": "constant.language.lua"
77
+ },
78
+ {
79
+ "match": "(?<=\\s)[=→λ∀?]",
80
+ "name": "keyword.operator.lean"
81
+ },
82
+ {
83
+ "begin": "\"",
84
+ "beginCaptures": {
85
+ "0": {
86
+ "name": "punctuation.definition.string.begin.lean"
87
+ }
88
+ },
89
+ "end": "\"",
90
+ "endCaptures": {
91
+ "0": {
92
+ "name": "punctuation.definition.string.end.lean"
93
+ }
94
+ },
95
+ "name": "string.quoted.double.lean",
96
+ "patterns": [
97
+ {
98
+ "match": "\\\\(NUL|SOH|STX|ETX|EOT|ENQ|ACK|BEL|BS|HT|LF|VT|FF|CR|SO|SI|DLE|DC1|DC2|DC3|DC4|NAK|SYN|ETB|CAN|EM|SUB|ESC|FS|GS|RS|US|SP|DEL|[abfnrtv\\\\\\\"'\\&])",
99
+ "name": "constant.character.escape.lean"
100
+ },
101
+ {
102
+ "match": "\\\\o[0-7]+|\\\\x[0-9A-Fa-f]+|\\\\[0-9]+",
103
+ "name": "constant.character.escape.octal.lean"
104
+ },
105
+ {
106
+ "match": "\\^[A-Z@\\[\\]\\\\\\^_]",
107
+ "name": "constant.character.escape.control.lean"
108
+ }
109
+ ]
110
+ },
111
+ {
112
+ "match": "\\b([0-9]+|0([xX][0-9a-fA-F]+))\\b",
113
+ "name": "constant.numeric.lean"
114
+ }
115
+ ],
116
+ "repository": {
117
+ "blockComment": {
118
+ "begin": "/-",
119
+ "captures": {
120
+ "0": {
121
+ "name": "punctuation.definition.comment.lean"
122
+ }
123
+ },
124
+ "end": "-/",
125
+ "name": "comment.block.lean"
126
+ },
127
+ "dashComment": {
128
+ "begin": "(--)",
129
+ "beginCaptures": {
130
+ "0": {
131
+ "name": "punctuation.definition.comment.lean"
132
+ }
133
+ },
134
+ "end": "$",
135
+ "name": "comment.line.double-dash.lean"
136
+ },
137
+ "identifier": {
138
+ "comment": "not so much here to be used as to be a reference",
139
+ "match": "\\b[^\\(\\)\\{\\}[:space:]=→λ∀?][^\\(\\)\\{\\}[:space:]]*",
140
+ "name": "entity.name.function.lean"
141
+ }
142
+ },
143
+ "scopeName": "source.lean",
144
+ "uuid": "BCCD7FA1-4C45-41B2-B1C9-C850F00AFCD8"
145
+ }
@@ -0,0 +1,23 @@
1
+ {
2
+ "fileTypes": [
3
+ "lid"
4
+ ],
5
+ "name": "Lid File",
6
+ "patterns": [
7
+ {
8
+ "begin": "([\\x{21}-\\x{39}\\x{3B}-\\x{7E}]+)(:)\\s*",
9
+ "beginCaptures": {
10
+ "1": {
11
+ "name": "keyword.other.mail"
12
+ },
13
+ "2": {
14
+ "name": "punctuation.separator.key-value.mail"
15
+ }
16
+ },
17
+ "end": "^(?![ \\t\\v])",
18
+ "name": "meta.header.mail"
19
+ }
20
+ ],
21
+ "scopeName": "source.lid",
22
+ "uuid": "7E074E76-1515-4B0D-BFAB-E0D9D8854163"
23
+ }
@@ -0,0 +1,623 @@
1
+ {
2
+ "comment": "\n\t\tThis bundle is, as can easily be seen, far from complete,\n\t\tbut it should still be as useful as the Lilypond.app pyobjc\n\t\tapplication, which has no syntax coloring, no way to do\n\t\tsnippets, and pretty much no interesting functionality at\n\t\tall, other than a \"Run\" menu option. :)\n\t",
3
+ "fileTypes": [
4
+ "ly",
5
+ "lily",
6
+ "ily"
7
+ ],
8
+ "keyEquivalent": "^~L",
9
+ "name": "LilyPond",
10
+ "patterns": [
11
+ {
12
+ "include": "#comments"
13
+ },
14
+ {
15
+ "include": "#g_header"
16
+ },
17
+ {
18
+ "include": "#groupings"
19
+ },
20
+ {
21
+ "include": "#strings"
22
+ },
23
+ {
24
+ "include": "#scheme"
25
+ },
26
+ {
27
+ "include": "#functions"
28
+ }
29
+ ],
30
+ "repository": {
31
+ "comments": {
32
+ "patterns": [
33
+ {
34
+ "begin": "%{",
35
+ "captures": {
36
+ "0": {
37
+ "name": "punctuation.definition.comment.lilypond"
38
+ }
39
+ },
40
+ "end": "%}",
41
+ "name": "comment.block.lilypond"
42
+ },
43
+ {
44
+ "begin": "(^[ \\t]+)?(?=%)",
45
+ "beginCaptures": {
46
+ "1": {
47
+ "name": "punctuation.whitespace.comment.leading.lilypond"
48
+ }
49
+ },
50
+ "end": "(?!\\G)",
51
+ "patterns": [
52
+ {
53
+ "begin": "%",
54
+ "beginCaptures": {
55
+ "0": {
56
+ "name": "punctuation.definition.comment.lilypond"
57
+ }
58
+ },
59
+ "end": "\\n",
60
+ "name": "comment.line.percentage.lilypond"
61
+ }
62
+ ]
63
+ }
64
+ ]
65
+ },
66
+ "f_clef": {
67
+ "captures": {
68
+ "1": {
69
+ "name": "support.function.element.lilypond"
70
+ },
71
+ "2": {
72
+ "name": "punctuation.definition.function.lilypond"
73
+ },
74
+ "3": {
75
+ "name": "punctuation.definition.string.lilypond"
76
+ },
77
+ "4": {
78
+ "name": "constant.language.clef-name.lilypond"
79
+ },
80
+ "5": {
81
+ "name": "constant.other.modifier.clef.lilypond"
82
+ },
83
+ "6": {
84
+ "name": "meta.fixme.unknown-clef-name.lilypond"
85
+ },
86
+ "7": {
87
+ "name": "constant.other.modifier.clef.lilypond"
88
+ },
89
+ "8": {
90
+ "name": "punctuation.definition.string.lilypond"
91
+ }
92
+ },
93
+ "comment": "\n\t\t\t\tThis looks something like: \\clef mezzosoprano_8\n\t\t\t\tOr maybe: \\clef neomensural-c3^15\n\t\t\t",
94
+ "match": "(?x)\n\t\t\t\t((\\\\) clef) \\s+ # backslash + \"clef\" + spaces (groups 1-2)\n\t\t\t\t(?:\n\t\t\t\t (\"?)\t# beginning quotes (group 3)\n\t\t\t\t (?:\n\t\t\t\t\t ( (?: # group 4\n\t\t\t\t\t\t treble | violin | G | french | # G clefs\n\t\t\t\t\t alto | C | tenor | (?:mezzo)?soprano | baritone | # C clefs\n\t\t\t\t\t (?:sub)?bass | F | varbaritone | # F clefs\n\t\t\t\t\t percussion | tab | # percussion / tablature clefs\n \n\t\t\t\t (?:neo)?mensural-c[1-4] | mensural-[fg] | \t\t# Ancient clefs\n\t\t\t\t\t petrucci-(?: [fg] | c[1-5] ) |\n\t\t\t\t\t (?: vaticana | medicaea | hufnagel ) - (?: do[1-3] | fa[12] ) |\n\t\t\t\t\t hufnagel-do-fa\n\t\t\t\t\t )\n\t\t\t\t\t ([_^](?:8|15)?)? # optionally shift 1-2 octaves ↑/↓ (group 5)\n\t\t\t\t\t ) |\n\t\t\t\t\t ( (?:\\w+) ([_^](?:8|15))? ) # unknown clef name (groups 6-7)\n\t\t\t\t )\n\t\t\t\t (\\3) # closing quotes (group 8)\n\t\t\t\t)?\n\t\t\t",
95
+ "name": "meta.element.clef.lilypond"
96
+ },
97
+ "f_generic": {
98
+ "captures": {
99
+ "1": {
100
+ "name": "punctuation.definition.function.lilypond"
101
+ }
102
+ },
103
+ "match": "(\\\\)[a-zA-Z-]+\\b",
104
+ "name": "support.function.general.lilypond"
105
+ },
106
+ "f_key-signature": {
107
+ "comment": "FIXME",
108
+ "name": "meta.element.key-signature.lilypond"
109
+ },
110
+ "f_keywords": {
111
+ "captures": {
112
+ "1": {
113
+ "name": "punctuation.definition.function.lilypond"
114
+ }
115
+ },
116
+ "match": "(?x)\n\t\t\t\t(?: (\\\\)\n\t\t\t\t (?: set | new | override | revert)\\b\n\t\t\t\t)\n\t\t\t",
117
+ "name": "keyword.control.lilypond"
118
+ },
119
+ "f_time-signature": {
120
+ "captures": {
121
+ "1": {
122
+ "name": "support.function.element.lilypond"
123
+ },
124
+ "2": {
125
+ "name": "punctuation.definition.function.lilypond"
126
+ },
127
+ "3": {
128
+ "name": "constant.numeric.time-signature.lilypond"
129
+ }
130
+ },
131
+ "match": "(?x)\n\t\t\t\t((\\\\) time) \\s+ # backslash + \"time\" + spaces (groups 1-2)\n\t\t\t\t([1-9][0-9]*/[1-9][0-9]*)?\n\t\t\t",
132
+ "name": "meta.element.time-signature.lilypond"
133
+ },
134
+ "functions": {
135
+ "patterns": [
136
+ {
137
+ "include": "#f_clef"
138
+ },
139
+ {
140
+ "include": "#f_time-signature"
141
+ },
142
+ {
143
+ "include": "#f_key-signature"
144
+ },
145
+ {
146
+ "include": "#f_keywords"
147
+ },
148
+ {
149
+ "include": "#f_generic"
150
+ }
151
+ ]
152
+ },
153
+ "g_header": {
154
+ "begin": "((\\\\)header)\\s*({)",
155
+ "beginCaptures": {
156
+ "1": {
157
+ "name": "support.function.section.header.lilypond"
158
+ },
159
+ "2": {
160
+ "name": "punctuation.definition.function.lilypond"
161
+ },
162
+ "3": {
163
+ "name": "punctuation.section.group.begin.lilypond"
164
+ }
165
+ },
166
+ "end": "}",
167
+ "endCaptures": {
168
+ "0": {
169
+ "name": "punctuation.section.group.end.lilypond"
170
+ }
171
+ },
172
+ "name": "meta.header.lilypond",
173
+ "patterns": [
174
+ {
175
+ "include": "#comments"
176
+ },
177
+ {
178
+ "include": "#strings"
179
+ },
180
+ {
181
+ "include": "#scheme"
182
+ },
183
+ {
184
+ "include": "#g_markup"
185
+ },
186
+ {
187
+ "match": "=",
188
+ "name": "punctuation.separator.key-value.lilypond"
189
+ },
190
+ {
191
+ "match": "(?x)\n\t\t\t\t\t\tdedication | title | subtitle | subsubtitle | poet |\n\t\t\t\t\t\tcomposer | meter | opus | arranger | instrument |\n\t\t\t\t\t\tpiece | breakbefore | copyright | tagline | enteredby\n\t\t\t\t\t",
192
+ "name": "support.constant.header.lilypond"
193
+ },
194
+ {
195
+ "match": "(?x)\n\t\t\t\t\t\tmutopiatitle | mutopiacomposer | mutopiapoet |\n\t\t\t\t\t\tmutopiaopus | mutopiainstrument | date | source |\n\t\t\t\t\t\tstyle | maintainer | maintainerEmail |\n\t\t\t\t\t\tmaintainerWeb | lastupdated\n\t\t\t\t\t",
196
+ "name": "support.constant.header.mutopia.lilypond"
197
+ }
198
+ ]
199
+ },
200
+ "g_m_group": {
201
+ "begin": "{",
202
+ "beginCaptures": {
203
+ "0": {
204
+ "name": "punctuation.section.group.begin.lilypond"
205
+ }
206
+ },
207
+ "end": "}",
208
+ "endCaptures": {
209
+ "0": {
210
+ "name": "punctuation.section.group.end.lilypond"
211
+ }
212
+ },
213
+ "name": "meta.group.lilypond",
214
+ "patterns": [
215
+ {
216
+ "include": "#f_generic"
217
+ },
218
+ {
219
+ "include": "#strings"
220
+ },
221
+ {
222
+ "include": "#comments"
223
+ },
224
+ {
225
+ "include": "#scheme"
226
+ },
227
+ {
228
+ "include": "#g_m_group"
229
+ }
230
+ ]
231
+ },
232
+ "g_markup": {
233
+ "begin": "(?x)\n\t\t\t\t((\\\\) markup) \\s+ # backslash + \"markup\" + spaces\n\t\t\t\t(?={)\n\t\t\t",
234
+ "beginCaptures": {
235
+ "1": {
236
+ "name": "support.function.element.markup.lilypond"
237
+ },
238
+ "2": {
239
+ "name": "punctuation.definition.function.markup"
240
+ }
241
+ },
242
+ "end": "(?<=})",
243
+ "name": "meta.element.markup.lilypond",
244
+ "patterns": [
245
+ {
246
+ "include": "#g_m_group"
247
+ }
248
+ ]
249
+ },
250
+ "g_relative": {
251
+ "begin": "((\\\\)relative)\\s*(?:([a-h][',]*)\\s*)?(?={)",
252
+ "beginCaptures": {
253
+ "1": {
254
+ "name": "support.function.section.lilypond"
255
+ },
256
+ "2": {
257
+ "name": "punctuation.definition.function.lilypond"
258
+ },
259
+ "3": {
260
+ "name": "storage.type.pitch.lilypond"
261
+ }
262
+ },
263
+ "end": "(?<=})",
264
+ "patterns": [
265
+ {
266
+ "include": "#group"
267
+ }
268
+ ]
269
+ },
270
+ "g_system": {
271
+ "begin": "<<",
272
+ "beginCaptures": {
273
+ "0": {
274
+ "name": "punctuation.section.system.begin.lilypond"
275
+ }
276
+ },
277
+ "end": ">>",
278
+ "endCaptures": {
279
+ "0": {
280
+ "name": "punctuation.section.system.end.lilypond"
281
+ }
282
+ },
283
+ "name": "meta.system.lilypond",
284
+ "patterns": [
285
+ {
286
+ "include": "$self"
287
+ }
288
+ ]
289
+ },
290
+ "g_times": {
291
+ "begin": "((\\\\)times)\\s*(?:([1-9][0-9]*/[1-9][0-9])\\s*)(?={)",
292
+ "beginCaptures": {
293
+ "1": {
294
+ "name": "support.function.section.lilypond"
295
+ },
296
+ "2": {
297
+ "name": "punctuation.definition.function.lilypond"
298
+ },
299
+ "3": {
300
+ "name": "constant.numeric.fraction.lilypond"
301
+ }
302
+ },
303
+ "end": "(?<=})",
304
+ "patterns": [
305
+ {
306
+ "include": "#group"
307
+ }
308
+ ]
309
+ },
310
+ "group": {
311
+ "begin": "{",
312
+ "beginCaptures": {
313
+ "0": {
314
+ "name": "punctuation.section.group.begin.lilypond"
315
+ }
316
+ },
317
+ "end": "}",
318
+ "endCaptures": {
319
+ "0": {
320
+ "name": "punctuation.section.group.end.lilypond"
321
+ }
322
+ },
323
+ "name": "meta.music-expression.lilypond",
324
+ "patterns": [
325
+ {
326
+ "include": "#music-expr"
327
+ }
328
+ ]
329
+ },
330
+ "groupings": {
331
+ "patterns": [
332
+ {
333
+ "include": "#g_system"
334
+ },
335
+ {
336
+ "include": "#g_relative"
337
+ },
338
+ {
339
+ "include": "#g_times"
340
+ },
341
+ {
342
+ "include": "#group"
343
+ }
344
+ ]
345
+ },
346
+ "music-expr": {
347
+ "patterns": [
348
+ {
349
+ "include": "#comments"
350
+ },
351
+ {
352
+ "include": "#groupings"
353
+ },
354
+ {
355
+ "include": "#strings"
356
+ },
357
+ {
358
+ "include": "#functions"
359
+ },
360
+ {
361
+ "include": "#scheme"
362
+ },
363
+ {
364
+ "include": "#notes"
365
+ }
366
+ ]
367
+ },
368
+ "n_articulations": {
369
+ "patterns": [
370
+ {
371
+ "match": "(?x)\n\t\t\t\t\t\t([_^-])\n\t\t\t\t\t\t(?:[.>^+|_-])\n\t\t\t\t\t",
372
+ "name": "storage.modifier.articulation.accent.lilypond"
373
+ },
374
+ {
375
+ "captures": {
376
+ "1": {
377
+ "name": "punctuation.definition.function.lilypond"
378
+ }
379
+ },
380
+ "match": "(?x)\n\t\t\t\t\t\t(\\\\)\n\t\t\t\t\t\t(?: accent | markato | staccatissimo |\t\t # basic accents\n\t\t\t\t\t\t\tespressivo | staccato | tenuto | portato | \n\t\t\t\t\t\t\t(?:up|down)bow | flageolet | thumb |\n\t\t\t\t\t\t\t[lr](?:heel|toe) | open | stopped |\n\t\t\t\t\t\t\t(?:reverse)?turn | trill |\n\t\t\t\t\t\t\tprall(?: prall | mordent | down | up)? | # pralls\n\t\t\t\t\t\t\t(?: up | down | line ) prall | # and\n\t\t\t\t\t\t\t(?: up | down )? mordent | # mordents\n\t\t\t\t\t\t\tsignumcongruentiae |\n\t\t\t\t\t\t\t(?: (?:very)? long | short)?fermata(Markup)? | # fermatas\n\t\t\t\t\t\t\tsegno | (?:var)?coda \n\t\t\t\t\t\t)\n\t\t\t\t\t",
381
+ "name": "storage.modifier.articulation.named.lilypond"
382
+ },
383
+ {
384
+ "match": "(?x)\n\t\t\t\t\t\t(\\\\) # backslash\n\t\t\t\t\t\t(?:\n\t\t\t\t\t\t p{1,5} | m[pf] | f{1,4} | fp | # forte, piano, etc.\n \t\t\t\t\t\t[sr]fz | sff? | spp? | \n \t\t\t\t\t\t< | > | ! | espressivo # (de)crescendo\n\t\t\t\t\t\t)\n\t\t\t\t\t",
385
+ "name": "storage.modifier.articulation.dynamics.lilypond"
386
+ },
387
+ {
388
+ "match": "\\[|\\]",
389
+ "name": "storage.modifier.beam.lilypond"
390
+ },
391
+ {
392
+ "match": "\\(|\\)",
393
+ "name": "storage.modifier.slur.lilypond"
394
+ },
395
+ {
396
+ "match": "\\\\\\(|\\\\\\)",
397
+ "name": "storage.modifier.slur.phrasing.lilypond"
398
+ }
399
+ ]
400
+ },
401
+ "notes": {
402
+ "comment": "\n\t\t\t\tThis section includes the rules for notes, rests, and chords\n\t\t\t",
403
+ "patterns": [
404
+ {
405
+ "begin": "(?x)\\b\n\t\t\t\t\t (\t\t\t\t\t\t # (group 1)\n\t\t\t\t\t\t ( [a-h] # Pitch (group 2)\n\t\t\t\t\t\t ( (?:i[sh]){1,2} | # - sharp (group 3)\n\t\t\t\t\t\t (?:e[sh]|s){1,2} # - flat\n\t\t\t\t\t\t )?\n\t\t\t\t\t (?:(\\!)|(\\?))? # Cautionary accidental (groups 4-5)\n\t\t\t\t\t ('+|,+)? # Octave (group 6)\n\t\t\t\t\t\t )\n\t\t\t\t\t\t ( ( ((\\\\)breve)| # Duration (groups 7-10)\n\t\t\t\t\t\t 64|32|16|8|4|2|1\n\t\t\t\t\t\t )\n\t\t\t\t\t\t (\\.+)? # Augmentation dot (group 11)\n\t\t\t\t\t\t\t((?:(\\*)(\\d+(?:/\\d+)?))*) # Scaling duration (groups 12-14)\n\t\t\t\t\t\t )?\n\t\t\t\t\t\t)(?![a-z])\t# do not follow a note with a letter\n\t\t\t\t\t",
406
+ "beginCaptures": {
407
+ "10": {
408
+ "name": "punctuation.definition.function.lilypond"
409
+ },
410
+ "13": {
411
+ "name": "keyword.operator.duration-scale.lilypond"
412
+ },
413
+ "14": {
414
+ "name": "constant.numeric.fraction.lilypond"
415
+ },
416
+ "2": {
417
+ "name": "storage.type.pitch.lilypond"
418
+ },
419
+ "4": {
420
+ "name": "meta.note-modifier.accidental.reminder.lilypond"
421
+ },
422
+ "5": {
423
+ "name": "meta.note-modifier.accidental.cautionary.lilypond"
424
+ },
425
+ "6": {
426
+ "name": "meta.note-modifier.octave.lilypond"
427
+ },
428
+ "7": {
429
+ "name": "storage.type.duration.lilypond"
430
+ }
431
+ },
432
+ "comment": "\n\t\t\t\t\t\tThis rule handles notes, including the pitch, the\n\t\t\t\t\t\tduration, and any articulations drawn along with\n\t\t\t\t\t\tthe note.\n\t\t\t\t\t\t\n\t\t\t\t\t\tThis rule gets a whole lot uglier if we want to\n\t\t\t\t\t\tsupport multilingual note names. If so, the rule\n\t\t\t\t\t\tgoes something like:\n\t\t\t\t\t\t\n\t\t\t\t\t\t(?x)\n\t\t\t\t\t\t\t\\b( # Basic Pitches\n\t\t\t\t\t\t\t [a-h] # Dutch/English/etc. \n\t\t\t\t\t\t\t (?: (iss?|s|sharp|x)(iss?|s|sharp|x|ih) | # sharp / flat\n\t\t\t\t\t\t\t\t (ess?|s|flat|f)(ess?|s|flat|f|eh)\n\t\t\t\t\t\t\t )? |\n\t\t\t\t\t\t\t (?: do|re|mi|fa|sol|la|si) # Italian/Spanish\n\t\t\t\t\t\t\t (?: ss?|dd?bb?) # sharp/flat\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t...\n\t\t\t\t\t",
433
+ "end": "(?x)\n\t\t\t\t\t\t(?= [\\s}~a-z] |$) # End when we encounter a space or } or end of line\n\t\t\t\t\t",
434
+ "name": "meta.element.note.lilypond",
435
+ "patterns": [
436
+ {
437
+ "include": "#n_articulations"
438
+ }
439
+ ]
440
+ },
441
+ {
442
+ "begin": "(?x)\\b\n\t\t\t\t\t\t(?:(r)|(R)) # (groups 1-2)\n\t\t\t\t\t\t( ( (\\\\)breve| # Duration (groups 3-5)\n\t\t\t\t\t\t 64|32|16|8|4|2|1\n\t\t\t\t\t\t )\n\t\t\t\t\t\t (\\.+)? # Augmentation dot (group 6)\n\t\t\t\t\t\t ((?:(\\*)(\\d+(?:/\\d+)?))*) # Scaling duration (groups 7-9)\n\t\t\t\t\t\t\n\t\t\t\t\t\t)?\n\t\t\t\t\t\t(?![a-z])\t# do not follow a note with a letter\n\t\t\t\t\t",
443
+ "beginCaptures": {
444
+ "1": {
445
+ "name": "storage.type.pause.rest.lilypond"
446
+ },
447
+ "2": {
448
+ "name": "storage.type.pause.rest.multi-measure.lilypond"
449
+ },
450
+ "3": {
451
+ "name": "storage.type.duration.lilypond"
452
+ },
453
+ "5": {
454
+ "name": "punctuation.definition.function.lilypond"
455
+ },
456
+ "7": {
457
+ "name": "keyword.operator.duration-scale.lilypond"
458
+ },
459
+ "9": {
460
+ "name": "constant.numeric.fraction.lilypond"
461
+ }
462
+ },
463
+ "end": "(?=[\\s}~a-z])",
464
+ "name": "meta.element.pause.rest.lilypond",
465
+ "patterns": [
466
+ {
467
+ "include": "#n_articulations"
468
+ }
469
+ ]
470
+ },
471
+ {
472
+ "begin": "(?x)\\b\n\t\t\t\t\t\t(s) # (group 1)\n\t\t\t\t\t\t( ( (\\\\)breve| # Duration (groups 2-4)\n\t\t\t\t\t\t 64|32|16|8|4|2|1\n\t\t\t\t\t\t )\n\t\t\t\t\t\t (\\.+)? # Augmentation dot (group 5)\n\t\t\t\t\t\t ((?:(\\*)(\\d+(?:/\\d+)?))*) # Scaling duration (groups 6-8)\n\t\t\t\t\t\t\n\t\t\t\t\t\t)?\n\t\t\t\t\t\t(?![a-z])\t# do not follow a note with a letter\n\t\t\t\t\t",
473
+ "beginCaptures": {
474
+ "1": {
475
+ "name": "storage.type.pause.skip.lilypond"
476
+ },
477
+ "2": {
478
+ "name": "storage.type.duration.lilypond"
479
+ },
480
+ "4": {
481
+ "name": "punctuation.definition.function.lilypond"
482
+ },
483
+ "6": {
484
+ "name": "keyword.operator.duration-scale.lilypond"
485
+ },
486
+ "8": {
487
+ "name": "constant.numeric.fraction.lilypond"
488
+ }
489
+ },
490
+ "end": "(?=[\\s}~a-z]|$)",
491
+ "name": "meta.element.pause.skip.lilypond",
492
+ "patterns": [
493
+ {
494
+ "include": "#n_articulations"
495
+ }
496
+ ]
497
+ },
498
+ {
499
+ "captures": {
500
+ "1": {
501
+ "name": "storage.type.pause.skip.lilypond"
502
+ },
503
+ "2": {
504
+ "name": "punctuation.definition.function.lilypond"
505
+ },
506
+ "3": {
507
+ "name": "storage.type.duration.lilypond"
508
+ }
509
+ },
510
+ "match": "((\\\\)skip)\\s+(64|32|16|8|4|2|1)",
511
+ "name": "meta.element.pause.skip.lilypond"
512
+ },
513
+ {
514
+ "begin": "<",
515
+ "beginCaptures": {
516
+ "0": {
517
+ "name": "punctuation.definition.chord.lilypond"
518
+ }
519
+ },
520
+ "comment": "\n\t\t\t\t\t\tLilypond chords look like: < a b c >\n\t\t\t\t\t",
521
+ "end": ">",
522
+ "endCaptures": {
523
+ "0": {
524
+ "name": "punctuation.definition.chord.lilypond"
525
+ }
526
+ },
527
+ "name": "meta.element.chord.lilypond",
528
+ "patterns": [
529
+ {
530
+ "captures": {
531
+ "1": {
532
+ "name": "storage.type.pitch.lilypond"
533
+ },
534
+ "3": {
535
+ "name": "meta.note-modifier.accidental.reminder.lilypond"
536
+ },
537
+ "4": {
538
+ "name": "meta.note-modifier.accidental.cautionary.lilypond"
539
+ },
540
+ "5": {
541
+ "name": "meta.note-modifier.octave.lilypond"
542
+ }
543
+ },
544
+ "match": "(?x)\\b\n\t\t\t\t\t\t\t\t ( [a-h] # Pitch (group 1)\n\t\t\t\t\t\t\t\t ( (?:i[sh]){1,2} | # - sharp (group 2)\n\t\t\t\t\t\t\t\t (?:e[sh]|s){1,2} # - flat\n\t\t\t\t\t\t\t\t )?\n\t\t\t\t\t\t\t (?:(\\!)|(\\?))? # Reminder/cautionary accidental (groups 3-4)\n\t\t\t\t\t\t\t ('+|,+)? # Octave (group 5)\n\t\t\t\t\t\t\t\t )\n\t\t\t\t\t\t\t"
545
+ }
546
+ ]
547
+ },
548
+ {
549
+ "begin": "(?x)\n\t\t\t\t\t (?<!-)\n\t\t\t\t\t (?<=>)\n\t\t\t\t\t\t(\n\t\t\t\t\t\t\t( ( ((\\\\)breve)| # Duration (groups 1-4)\n\t\t\t\t\t\t\t 64|32|16|8|4|2|1\n\t\t\t\t\t\t\t )\n\t\t\t\t\t\t\t (\\.+)? # Augmentation dot (group 5)\n\t\t\t\t\t\t\t) |\n\t\t\t\t\t\t\t(?![\\s}~a-z]|$)\n\t\t\t\t\t\t)\n\t\t\t\t\t",
550
+ "beginCaptures": {
551
+ "1": {
552
+ "name": "storage.type.duration.lilypond"
553
+ },
554
+ "4": {
555
+ "name": "punctuation.definition.function.lilypond"
556
+ }
557
+ },
558
+ "comment": "\n\t\t\t\t\t\tThis rule attaches stuff to the end of a chord\n\t\t\t\t\t\t\n\t\t\t\t\t\tTherefore it begins after the > which ends a chord,\n\t\t\t\t\t\tand does not end after a > which ends a chord.\n\t\t\t\t\t\t(to avoid infinite loops)\n\t\t\t\t\t",
559
+ "end": "(?=[\\s}~a-z]|$)(?<![^-]>)",
560
+ "name": "meta.element.chord.lilypond",
561
+ "patterns": [
562
+ {
563
+ "include": "#n_articulations"
564
+ }
565
+ ]
566
+ },
567
+ {
568
+ "match": "~",
569
+ "name": "storage.type.tie.lilypond"
570
+ },
571
+ {
572
+ "captures": {
573
+ "1": {
574
+ "name": "punctuation.definition.function.lilypond"
575
+ }
576
+ },
577
+ "match": "(\\\\)breathe",
578
+ "name": "storage.type.breath-mark.lilypond"
579
+ }
580
+ ]
581
+ },
582
+ "scheme": {
583
+ "begin": "(^[ \\t])?(?=#)",
584
+ "beginCaptures": {
585
+ "0": {
586
+ "name": "punctuation.whitespace.embedded.leading.scheme"
587
+ }
588
+ },
589
+ "end": "(?!\\G)",
590
+ "patterns": [
591
+ {
592
+ "begin": "#",
593
+ "contentName": "source.scheme",
594
+ "end": "(?=[\\s%])|(?<=\\n)",
595
+ "name": "meta.embedded.line.scheme",
596
+ "patterns": [
597
+ {
598
+ "include": "source.scheme"
599
+ }
600
+ ]
601
+ }
602
+ ]
603
+ },
604
+ "strings": {
605
+ "begin": "\"",
606
+ "captures": {
607
+ "0": {
608
+ "name": "punctuation.definition.string.lilypond"
609
+ }
610
+ },
611
+ "end": "\"",
612
+ "name": "string.quoted.double.lilypond",
613
+ "patterns": [
614
+ {
615
+ "match": "\\\\.",
616
+ "name": "constant.character.escape.lilypond"
617
+ }
618
+ ]
619
+ }
620
+ },
621
+ "scopeName": "source.lilypond",
622
+ "uuid": "F25B30BE-0526-4D92-806C-F0D678DDF669"
623
+ }