Source file tm_grammar_dotenv.ml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
let lang_id = "dotenv"
let json = {json|{
"displayName": "dotEnv",
"name": "dotenv",
"patterns": [
{
"captures": {
"1": {
"patterns": [
{
"include": "#line-comment"
}
]
}
},
"match": "^\\s?(#.*)$\\n"
},
{
"captures": {
"1": {
"patterns": [
{
"include": "#key"
}
]
},
"2": {
"name": "keyword.operator.assignment.dotenv"
},
"3": {
"name": "property.value.dotenv",
"patterns": [
{
"include": "#line-comment"
},
{
"include": "#double-quoted-string"
},
{
"include": "#single-quoted-string"
},
{
"include": "#interpolation"
}
]
}
},
"match": "^\\s?(.*?)\\s?(=)(.*)$"
}
],
"repository": {
"double-quoted-string": {
"captures": {
"1": {
"patterns": [
{
"include": "#interpolation"
},
{
"include": "#escape-characters"
}
]
}
},
"match": "\"(.*)\"",
"name": "string.quoted.double.dotenv"
},
"escape-characters": {
"match": "\\\\(?:[\"'\\\\bfnrt]|u[0-9A-F]{4})",
"name": "constant.character.escape.dotenv"
},
"interpolation": {
"captures": {
"1": {
"name": "keyword.interpolation.begin.dotenv"
},
"2": {
"name": "variable.interpolation.dotenv"
},
"3": {
"name": "keyword.interpolation.end.dotenv"
}
},
"match": "(\\$\\{)(.*)(})"
},
"key": {
"captures": {
"1": {
"name": "keyword.key.export.dotenv"
},
"2": {
"name": "variable.key.dotenv",
"patterns": [
{
"include": "#variable"
}
]
}
},
"match": "(export\\s)?(.*)"
},
"line-comment": {
"match": "#.*$",
"name": "comment.line.dotenv"
},
"single-quoted-string": {
"match": "'(.*)'",
"name": "string.quoted.single.dotenv"
},
"variable": {
"match": "[A-Z_a-z]+[0-9A-Z_a-z]*"
}
},
"scopeName": "source.dotenv"
}|json}