github-linguist-grammars 4.6.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/grammars/file.lasso.json +713 -0
- data/grammars/module.ceylon.json +54 -0
- data/grammars/objdump.x86asm.json +73 -0
- data/grammars/source.Inform7.json +45 -0
- data/grammars/source.Kotlin.json +774 -0
- data/grammars/source.LS.json +104 -0
- data/grammars/source.MCPOST.json +68 -0
- data/grammars/source.MOD.json +70 -0
- data/grammars/source.abap.json +176 -0
- data/grammars/source.abl.json +138 -0
- data/grammars/source.actionscript.3.json +1571 -0
- data/grammars/source.acucobol.json +16 -0
- data/grammars/source.ada.json +140 -0
- data/grammars/source.agda.json +254 -0
- data/grammars/source.ahk.json +171 -0
- data/grammars/source.alloy.json +44 -0
- data/grammars/source.ampl.json +157 -0
- data/grammars/source.antlr.json +300 -0
- data/grammars/source.apache-config.json +352 -0
- data/grammars/source.apache-config.mod_perl.json +70 -0
- data/grammars/source.apl.json +442 -0
- data/grammars/source.applescript.json +1385 -0
- data/grammars/source.apt.json +25 -0
- data/grammars/source.asm.x86.json +182 -0
- data/grammars/source.asp.json +157 -0
- data/grammars/source.aspectj.json +963 -0
- data/grammars/source.ats.json +170 -0
- data/grammars/source.autoit.3.json +132 -0
- data/grammars/source.awk.json +388 -0
- data/grammars/source.befunge.json +38 -0
- data/grammars/source.bf.json +36 -0
- data/grammars/source.bison.json +59 -0
- data/grammars/source.blitzmax.json +912 -0
- data/grammars/source.boo.json +452 -0
- data/grammars/source.brightauthorproject.json +29 -0
- data/grammars/source.brightscript.json +158 -0
- data/grammars/source.bro.json +409 -0
- data/grammars/source.bsv.json +283 -0
- data/grammars/source.c++.json +364 -0
- data/grammars/source.c++.qt.json +37 -0
- data/grammars/source.c.ec.json +39 -0
- data/grammars/source.c.json +727 -0
- data/grammars/source.c.platform.json +154 -0
- data/grammars/source.cache.cmake.json +75 -0
- data/grammars/source.cake.json +16 -0
- data/grammars/source.camlp4.ocaml.json +63 -0
- data/grammars/source.capnp.json +93 -0
- data/grammars/source.ceylon.json +77 -0
- data/grammars/source.cfscript.cfc.json +170 -0
- data/grammars/source.cfscript.json +744 -0
- data/grammars/source.chapel.json +240 -0
- data/grammars/source.cirru.json +66 -0
- data/grammars/source.clarion.json +159 -0
- data/grammars/source.clips.json +80 -0
- data/grammars/source.clojure.json +397 -0
- data/grammars/source.cm.json +54 -0
- data/grammars/source.cmake.json +181 -0
- data/grammars/source.cobol.json +528 -0
- data/grammars/source.coffee.json +678 -0
- data/grammars/source.compiled-papyrus.json +11 -0
- data/grammars/source.cool.json +103 -0
- data/grammars/source.coq.json +62 -0
- data/grammars/source.crystal.json +2760 -0
- data/grammars/source.cs.json +556 -0
- data/grammars/source.css.json +630 -0
- data/grammars/source.css.less.json +276 -0
- data/grammars/source.css.mss.json +256 -0
- data/grammars/source.csx.json +16 -0
- data/grammars/source.cuda-c++.json +137 -0
- data/grammars/source.cython.json +2108 -0
- data/grammars/source.d.json +722 -0
- data/grammars/source.dart.json +763 -0
- data/grammars/source.desktop.json +90 -0
- data/grammars/source.diff.json +162 -0
- data/grammars/source.dockerfile.json +89 -0
- data/grammars/source.dosbatch.json +70 -0
- data/grammars/source.dot.json +126 -0
- data/grammars/source.dylan.json +217 -0
- data/grammars/source.eiffel.json +138 -0
- data/grammars/source.elixir.json +737 -0
- data/grammars/source.elm.json +355 -0
- data/grammars/source.erazor.json +126 -0
- data/grammars/source.erlang.json +1674 -0
- data/grammars/source.essl.json +50 -0
- data/grammars/source.factor.json +260 -0
- data/grammars/source.fan.json +188 -0
- data/grammars/source.fancy.json +270 -0
- data/grammars/source.fish.json +214 -0
- data/grammars/source.forth.json +101 -0
- data/grammars/source.fortran.json +499 -0
- data/grammars/source.fortran.modern.json +226 -0
- data/grammars/source.fsharp.json +403 -0
- data/grammars/source.gap.json +167 -0
- data/grammars/source.gcode.json +25 -0
- data/grammars/source.gdscript.json +154 -0
- data/grammars/source.gfm.json +1270 -0
- data/grammars/source.glsl.json +71 -0
- data/grammars/source.gnuplot.json +276 -0
- data/grammars/source.go.json +552 -0
- data/grammars/source.golo.json +182 -0
- data/grammars/source.gosu.2.json +163 -0
- data/grammars/source.grace.json +679 -0
- data/grammars/source.groovy.gradle.json +73 -0
- data/grammars/source.groovy.json +1385 -0
- data/grammars/source.harbour.json +450 -0
- data/grammars/source.haskell.json +449 -0
- data/grammars/source.haxe.2.json +1243 -0
- data/grammars/source.hss.1.json +464 -0
- data/grammars/source.httpspec.json +287 -0
- data/grammars/source.hxml.json +26 -0
- data/grammars/source.hy.json +270 -0
- data/grammars/source.idl-dlm.json +112 -0
- data/grammars/source.idl.json +267 -0
- data/grammars/source.idris.json +537 -0
- data/grammars/source.ini.json +113 -0
- data/grammars/source.inno.json +65 -0
- data/grammars/source.io.json +164 -0
- data/grammars/source.ioke.json +272 -0
- data/grammars/source.isabelle.root.json +68 -0
- data/grammars/source.isabelle.theory.json +106 -0
- data/grammars/source.j.json +49 -0
- data/grammars/source.jade.json +1009 -0
- data/grammars/source.jasmin.json +299 -0
- data/grammars/source.java-properties.json +97 -0
- data/grammars/source.java.json +1026 -0
- data/grammars/source.jcl.json +49 -0
- data/grammars/source.jflex.json +490 -0
- data/grammars/source.jq.json +218 -0
- data/grammars/source.js.json +948 -0
- data/grammars/source.js.jsx.json +2937 -0
- data/grammars/source.js.objj.json +424 -0
- data/grammars/source.js.regexp.json +150 -0
- data/grammars/source.js.regexp.replacement.json +30 -0
- data/grammars/source.json.json +149 -0
- data/grammars/source.julia.json +407 -0
- data/grammars/source.lean.json +145 -0
- data/grammars/source.lid.json +23 -0
- data/grammars/source.lilypond.json +623 -0
- data/grammars/source.lisp.json +111 -0
- data/grammars/source.litcoffee.json +669 -0
- data/grammars/source.livescript.json +616 -0
- data/grammars/source.llvm.json +71 -0
- data/grammars/source.logos.json +31 -0
- data/grammars/source.logtalk.json +315 -0
- data/grammars/source.loomscript.json +214 -0
- data/grammars/source.lsl.json +216 -0
- data/grammars/source.lua.json +191 -0
- data/grammars/source.makefile.json +474 -0
- data/grammars/source.makegen.json +13 -0
- data/grammars/source.man.json +53 -0
- data/grammars/source.mask.json +701 -0
- data/grammars/source.mata.json +133 -0
- data/grammars/source.mathematica.json +429 -0
- data/grammars/source.matlab.json +776 -0
- data/grammars/source.mercury.json +251 -0
- data/grammars/source.ml.json +291 -0
- data/grammars/source.modelica.json +142 -0
- data/grammars/source.modula2.json +103 -0
- data/grammars/source.monkey.json +701 -0
- data/grammars/source.moonscript.json +149 -0
- data/grammars/source.mupad.json +149 -0
- data/grammars/source.nant-build.json +86 -0
- data/grammars/source.ncl.json +66 -0
- data/grammars/source.nemerle.json +137 -0
- data/grammars/source.nesc.json +27 -0
- data/grammars/source.netlinx.erb.json +47 -0
- data/grammars/source.netlinx.json +768 -0
- data/grammars/source.nginx.json +797 -0
- data/grammars/source.nim.json +1150 -0
- data/grammars/source.nim_filter.json +133 -0
- data/grammars/source.nimcfg.json +116 -0
- data/grammars/source.ninja.json +66 -0
- data/grammars/source.nit.json +238 -0
- data/grammars/source.nix.json +1200 -0
- data/grammars/source.nmml.json +87 -0
- data/grammars/source.nsis.json +150 -0
- data/grammars/source.objc++.json +19 -0
- data/grammars/source.objc.json +918 -0
- data/grammars/source.objc.platform.json +277 -0
- data/grammars/source.ocaml.json +1426 -0
- data/grammars/source.ocamllex.json +305 -0
- data/grammars/source.ocamlyacc.json +346 -0
- data/grammars/source.octave.json +451 -0
- data/grammars/source.ooc.json +692 -0
- data/grammars/source.opa.json +206 -0
- data/grammars/source.opal.json +415 -0
- data/grammars/source.opalsysdefs.json +70 -0
- data/grammars/source.opencobol.json +65 -0
- data/grammars/source.ox.json +97 -0
- data/grammars/source.oz.json +84 -0
- data/grammars/source.papyrus-assembly.json +266 -0
- data/grammars/source.papyrus.json +231 -0
- data/grammars/source.parrot.pir.json +117 -0
- data/grammars/source.pascal.json +150 -0
- data/grammars/source.perl.6.json +310 -0
- data/grammars/source.perl.json +2413 -0
- data/grammars/source.php.zephir.json +362 -0
- data/grammars/source.pig_latin.json +172 -0
- data/grammars/source.pike.json +62 -0
- data/grammars/source.plsql.oracle.json +642 -0
- data/grammars/source.po.json +232 -0
- data/grammars/source.pogoscript.json +85 -0
- data/grammars/source.postscript.json +231 -0
- data/grammars/source.powershell.json +755 -0
- data/grammars/source.processing.json +885 -0
- data/grammars/source.prolog.eclipse.json +206 -0
- data/grammars/source.prolog.json +292 -0
- data/grammars/source.protobuf.json +395 -0
- data/grammars/source.pubspec.json +13 -0
- data/grammars/source.puppet.json +494 -0
- data/grammars/source.purescript.json +818 -0
- data/grammars/source.pyjade.json +1010 -0
- data/grammars/source.python.django.json +34 -0
- data/grammars/source.python.json +1960 -0
- data/grammars/source.python.salt.json +13 -0
- data/grammars/source.qmake.json +217 -0
- data/grammars/source.qml.json +195 -0
- data/grammars/source.r.json +203 -0
- data/grammars/source.racket.json +119 -0
- data/grammars/source.rebol.json +647 -0
- data/grammars/source.red.json +652 -0
- data/grammars/source.regexp.babel.json +190 -0
- data/grammars/source.regexp.python.json +187 -0
- data/grammars/source.regexp.spin.json +188 -0
- data/grammars/source.ruby.json +1956 -0
- data/grammars/source.ruby.rspec.cucumber.steps.json +274 -0
- data/grammars/source.rust.json +269 -0
- data/grammars/source.sas.json +322 -0
- data/grammars/source.sas_log.json +26 -0
- data/grammars/source.sass.json +248 -0
- data/grammars/source.sbt.json +36 -0
- data/grammars/source.scad.json +152 -0
- data/grammars/source.scala.json +739 -0
- data/grammars/source.scaml.json +466 -0
- data/grammars/source.scheme.json +370 -0
- data/grammars/source.scilab.json +103 -0
- data/grammars/source.scss.json +1321 -0
- data/grammars/source.shell.json +1212 -0
- data/grammars/source.smali.json +1668 -0
- data/grammars/source.smalltalk.json +135 -0
- data/grammars/source.smt.json +173 -0
- data/grammars/source.sp.json +118 -0
- data/grammars/source.sparql.json +23 -0
- data/grammars/source.spin.json +936 -0
- data/grammars/source.sqf.json +112 -0
- data/grammars/source.sql.json +473 -0
- data/grammars/source.stata.json +208 -0
- data/grammars/source.strings.json +53 -0
- data/grammars/source.stylus.json +1021 -0
- data/grammars/source.swift.json +965 -0
- data/grammars/source.systemverilog.json +1050 -0
- data/grammars/source.tcl.json +277 -0
- data/grammars/source.tea.json +180 -0
- data/grammars/source.thrift.json +704 -0
- data/grammars/source.toml.json +327 -0
- data/grammars/source.ts.json +1094 -0
- data/grammars/source.tsx.json +1324 -0
- data/grammars/source.turtle.json +505 -0
- data/grammars/source.txl.json +62 -0
- data/grammars/source.ucfconstraints.json +72 -0
- data/grammars/source.vala.json +814 -0
- data/grammars/source.varnish.vcl.json +343 -0
- data/grammars/source.vbnet.json +338 -0
- data/grammars/source.verilog.json +302 -0
- data/grammars/source.vhdl.json +1349 -0
- data/grammars/source.viml.json +224 -0
- data/grammars/source.webidl.json +814 -0
- data/grammars/source.x10.json +68 -0
- data/grammars/source.x86asm.json +47 -0
- data/grammars/source.xc.json +379 -0
- data/grammars/source.xq.json +241 -0
- data/grammars/source.xquery.json +193 -0
- data/grammars/source.xtend.json +733 -0
- data/grammars/source.yaml.json +334 -0
- data/grammars/source.yaml.salt.json +348 -0
- data/grammars/text.bibtex.json +251 -0
- data/grammars/text.cfml.basic.json +736 -0
- data/grammars/text.dart-analysis-output.json +162 -0
- data/grammars/text.dart-doccomments.json +19 -0
- data/grammars/text.elixir.json +45 -0
- data/grammars/text.gherkin.feature.json +135 -0
- data/grammars/text.groff.json +113 -0
- data/grammars/text.haml.json +299 -0
- data/grammars/text.html.abl.json +24 -0
- data/grammars/text.html.asciidoc.json +492 -0
- data/grammars/text.html.asdoc.json +541 -0
- data/grammars/text.html.asp.json +58 -0
- data/grammars/text.html.basic.json +552 -0
- data/grammars/text.html.cfm.json +811 -0
- data/grammars/text.html.creole.json +329 -0
- data/grammars/text.html.django.json +69 -0
- data/grammars/text.html.elixir.json +18 -0
- data/grammars/text.html.erb.json +157 -0
- data/grammars/text.html.erlang.yaws.json +72 -0
- data/grammars/text.html.factor.json +27 -0
- data/grammars/text.html.handlebars.json +783 -0
- data/grammars/text.html.jsp.json +1203 -0
- data/grammars/text.html.liquid.json +35 -0
- data/grammars/text.html.mako.json +729 -0
- data/grammars/text.html.markdown.source.gfm.apib.json +1297 -0
- data/grammars/text.html.markdown.source.gfm.mson.json +1165 -0
- data/grammars/text.html.mediawiki.json +972 -0
- data/grammars/text.html.php.json +2607 -0
- data/grammars/text.html.slash.json +313 -0
- data/grammars/text.html.smarty.json +216 -0
- data/grammars/text.html.ssp.json +49 -0
- data/grammars/text.html.tcl.json +44 -0
- data/grammars/text.html.twig.json +1353 -0
- data/grammars/text.html.vue.json +642 -0
- data/grammars/text.idl-idldoc.json +14 -0
- data/grammars/text.junit-test-report.json +92 -0
- data/grammars/text.log.latex.json +86 -0
- data/grammars/text.python.console.json +25 -0
- data/grammars/text.python.traceback.json +46 -0
- data/grammars/text.rdoc.json +48 -0
- data/grammars/text.restructuredtext.json +561 -0
- data/grammars/text.robot.json +73 -0
- data/grammars/text.shell-session.json +48 -0
- data/grammars/text.slim.json +527 -0
- data/grammars/text.tex.json +271 -0
- data/grammars/text.tex.latex.beamer.json +63 -0
- data/grammars/text.tex.latex.haskell.json +56 -0
- data/grammars/text.tex.latex.json +1013 -0
- data/grammars/text.tex.latex.memoir.json +99 -0
- data/grammars/text.tex.latex.rd.json +117 -0
- data/grammars/text.xml.ant.json +202 -0
- data/grammars/text.xml.flex-config.json +2634 -0
- data/grammars/text.xml.genshi.json +34 -0
- data/grammars/text.xml.json +364 -0
- data/grammars/text.xml.pom.json +774 -0
- data/grammars/text.xml.xsl.json +94 -0
- data/grammars/text.zone_file.json +72 -0
- data/lib/linguist/grammars.rb +13 -0
- 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
|
+
}
|