Source file tm_grammar_dax.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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
let lang_id = "dax"
let json = {json|{
"displayName": "DAX",
"name": "dax",
"patterns": [
{
"include": "#comments"
},
{
"include": "#keywords"
},
{
"include": "#labels"
},
{
"include": "#parameters"
},
{
"include": "#strings"
},
{
"include": "#numbers"
}
],
"repository": {
"comments": {
"patterns": [
{
"begin": "//",
"captures": {
"0": {
"name": "punctuation.definition.comment.dax"
}
},
"end": "\\n",
"name": "comment.line.dax"
},
{
"begin": "--",
"captures": {
"0": {
"name": "punctuation.definition.comment.dax"
}
},
"end": "\\n",
"name": "comment.line.dax"
},
{
"begin": "/\\*",
"captures": {
"0": {
"name": "punctuation.definition.comment.dax"
}
},
"end": "\\*/",
"name": "comment.block.dax"
}
]
},
"keywords": {
"patterns": [
{
"match": "\\b(YIELDMAT|YIELDDISC|YIELD|YEARFRAC|YEAR|XNPV|XIRR|WEEKNUM|WEEKDAY|VDB|VARX.S|VARX.P|VAR.S|VAR.P|VALUES?|UTCTODAY|UTCNOW|USERPRINCIPALNAME|USEROBJECTID|USERNAME|USERELATIONSHIP|USERCULTURE|UPPER|UNION|UNICODE|UNICHAR|TRUNC|TRUE|TRIM|TREATAS|TOTALYTD|TOTALQTD|TOTALMTD|TOPNSKIP|TOPNPERLEVEL|TOPN|TODAY|TIMEVALUE|TIME|TBILLYIELD|TBILLPRICE|TBILLEQ|TANH?|T.INV.2T|T.INV|T.DIST.RT|T.DIST.2T|T.DIST|SYD|SWITCH|SUMX|SUMMARIZECOLUMNS|SUMMARIZE|SUM|SUBSTITUTEWITHINDEX|SUBSTITUTE|STDEVX.S|STDEVX.P|STDEV.S|STDEV.P|STARTOFYEAR|STARTOFQUARTER|STARTOFMONTH|SQRTPI|SQRT|SLN|SINH?|SIGN|SELECTEDVALUE|SELECTEDMEASURENAME|SELECTEDMEASUREFORMATSTRING|SELECTEDMEASURE|SELECTCOLUMNS|SECOND|SEARCH|SAMPLE|SAMEPERIODLASTYEAR|RRI|ROW|ROUNDUP|ROUNDDOWN|ROUND|ROLLUPISSUBTOTAL|ROLLUPGROUP|ROLLUPADDISSUBTOTAL|ROLLUP|RIGHT|REPT|REPLACE|REMOVEFILTERS|RELATEDTABLE|RELATED|RECEIVED|RATE|RANKX|RANK.EQ|RANDBETWEEN|RAND|RADIANS|QUOTIENT|QUARTER|PV|PRODUCTX?|PRICEMAT|PRICEDISC|PRICE|PREVIOUSYEAR|PREVIOUSQUARTER|PREVIOUSMONTH|PREVIOUSDAY|PPMT|POWER|POISSON.DIST|PMT|PI|PERMUT|PERCENTILEX.INC|PERCENTILEX.EXC|PERCENTILE.INC|PERCENTILE.EXC|PDURATION|PATHLENGTH|PATHITEMREVERSE|PATHITEM|PATHCONTAINS|PATH|PARALLELPERIOD|OR|OPENINGBALANCEYEAR|OPENINGBALANCEQUARTER|OPENINGBALANCEMONTH|ODDLYIELD|ODDLPRICE|ODDFYIELD|ODDFPRICE|ODD|NPER|NOW|NOT|NORM.S.INV|NORM.S.DIST|NORM.INV|NORM.DIST|NONVISUAL|NOMINAL|NEXTYEAR|NEXTQUARTER|NEXTMONTH|NEXTDAY|NATURALLEFTOUTERJOIN|NATURALINNERJOIN|MROUND|MONTH|MOD|MINX|MINUTE|MINA?|MID|MEDIANX?|MDURATION|MAXX|MAXA?|LOWER|LOOKUPVALUE|LOG10|LOG|LN|LEN|LEFT|LCM|LASTNONBLANKVALUE|LASTNONBLANK|LASTDATE|KEYWORDMATCH|KEEPFILTERS|ISTEXT|ISSUBTOTAL|ISSELECTEDMEASURE|ISPMT|ISONORAFTER|ISODD|ISO.CEILING|ISNUMBER|ISNONTEXT|ISLOGICAL|ISINSCOPE|ISFILTERED|ISEVEN|ISERROR|ISEMPTY|ISCROSSFILTERED|ISBLANK|ISAFTER|IPMT|INTRATE|INTERSECT|INT|IGNORE|IFERROR|IF.EAGER|IF|HOUR|HASONEVALUE|HASONEFILTER|HASH|GROUPBY|GEOMEANX?|GENERATESERIES|GENERATEALL|GENERATE|GCD|FV|FORMAT|FLOOR|FIXED|FIRSTNONBLANKVALUE|FIRSTNONBLANK|FIRSTDATE|FIND|FILTERS?|FALSE|FACT|EXPON.DIST|EXP|EXCEPT|EXACT|EVEN|ERROR|EOMONTH|ENDOFYEAR|ENDOFQUARTER|ENDOFMONTH|EFFECT|EDATE|EARLIEST|EARLIER|DURATION|DOLLARFR|DOLLARDE|DIVIDE|DISTINCTCOUNTNOBLANK|DISTINCTCOUNT|DISTINCT|DISC|DETAILROWS|DEGREES|DDB|DB|DAY|DATEVALUE|DATESYTD|DATESQTD|DATESMTD|DATESINPERIOD|DATESBETWEEN|DATEDIFF|DATEADD|DATE|DATATABLE|CUSTOMDATA|CURRENTGROUP|CURRENCY|CUMPRINC|CUMIPMT|CROSSJOIN|CROSSFILTER|COUPPCD|COUPNUM|COUPNCD|COUPDAYSNC|COUPDAYS|COUPDAYBS|COUNTX|COUNTROWS|COUNTBLANK|COUNTAX?|COUNT|COTH?|COSH?|CONVERT|CONTAINSSTRINGEXACT|CONTAINSSTRING|CONTAINSROW|CONTAINS|CONFIDENCE.T|CONFIDENCE.NORM|CONCATENATEX?|COMBINEVALUES|COMBINA?|COLUMNSTATISTICS|COALESCE|CLOSINGBALANCEYEAR|CLOSINGBALANCEQUARTER|CLOSINGBALANCEMONTH|CHISQ.INV.RT|CHISQ.INV|CHISQ.DIST.RT|CHISQ.DIST|CEILING|CALENDARAUTO|CALENDAR|CALCULATETABLE|CALCULATE|BLANK|BETA.INV|BETA.DIST|AVERAGEX|AVERAGEA?|ATANH?|ASINH?|APPROXIMATEDISTINCTCOUNT|AND|AMORLINC|AMORDEGRC|ALLSELECTED|ALLNOBLANKROW|ALLEXCEPT|ALLCROSSFILTERED|ALL|ADDMISSINGITEMS|ADDCOLUMNS|ACOTH?|ACOSH?|ACCRINTM?|ABS)\\b",
"name": "variable.language.dax"
},
{
"match": "\\b(DEFINE|EVALUATE|ORDER BY|RETURN|VAR)\\b",
"name": "keyword.control.dax"
},
{
"match": "[{}]",
"name": "keyword.array.constructor.dax"
},
{
"match": "[<>]|>=|<=|=(?!==)",
"name": "keyword.operator.comparison.dax"
},
{
"match": "&&|IN|NOT|\\|\\|",
"name": "keyword.operator.logical.dax"
},
{
"match": "[-*+/]",
"name": "keyword.arithmetic.operator.dax"
},
{
"begin": "\\[",
"end": "]",
"name": "support.function.dax"
},
{
"begin": "\"",
"end": "\"",
"name": "string.quoted.double.dax"
},
{
"begin": "'",
"end": "'",
"name": "support.class.dax"
}
]
},
"labels": {
"patterns": [
{
"captures": {
"1": {
"name": "punctuation.separator.label.dax"
},
"2": {
"name": "entity.name.label.dax"
}
},
"match": "^((.*?)\\s*([!:]=))"
}
]
},
"metas": {
"patterns": [
{
"begin": "\\(",
"beginCaptures": {
"0": {
"name": "meta.brace.round.dax"
}
},
"end": "\\)",
"endCaptures": {
"0": {
"name": "meta.brace.round.dax"
}
}
}
]
},
"numbers": {
"match": "-?(?:0|[1-9]\\d*)(?:(?:\\.\\d+)?(?:[Ee][-+]?\\d+)?)?",
"name": "constant.numeric.dax"
},
"parameters": {
"patterns": [
{
"begin": "\\b(?<!\\.)(VAR)\\b(?<!\\.)\\b",
"beginCaptures": {
"1": {
"name": "keyword.control.dax"
},
"2": {
"name": "variable.other.readwrite.dax"
}
},
"end": "=",
"endCaptures": {
"0": {
"name": "keyword.operator.assignment.dax"
}
},
"name": "meta.function.definition.parameters.dax",
"patterns": [
{
"match": "=",
"name": "keyword.control.dax"
}
]
},
{
"match": "[$_[:alpha:]][$_[:alnum:]]*",
"name": "variable.other.constant.dax"
}
]
},
"strings": {
"begin": "\"",
"end": "\"",
"name": "string.quoted.double.dax",
"patterns": [
{
"match": "\\\\.",
"name": "constant.character.escape.dax"
}
]
}
},
"scopeName": "source.dax"
}|json}