msdax.js 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405
  1. "use strict";
  2. /*!-----------------------------------------------------------------------------
  3. * Copyright (c) Microsoft Corporation. All rights reserved.
  4. * Version: 0.38.0(0e330ae453813de4e6cf272460fb79c7117073d0)
  5. * Released under the MIT license
  6. * https://github.com/microsoft/monaco-editor/blob/main/LICENSE.txt
  7. *-----------------------------------------------------------------------------*/
  8. define("vs/basic-languages/msdax/msdax", ["require"],(require)=>{
  9. var moduleExports = (() => {
  10. var __defProp = Object.defineProperty;
  11. var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
  12. var __getOwnPropNames = Object.getOwnPropertyNames;
  13. var __hasOwnProp = Object.prototype.hasOwnProperty;
  14. var __export = (target, all) => {
  15. for (var name in all)
  16. __defProp(target, name, { get: all[name], enumerable: true });
  17. };
  18. var __copyProps = (to, from, except, desc) => {
  19. if (from && typeof from === "object" || typeof from === "function") {
  20. for (let key of __getOwnPropNames(from))
  21. if (!__hasOwnProp.call(to, key) && key !== except)
  22. __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
  23. }
  24. return to;
  25. };
  26. var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
  27. // src/basic-languages/msdax/msdax.ts
  28. var msdax_exports = {};
  29. __export(msdax_exports, {
  30. conf: () => conf,
  31. language: () => language
  32. });
  33. var conf = {
  34. comments: {
  35. lineComment: "//",
  36. blockComment: ["/*", "*/"]
  37. },
  38. brackets: [
  39. ["[", "]"],
  40. ["(", ")"],
  41. ["{", "}"]
  42. ],
  43. autoClosingPairs: [
  44. { open: '"', close: '"', notIn: ["string", "comment"] },
  45. { open: "'", close: "'", notIn: ["string", "comment"] },
  46. { open: "[", close: "]", notIn: ["string", "comment"] },
  47. { open: "(", close: ")", notIn: ["string", "comment"] },
  48. { open: "{", close: "}", notIn: ["string", "comment"] }
  49. ]
  50. };
  51. var language = {
  52. defaultToken: "",
  53. tokenPostfix: ".msdax",
  54. ignoreCase: true,
  55. brackets: [
  56. { open: "[", close: "]", token: "delimiter.square" },
  57. { open: "{", close: "}", token: "delimiter.brackets" },
  58. { open: "(", close: ")", token: "delimiter.parenthesis" }
  59. ],
  60. keywords: [
  61. "VAR",
  62. "RETURN",
  63. "NOT",
  64. "EVALUATE",
  65. "DATATABLE",
  66. "ORDER",
  67. "BY",
  68. "START",
  69. "AT",
  70. "DEFINE",
  71. "MEASURE",
  72. "ASC",
  73. "DESC",
  74. "IN",
  75. "BOOLEAN",
  76. "DOUBLE",
  77. "INTEGER",
  78. "DATETIME",
  79. "CURRENCY",
  80. "STRING"
  81. ],
  82. functions: [
  83. "CLOSINGBALANCEMONTH",
  84. "CLOSINGBALANCEQUARTER",
  85. "CLOSINGBALANCEYEAR",
  86. "DATEADD",
  87. "DATESBETWEEN",
  88. "DATESINPERIOD",
  89. "DATESMTD",
  90. "DATESQTD",
  91. "DATESYTD",
  92. "ENDOFMONTH",
  93. "ENDOFQUARTER",
  94. "ENDOFYEAR",
  95. "FIRSTDATE",
  96. "FIRSTNONBLANK",
  97. "LASTDATE",
  98. "LASTNONBLANK",
  99. "NEXTDAY",
  100. "NEXTMONTH",
  101. "NEXTQUARTER",
  102. "NEXTYEAR",
  103. "OPENINGBALANCEMONTH",
  104. "OPENINGBALANCEQUARTER",
  105. "OPENINGBALANCEYEAR",
  106. "PARALLELPERIOD",
  107. "PREVIOUSDAY",
  108. "PREVIOUSMONTH",
  109. "PREVIOUSQUARTER",
  110. "PREVIOUSYEAR",
  111. "SAMEPERIODLASTYEAR",
  112. "STARTOFMONTH",
  113. "STARTOFQUARTER",
  114. "STARTOFYEAR",
  115. "TOTALMTD",
  116. "TOTALQTD",
  117. "TOTALYTD",
  118. "ADDCOLUMNS",
  119. "ADDMISSINGITEMS",
  120. "ALL",
  121. "ALLEXCEPT",
  122. "ALLNOBLANKROW",
  123. "ALLSELECTED",
  124. "CALCULATE",
  125. "CALCULATETABLE",
  126. "CALENDAR",
  127. "CALENDARAUTO",
  128. "CROSSFILTER",
  129. "CROSSJOIN",
  130. "CURRENTGROUP",
  131. "DATATABLE",
  132. "DETAILROWS",
  133. "DISTINCT",
  134. "EARLIER",
  135. "EARLIEST",
  136. "EXCEPT",
  137. "FILTER",
  138. "FILTERS",
  139. "GENERATE",
  140. "GENERATEALL",
  141. "GROUPBY",
  142. "IGNORE",
  143. "INTERSECT",
  144. "ISONORAFTER",
  145. "KEEPFILTERS",
  146. "LOOKUPVALUE",
  147. "NATURALINNERJOIN",
  148. "NATURALLEFTOUTERJOIN",
  149. "RELATED",
  150. "RELATEDTABLE",
  151. "ROLLUP",
  152. "ROLLUPADDISSUBTOTAL",
  153. "ROLLUPGROUP",
  154. "ROLLUPISSUBTOTAL",
  155. "ROW",
  156. "SAMPLE",
  157. "SELECTCOLUMNS",
  158. "SUBSTITUTEWITHINDEX",
  159. "SUMMARIZE",
  160. "SUMMARIZECOLUMNS",
  161. "TOPN",
  162. "TREATAS",
  163. "UNION",
  164. "USERELATIONSHIP",
  165. "VALUES",
  166. "SUM",
  167. "SUMX",
  168. "PATH",
  169. "PATHCONTAINS",
  170. "PATHITEM",
  171. "PATHITEMREVERSE",
  172. "PATHLENGTH",
  173. "AVERAGE",
  174. "AVERAGEA",
  175. "AVERAGEX",
  176. "COUNT",
  177. "COUNTA",
  178. "COUNTAX",
  179. "COUNTBLANK",
  180. "COUNTROWS",
  181. "COUNTX",
  182. "DISTINCTCOUNT",
  183. "DIVIDE",
  184. "GEOMEAN",
  185. "GEOMEANX",
  186. "MAX",
  187. "MAXA",
  188. "MAXX",
  189. "MEDIAN",
  190. "MEDIANX",
  191. "MIN",
  192. "MINA",
  193. "MINX",
  194. "PERCENTILE.EXC",
  195. "PERCENTILE.INC",
  196. "PERCENTILEX.EXC",
  197. "PERCENTILEX.INC",
  198. "PRODUCT",
  199. "PRODUCTX",
  200. "RANK.EQ",
  201. "RANKX",
  202. "STDEV.P",
  203. "STDEV.S",
  204. "STDEVX.P",
  205. "STDEVX.S",
  206. "VAR.P",
  207. "VAR.S",
  208. "VARX.P",
  209. "VARX.S",
  210. "XIRR",
  211. "XNPV",
  212. "DATE",
  213. "DATEDIFF",
  214. "DATEVALUE",
  215. "DAY",
  216. "EDATE",
  217. "EOMONTH",
  218. "HOUR",
  219. "MINUTE",
  220. "MONTH",
  221. "NOW",
  222. "SECOND",
  223. "TIME",
  224. "TIMEVALUE",
  225. "TODAY",
  226. "WEEKDAY",
  227. "WEEKNUM",
  228. "YEAR",
  229. "YEARFRAC",
  230. "CONTAINS",
  231. "CONTAINSROW",
  232. "CUSTOMDATA",
  233. "ERROR",
  234. "HASONEFILTER",
  235. "HASONEVALUE",
  236. "ISBLANK",
  237. "ISCROSSFILTERED",
  238. "ISEMPTY",
  239. "ISERROR",
  240. "ISEVEN",
  241. "ISFILTERED",
  242. "ISLOGICAL",
  243. "ISNONTEXT",
  244. "ISNUMBER",
  245. "ISODD",
  246. "ISSUBTOTAL",
  247. "ISTEXT",
  248. "USERNAME",
  249. "USERPRINCIPALNAME",
  250. "AND",
  251. "FALSE",
  252. "IF",
  253. "IFERROR",
  254. "NOT",
  255. "OR",
  256. "SWITCH",
  257. "TRUE",
  258. "ABS",
  259. "ACOS",
  260. "ACOSH",
  261. "ACOT",
  262. "ACOTH",
  263. "ASIN",
  264. "ASINH",
  265. "ATAN",
  266. "ATANH",
  267. "BETA.DIST",
  268. "BETA.INV",
  269. "CEILING",
  270. "CHISQ.DIST",
  271. "CHISQ.DIST.RT",
  272. "CHISQ.INV",
  273. "CHISQ.INV.RT",
  274. "COMBIN",
  275. "COMBINA",
  276. "CONFIDENCE.NORM",
  277. "CONFIDENCE.T",
  278. "COS",
  279. "COSH",
  280. "COT",
  281. "COTH",
  282. "CURRENCY",
  283. "DEGREES",
  284. "EVEN",
  285. "EXP",
  286. "EXPON.DIST",
  287. "FACT",
  288. "FLOOR",
  289. "GCD",
  290. "INT",
  291. "ISO.CEILING",
  292. "LCM",
  293. "LN",
  294. "LOG",
  295. "LOG10",
  296. "MOD",
  297. "MROUND",
  298. "ODD",
  299. "PERMUT",
  300. "PI",
  301. "POISSON.DIST",
  302. "POWER",
  303. "QUOTIENT",
  304. "RADIANS",
  305. "RAND",
  306. "RANDBETWEEN",
  307. "ROUND",
  308. "ROUNDDOWN",
  309. "ROUNDUP",
  310. "SIGN",
  311. "SIN",
  312. "SINH",
  313. "SQRT",
  314. "SQRTPI",
  315. "TAN",
  316. "TANH",
  317. "TRUNC",
  318. "BLANK",
  319. "CONCATENATE",
  320. "CONCATENATEX",
  321. "EXACT",
  322. "FIND",
  323. "FIXED",
  324. "FORMAT",
  325. "LEFT",
  326. "LEN",
  327. "LOWER",
  328. "MID",
  329. "REPLACE",
  330. "REPT",
  331. "RIGHT",
  332. "SEARCH",
  333. "SUBSTITUTE",
  334. "TRIM",
  335. "UNICHAR",
  336. "UNICODE",
  337. "UPPER",
  338. "VALUE"
  339. ],
  340. tokenizer: {
  341. root: [
  342. { include: "@comments" },
  343. { include: "@whitespace" },
  344. { include: "@numbers" },
  345. { include: "@strings" },
  346. { include: "@complexIdentifiers" },
  347. [/[;,.]/, "delimiter"],
  348. [/[({})]/, "@brackets"],
  349. [
  350. /[a-z_][a-zA-Z0-9_]*/,
  351. {
  352. cases: {
  353. "@keywords": "keyword",
  354. "@functions": "keyword",
  355. "@default": "identifier"
  356. }
  357. }
  358. ],
  359. [/[<>=!%&+\-*/|~^]/, "operator"]
  360. ],
  361. whitespace: [[/\s+/, "white"]],
  362. comments: [
  363. [/\/\/+.*/, "comment"],
  364. [/\/\*/, { token: "comment.quote", next: "@comment" }]
  365. ],
  366. comment: [
  367. [/[^*/]+/, "comment"],
  368. [/\*\//, { token: "comment.quote", next: "@pop" }],
  369. [/./, "comment"]
  370. ],
  371. numbers: [
  372. [/0[xX][0-9a-fA-F]*/, "number"],
  373. [/[$][+-]*\d*(\.\d*)?/, "number"],
  374. [/((\d+(\.\d*)?)|(\.\d+))([eE][\-+]?\d+)?/, "number"]
  375. ],
  376. strings: [
  377. [/N"/, { token: "string", next: "@string" }],
  378. [/"/, { token: "string", next: "@string" }]
  379. ],
  380. string: [
  381. [/[^"]+/, "string"],
  382. [/""/, "string"],
  383. [/"/, { token: "string", next: "@pop" }]
  384. ],
  385. complexIdentifiers: [
  386. [/\[/, { token: "identifier.quote", next: "@bracketedIdentifier" }],
  387. [/'/, { token: "identifier.quote", next: "@quotedIdentifier" }]
  388. ],
  389. bracketedIdentifier: [
  390. [/[^\]]+/, "identifier"],
  391. [/]]/, "identifier"],
  392. [/]/, { token: "identifier.quote", next: "@pop" }]
  393. ],
  394. quotedIdentifier: [
  395. [/[^']+/, "identifier"],
  396. [/''/, "identifier"],
  397. [/'/, { token: "identifier.quote", next: "@pop" }]
  398. ]
  399. }
  400. };
  401. return __toCommonJS(msdax_exports);
  402. })();
  403. return moduleExports;
  404. });