@platforma-sdk/tengo-builder 2.4.13 → 2.4.15

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (123) hide show
  1. package/README.md +4 -4
  2. package/bin/run.js +5 -5
  3. package/dist/commands/build.cjs +36 -36
  4. package/dist/commands/build.cjs.map +1 -1
  5. package/dist/commands/build.d.ts +5 -5
  6. package/dist/commands/build.js +36 -36
  7. package/dist/commands/build.js.map +1 -1
  8. package/dist/commands/check.cjs +5 -5
  9. package/dist/commands/check.cjs.map +1 -1
  10. package/dist/commands/check.d.ts +2 -2
  11. package/dist/commands/check.d.ts.map +1 -1
  12. package/dist/commands/check.js +5 -5
  13. package/dist/commands/check.js.map +1 -1
  14. package/dist/commands/dump/artifacts.cjs +4 -6
  15. package/dist/commands/dump/artifacts.cjs.map +1 -1
  16. package/dist/commands/dump/artifacts.d.ts +2 -2
  17. package/dist/commands/dump/artifacts.d.ts.map +1 -1
  18. package/dist/commands/dump/artifacts.js +4 -6
  19. package/dist/commands/dump/artifacts.js.map +1 -1
  20. package/dist/commands/dump/software.cjs +3 -5
  21. package/dist/commands/dump/software.cjs.map +1 -1
  22. package/dist/commands/dump/software.d.ts +2 -2
  23. package/dist/commands/dump/software.d.ts.map +1 -1
  24. package/dist/commands/dump/software.js +3 -5
  25. package/dist/commands/dump/software.js.map +1 -1
  26. package/dist/commands/test.cjs +5 -5
  27. package/dist/commands/test.cjs.map +1 -1
  28. package/dist/commands/test.d.ts +2 -2
  29. package/dist/commands/test.d.ts.map +1 -1
  30. package/dist/commands/test.js +5 -5
  31. package/dist/commands/test.js.map +1 -1
  32. package/dist/compiler/artifactset.cjs +2 -2
  33. package/dist/compiler/artifactset.cjs.map +1 -1
  34. package/dist/compiler/artifactset.d.ts +1 -1
  35. package/dist/compiler/artifactset.d.ts.map +1 -1
  36. package/dist/compiler/artifactset.js +2 -2
  37. package/dist/compiler/artifactset.js.map +1 -1
  38. package/dist/compiler/compiler.cjs +37 -34
  39. package/dist/compiler/compiler.cjs.map +1 -1
  40. package/dist/compiler/compiler.d.ts +3 -3
  41. package/dist/compiler/compiler.d.ts.map +1 -1
  42. package/dist/compiler/compiler.js +37 -34
  43. package/dist/compiler/compiler.js.map +1 -1
  44. package/dist/compiler/compileroptions.cjs +12 -12
  45. package/dist/compiler/compileroptions.cjs.map +1 -1
  46. package/dist/compiler/compileroptions.d.ts +2 -2
  47. package/dist/compiler/compileroptions.js +12 -12
  48. package/dist/compiler/compileroptions.js.map +1 -1
  49. package/dist/compiler/main.cjs +58 -58
  50. package/dist/compiler/main.cjs.map +1 -1
  51. package/dist/compiler/main.d.ts +6 -6
  52. package/dist/compiler/main.d.ts.map +1 -1
  53. package/dist/compiler/main.js +58 -58
  54. package/dist/compiler/main.js.map +1 -1
  55. package/dist/compiler/package.cjs +5 -2
  56. package/dist/compiler/package.cjs.map +1 -1
  57. package/dist/compiler/package.d.ts +6 -6
  58. package/dist/compiler/package.d.ts.map +1 -1
  59. package/dist/compiler/package.js +5 -2
  60. package/dist/compiler/package.js.map +1 -1
  61. package/dist/compiler/source.cjs +50 -52
  62. package/dist/compiler/source.cjs.map +1 -1
  63. package/dist/compiler/source.d.ts +2 -2
  64. package/dist/compiler/source.d.ts.map +1 -1
  65. package/dist/compiler/source.js +50 -52
  66. package/dist/compiler/source.js.map +1 -1
  67. package/dist/compiler/template.cjs +7 -7
  68. package/dist/compiler/template.cjs.map +1 -1
  69. package/dist/compiler/template.d.ts +2 -2
  70. package/dist/compiler/template.d.ts.map +1 -1
  71. package/dist/compiler/template.js +7 -7
  72. package/dist/compiler/template.js.map +1 -1
  73. package/dist/compiler/test.artifacts.d.ts +1 -1
  74. package/dist/compiler/test.artifacts.d.ts.map +1 -1
  75. package/dist/compiler/util.cjs +12 -12
  76. package/dist/compiler/util.cjs.map +1 -1
  77. package/dist/compiler/util.d.ts +2 -2
  78. package/dist/compiler/util.js +12 -12
  79. package/dist/compiler/util.js.map +1 -1
  80. package/dist/index.cjs +5 -5
  81. package/dist/index.cjs.map +1 -1
  82. package/dist/index.d.ts +7 -7
  83. package/dist/index.js +5 -5
  84. package/dist/index.js.map +1 -1
  85. package/dist/shared/basecmd.cjs +15 -15
  86. package/dist/shared/basecmd.cjs.map +1 -1
  87. package/dist/shared/basecmd.d.ts +4 -4
  88. package/dist/shared/basecmd.js +15 -15
  89. package/dist/shared/basecmd.js.map +1 -1
  90. package/dist/shared/dump.cjs +28 -28
  91. package/dist/shared/dump.cjs.map +1 -1
  92. package/dist/shared/dump.d.ts +2 -2
  93. package/dist/shared/dump.d.ts.map +1 -1
  94. package/dist/shared/dump.js +28 -28
  95. package/dist/shared/dump.js.map +1 -1
  96. package/dist/shared/proc.cjs +5 -5
  97. package/dist/shared/proc.cjs.map +1 -1
  98. package/dist/shared/proc.d.ts +2 -2
  99. package/dist/shared/proc.js +5 -5
  100. package/dist/shared/proc.js.map +1 -1
  101. package/package.json +21 -19
  102. package/src/commands/build.ts +57 -55
  103. package/src/commands/check.ts +15 -12
  104. package/src/commands/dump/artifacts.ts +11 -15
  105. package/src/commands/dump/software.ts +9 -10
  106. package/src/commands/test.ts +15 -12
  107. package/src/compiler/artifactset.ts +7 -9
  108. package/src/compiler/compiler.test.ts +134 -137
  109. package/src/compiler/compiler.ts +62 -62
  110. package/src/compiler/compileroptions.ts +15 -15
  111. package/src/compiler/main.test.ts +23 -23
  112. package/src/compiler/main.ts +83 -100
  113. package/src/compiler/package.ts +14 -12
  114. package/src/compiler/source.test.ts +191 -183
  115. package/src/compiler/source.ts +106 -79
  116. package/src/compiler/template.test.ts +50 -49
  117. package/src/compiler/template.ts +11 -21
  118. package/src/compiler/test.artifacts.ts +47 -47
  119. package/src/compiler/util.ts +17 -17
  120. package/src/index.ts +10 -10
  121. package/src/shared/basecmd.ts +16 -16
  122. package/src/shared/dump.ts +49 -70
  123. package/src/shared/proc.ts +8 -8
@@ -4,25 +4,23 @@ import { createArtifactNameSet } from './artifactset.js';
4
4
  import { createHash } from 'node:crypto';
5
5
 
6
6
  // matches any valid name in tengo. Don't forget to use '\b' when needed to limit the boundaries!
7
- const namePattern = '[_a-zA-Z][_a-zA-Z0-9]*';
7
+ const namePattern = "[_a-zA-Z][_a-zA-Z0-9]*";
8
8
  const functionCallRE = (moduleName, fnName) => {
9
- return new RegExp(`\\b${moduleName}\\.(?<fnCall>(?<fnName>`
10
- + fnName
11
- + `)\\s*\\(\\s*"(?<templateName>[^"]+)"\\s*\\))`, 'g');
9
+ return new RegExp(`\\b${moduleName}\\.(?<fnCall>(?<fnName>` +
10
+ fnName +
11
+ `)\\s*\\(\\s*"(?<templateName>[^"]+)"\\s*\\))`, "g");
12
12
  };
13
13
  const functionCallLikeRE = (moduleName, fnName) => {
14
- return new RegExp(`\\b${moduleName}\\.(?<fnName>`
15
- + fnName
16
- + `)\\s*\\(`, 'g');
14
+ return new RegExp(`\\b${moduleName}\\.(?<fnName>` + fnName + `)\\s*\\(`, "g");
17
15
  };
18
- const newGetTemplateIdRE = (moduleName) => functionCallRE(moduleName, 'getTemplateId');
19
- const newGetSoftwareInfoRE = (moduleName) => functionCallRE(moduleName, 'getSoftwareInfo');
20
- const newImportTemplateRE = (moduleName) => functionCallRE(moduleName, 'importTemplate');
21
- const newImportTemplateDetector = (moduleName) => functionCallLikeRE(moduleName, 'importTemplate');
22
- const newImportSoftwareRE = (moduleName) => functionCallRE(moduleName, 'importSoftware');
23
- const newImportSoftwareDetector = (moduleName) => functionCallLikeRE(moduleName, 'importSoftware');
24
- const newImportAssetRE = (moduleName) => functionCallRE(moduleName, 'importAsset');
25
- const newImportAssetDetector = (moduleName) => functionCallLikeRE(moduleName, 'importAsset');
16
+ const newGetTemplateIdRE = (moduleName) => functionCallRE(moduleName, "getTemplateId");
17
+ const newGetSoftwareInfoRE = (moduleName) => functionCallRE(moduleName, "getSoftwareInfo");
18
+ const newImportTemplateRE = (moduleName) => functionCallRE(moduleName, "importTemplate");
19
+ const newImportTemplateDetector = (moduleName) => functionCallLikeRE(moduleName, "importTemplate");
20
+ const newImportSoftwareRE = (moduleName) => functionCallRE(moduleName, "importSoftware");
21
+ const newImportSoftwareDetector = (moduleName) => functionCallLikeRE(moduleName, "importSoftware");
22
+ const newImportAssetRE = (moduleName) => functionCallRE(moduleName, "importAsset");
23
+ const newImportAssetDetector = (moduleName) => functionCallLikeRE(moduleName, "importAsset");
26
24
  const emptyLineRE = /^\s*$/;
27
25
  const compilerOptionRE = /^\/\/tengo:[\w]/;
28
26
  const wrongCompilerOptionRE = /^\s*\/\/\s*tengo:\s*./;
@@ -45,10 +43,10 @@ const dependencyRE = /(?<pkgName>[^"]+)?:(?<depID>[^"]+)/; // use it to parse <m
45
43
  * //tengo:<option name> [<option arg1> [<option arg 2> [...]]]
46
44
  */
47
45
  const parseComplierOption = (opt) => {
48
- const parts = opt.split(' ');
49
- const namePart = parts[0].split(':');
46
+ const parts = opt.split(" ");
47
+ const namePart = parts[0].split(":");
50
48
  if (namePart.length != 2) {
51
- throw new Error('compiler option format is wrong: expect to have option name after \'tengo:\' prefix, like \'tengo:MyOption\'');
49
+ throw new Error("compiler option format is wrong: expect to have option name after 'tengo:' prefix, like 'tengo:MyOption'");
52
50
  }
53
51
  const optName = namePart[1];
54
52
  return {
@@ -104,7 +102,7 @@ function parseSourceData(logger, src, fullSourceName, globalizeImports) {
104
102
  const dependencySet = createArtifactNameSet();
105
103
  const optionList = [];
106
104
  // iterating over lines
107
- const lines = src.split('\n');
105
+ const lines = src.split("\n");
108
106
  // processedLines keep all the original lines from <src>.
109
107
  // If <globalizeImport>==true, the parser modifies 'import' and 'getTemplateId' lines
110
108
  // with Platforma Tengo lib and template usages, resolving local names (":<item>") to
@@ -115,13 +113,13 @@ function parseSourceData(logger, src, fullSourceName, globalizeImports) {
115
113
  canDetectOptions: true,
116
114
  artifactImportREs: new Map(),
117
115
  importLikeREs: new Map(),
118
- multilineStatement: '',
116
+ multilineStatement: "",
119
117
  lineNo: 0,
120
118
  };
121
119
  for (const line of lines) {
122
120
  parserContext.lineNo++;
123
121
  try {
124
- const { line: processedLine, context: newContext, artifacts, option } = parseSingleSourceLine(logger, line, parserContext, fullSourceName.pkg, globalizeImports);
122
+ const { line: processedLine, context: newContext, artifacts, option, } = parseSingleSourceLine(logger, line, parserContext, fullSourceName.pkg, globalizeImports);
125
123
  processedLines.push(processedLine);
126
124
  parserContext = newContext;
127
125
  for (const artifact of artifacts ?? []) {
@@ -137,7 +135,7 @@ function parseSourceData(logger, src, fullSourceName, globalizeImports) {
137
135
  }
138
136
  }
139
137
  return {
140
- normalized: processedLines.join('\n'),
138
+ normalized: processedLines.join("\n"),
141
139
  deps: dependencySet,
142
140
  opts: optionList,
143
141
  };
@@ -147,12 +145,12 @@ function parseSingleSourceLine(logger, line, context, localPackageName, globaliz
147
145
  if (multilineCommentEndRE.exec(line)) {
148
146
  context.isInCommentBlock = false;
149
147
  }
150
- return { line: '', context, artifacts: [], option: undefined };
148
+ return { line: "", context, artifacts: [], option: undefined };
151
149
  }
152
150
  if (compilerOptionRE.exec(line)) {
153
151
  if (!context.canDetectOptions) {
154
152
  logger.error(`[line ${context.lineNo}]: compiler option '//tengo:' was detected, but it cannot be applied as compiler options can be set only at the file header, before any code line'`);
155
- throw new Error('tengo compiler options (\'//tengo:\' comments) can be set only in file header');
153
+ throw new Error("tengo compiler options ('//tengo:' comments) can be set only in file header");
156
154
  }
157
155
  return { line, context, artifacts: [], option: parseComplierOption(line) };
158
156
  }
@@ -161,15 +159,15 @@ function parseSingleSourceLine(logger, line, context, localPackageName, globaliz
161
159
  return { line, context, artifacts: [], option: undefined };
162
160
  }
163
161
  if (singlelineCommentRE.test(line) || singlelineTerminatedCommentRE.test(line)) {
164
- return { line: '', context, artifacts: [], option: undefined };
162
+ return { line: "", context, artifacts: [], option: undefined };
165
163
  }
166
- const canBeInlinedComment = line.includes('*/');
164
+ const canBeInlinedComment = line.includes("*/");
167
165
  if (multilineCommentStartRE.exec(line) && !canBeInlinedComment) {
168
166
  context.isInCommentBlock = true;
169
- return { line: '', context, artifacts: [], option: undefined };
167
+ return { line: "", context, artifacts: [], option: undefined };
170
168
  }
171
169
  const statement = context.multilineStatement + line.trim();
172
- const mayContainAComment = line.includes('//') || line.includes('/*');
170
+ const mayContainAComment = line.includes("//") || line.includes("/*");
173
171
  if (multilineStatementRE.test(line) && !mayContainAComment) {
174
172
  // We accumulate multiline statements into single line before analyzing them.
175
173
  // This dramatically simplifies parsing logic: things like
@@ -197,7 +195,7 @@ function parseSingleSourceLine(logger, line, context, localPackageName, globaliz
197
195
  context.multilineStatement += result.line.trim(); // accumulate the line after imports globalization.
198
196
  return result;
199
197
  }
200
- context.multilineStatement = ''; // reset accumulated multiline statement parts once we reach statement end.
198
+ context.multilineStatement = ""; // reset accumulated multiline statement parts once we reach statement end.
201
199
  if (emptyLineRE.exec(statement)) {
202
200
  return { line, context, artifacts: [], option: undefined };
203
201
  }
@@ -209,46 +207,46 @@ function processModuleImport(importInstruction, originalLine, statement, context
209
207
  const iInfo = parseImport(statement);
210
208
  // If we have plapi, ll or assets, then try to parse
211
209
  // getTemplateId, getSoftwareInfo, getSoftware and getAsset calls.
212
- if (iInfo.module === 'plapi') {
210
+ if (iInfo.module === "plapi") {
213
211
  if (!context.artifactImportREs.has(iInfo.module)) {
214
212
  context.artifactImportREs.set(iInfo.module, [
215
- ['template', newGetTemplateIdRE(iInfo.alias)],
216
- ['software', newGetSoftwareInfoRE(iInfo.alias)],
213
+ ["template", newGetTemplateIdRE(iInfo.alias)],
214
+ ["software", newGetSoftwareInfoRE(iInfo.alias)],
217
215
  ]);
218
216
  }
219
217
  return { line: originalLine, context, artifacts: [], option: undefined };
220
218
  }
221
- if (iInfo.module === '@milaboratory/tengo-sdk:ll'
222
- || iInfo.module === '@platforma-sdk/workflow-tengo:ll'
223
- || ((localPackageName === '@milaboratory/tengo-sdk'
224
- || localPackageName === '@platforma-sdk/workflow-tengo')
225
- && iInfo.module === ':ll')) {
219
+ if (iInfo.module === "@milaboratory/tengo-sdk:ll" ||
220
+ iInfo.module === "@platforma-sdk/workflow-tengo:ll" ||
221
+ ((localPackageName === "@milaboratory/tengo-sdk" ||
222
+ localPackageName === "@platforma-sdk/workflow-tengo") &&
223
+ iInfo.module === ":ll")) {
226
224
  if (!context.artifactImportREs.has(iInfo.module)) {
227
225
  context.artifactImportREs.set(iInfo.module, [
228
- ['template', newImportTemplateRE(iInfo.alias)],
229
- ['software', newImportSoftwareRE(iInfo.alias)],
226
+ ["template", newImportTemplateRE(iInfo.alias)],
227
+ ["software", newImportSoftwareRE(iInfo.alias)],
230
228
  ]);
231
229
  }
232
230
  }
233
- if (iInfo.module === '@milaboratory/tengo-sdk:assets'
234
- || iInfo.module === '@platforma-sdk/workflow-tengo:assets'
235
- || ((localPackageName === '@milaboratory/tengo-sdk'
236
- || localPackageName === '@platforma-sdk/workflow-tengo')
237
- && iInfo.module === ':assets')) {
231
+ if (iInfo.module === "@milaboratory/tengo-sdk:assets" ||
232
+ iInfo.module === "@platforma-sdk/workflow-tengo:assets" ||
233
+ ((localPackageName === "@milaboratory/tengo-sdk" ||
234
+ localPackageName === "@platforma-sdk/workflow-tengo") &&
235
+ iInfo.module === ":assets")) {
238
236
  if (!context.artifactImportREs.has(iInfo.module)) {
239
237
  context.artifactImportREs.set(iInfo.module, [
240
- ['template', newImportTemplateRE(iInfo.alias)],
241
- ['software', newImportSoftwareRE(iInfo.alias)],
242
- ['asset', newImportAssetRE(iInfo.alias)],
238
+ ["template", newImportTemplateRE(iInfo.alias)],
239
+ ["software", newImportSoftwareRE(iInfo.alias)],
240
+ ["asset", newImportAssetRE(iInfo.alias)],
243
241
  ]);
244
242
  context.importLikeREs.set(iInfo.module, [
245
- ['template', newImportTemplateDetector(iInfo.alias)],
246
- ['software', newImportSoftwareDetector(iInfo.alias)],
247
- ['asset', newImportAssetDetector(iInfo.alias)],
243
+ ["template", newImportTemplateDetector(iInfo.alias)],
244
+ ["software", newImportSoftwareDetector(iInfo.alias)],
245
+ ["asset", newImportAssetDetector(iInfo.alias)],
248
246
  ]);
249
247
  }
250
248
  }
251
- const artifact = parseArtifactName(iInfo.module, 'library', localPackageName);
249
+ const artifact = parseArtifactName(iInfo.module, "library", localPackageName);
252
250
  if (!artifact) {
253
251
  // not a Platforma Tengo library import
254
252
  return { line: originalLine, context, artifacts: [], option: undefined };
@@ -342,7 +340,7 @@ function parseArtifactName(moduleName, aType, localPackageName) {
342
340
  return { type: aType, pkg: pkgName ?? localPackageName, id: depID };
343
341
  }
344
342
  function getSha256(source) {
345
- return createHash('sha256').update(source).digest('hex');
343
+ return createHash("sha256").update(source).digest("hex");
346
344
  }
347
345
 
348
346
  export { ArtifactSource, getSha256, newGetSoftwareInfoRE, newGetTemplateIdRE, parseSingleSourceLine, parseSourceFile };
@@ -1 +1 @@
1
- {"version":3,"file":"source.js","sources":["../../src/compiler/source.ts"],"sourcesContent":["import { readFileSync } from 'node:fs';\nimport {\n type TypedArtifactName,\n type FullArtifactName,\n type ArtifactType,\n type CompileMode,\n type CompilerOption,\n fullNameToString,\n} from './package';\nimport type { ArtifactMap } from './artifactset';\nimport { createArtifactNameSet } from './artifactset';\nimport { createHash } from 'node:crypto';\nimport type { MiLogger } from '@milaboratories/ts-helpers';\n\n// matches any valid name in tengo. Don't forget to use '\\b' when needed to limit the boundaries!\nconst namePattern = '[_a-zA-Z][_a-zA-Z0-9]*';\n\nconst functionCallRE = (moduleName: string, fnName: string) => {\n return new RegExp(\n `\\\\b${moduleName}\\\\.(?<fnCall>(?<fnName>`\n + fnName\n + `)\\\\s*\\\\(\\\\s*\"(?<templateName>[^\"]+)\"\\\\s*\\\\))`,\n 'g',\n );\n};\n\nconst functionCallLikeRE = (moduleName: string, fnName: string) => {\n return new RegExp(\n `\\\\b${moduleName}\\\\.(?<fnName>`\n + fnName\n + `)\\\\s*\\\\(`,\n 'g',\n );\n};\n\nexport const newGetTemplateIdRE = (moduleName: string) => functionCallRE(moduleName, 'getTemplateId');\nexport const newGetSoftwareInfoRE = (moduleName: string) => functionCallRE(moduleName, 'getSoftwareInfo');\n\nconst newImportTemplateRE = (moduleName: string) => functionCallRE(moduleName, 'importTemplate');\nconst newImportTemplateDetector = (moduleName: string) => functionCallLikeRE(moduleName, 'importTemplate');\nconst newImportSoftwareRE = (moduleName: string) => functionCallRE(moduleName, 'importSoftware');\nconst newImportSoftwareDetector = (moduleName: string) => functionCallLikeRE(moduleName, 'importSoftware');\nconst newImportAssetRE = (moduleName: string) => functionCallRE(moduleName, 'importAsset');\nconst newImportAssetDetector = (moduleName: string) => functionCallLikeRE(moduleName, 'importAsset');\n\nconst emptyLineRE = /^\\s*$/;\nconst compilerOptionRE = /^\\/\\/tengo:[\\w]/;\nconst wrongCompilerOptionRE = /^\\s*\\/\\/\\s*tengo:\\s*./;\nconst singlelineCommentRE = /^\\s*(\\/\\/)/;\nconst singlelineTerminatedCommentRE = /^\\s*\\/\\*.*\\*\\/\\s*$/; // matches '^/* ... */$' comment lines as a special case of singleline comments.\nconst multilineCommentStartRE = /^\\s*\\/\\*/;\nconst multilineCommentEndRE = /\\*\\//;\nconst multilineStatementRE = /[.,]\\s*$/; // it is hard to consistently treat (\\n\"a\"\\n) multiline statements, we forbid them for now.\n\n// import could only be an assignment in a statement,\n// other ways could break a compilation.\nconst importRE = /\\s*:=\\s*import\\s*\\(\\s*\"(?<moduleName>[^\"]+)\"\\s*\\)/;\nconst importNameRE = new RegExp(\n `\\\\b(?<importName>${namePattern}(\\\\.${namePattern})*)${importRE.source}`,\n);\nconst dependencyRE = /(?<pkgName>[^\"]+)?:(?<depID>[^\"]+)/; // use it to parse <moduleName> from importPattern or <templateName> from getTemplateID\n\n/**\n * Parse compiler option string representation\n * Compiler option line is a comment starting with '//tengo:', say\n * //tengo:hash_override tralala\n *\n * The common compiler option syntax is:\n * //tengo:<option name> [<option arg1> [<option arg 2> [...]]]\n */\nconst parseComplierOption = (opt: string): CompilerOption => {\n const parts = opt.split(' ');\n const namePart = parts[0].split(':');\n if (namePart.length != 2) {\n throw new Error(\n 'compiler option format is wrong: expect to have option name after \\'tengo:\\' prefix, like \\'tengo:MyOption\\'',\n );\n }\n const optName = namePart[1];\n\n return {\n name: optName,\n args: parts.slice(1),\n };\n};\n\nexport class ArtifactSource {\n constructor(\n /** The mode this artifact was built (dev or dist) */\n public readonly compileMode: CompileMode,\n /** Full artifact id, including package version */\n public readonly fullName: FullArtifactName,\n /** Hash of the source code */\n public readonly sourceHash: string,\n /** Normalized source code */\n public readonly src: string,\n /** Path to source file where artifact came from */\n public readonly srcName: string,\n /** List of dependencies */\n public readonly dependencies: TypedArtifactName[],\n /** Additional compiler options detected in source code */\n public readonly compilerOptions: CompilerOption[],\n ) {}\n}\n\nexport function parseSourceFile(\n logger: MiLogger,\n mode: CompileMode,\n srcFile: string,\n fullSourceName: FullArtifactName,\n normalize: boolean,\n): ArtifactSource {\n const src = readFileSync(srcFile).toString();\n const { deps, normalized, opts } = parseSourceData(logger, src, fullSourceName, normalize);\n\n return new ArtifactSource(\n mode,\n fullSourceName,\n getSha256(normalized),\n normalized,\n srcFile,\n deps.array,\n opts,\n );\n}\n\nexport function parseSource(\n logger: MiLogger,\n mode: CompileMode,\n src: string,\n fullSourceName: FullArtifactName,\n normalize: boolean,\n): ArtifactSource {\n const { deps, normalized, opts } = parseSourceData(logger, src, fullSourceName, normalize);\n\n return new ArtifactSource(mode, fullSourceName, getSha256(normalized), normalized, '', deps.array, opts);\n}\n\n/**\n * Reads src\n * returns normalized source code,\n * gets dependencies from imports,\n * maps imports to global names if globalizeImports is true,\n * and collects compiler options like hashOverride.\n */\nfunction parseSourceData(\n logger: MiLogger,\n src: string,\n fullSourceName: FullArtifactName,\n globalizeImports: boolean,\n): {\n normalized: string;\n deps: ArtifactMap<TypedArtifactName>;\n opts: CompilerOption[];\n } {\n const dependencySet = createArtifactNameSet();\n const optionList: CompilerOption[] = [];\n\n // iterating over lines\n const lines = src.split('\\n');\n\n // processedLines keep all the original lines from <src>.\n // If <globalizeImport>==true, the parser modifies 'import' and 'getTemplateId' lines\n // with Platforma Tengo lib and template usages, resolving local names (\":<item>\") to\n // global (\"@milaboratory/pkg:<item>\")\n const processedLines: string[] = [];\n let parserContext: sourceParserContext = {\n isInCommentBlock: false,\n canDetectOptions: true,\n artifactImportREs: new Map<string, [ArtifactType, RegExp][]>(),\n importLikeREs: new Map<string, [ArtifactType, RegExp][]>(),\n multilineStatement: '',\n lineNo: 0,\n };\n\n for (const line of lines) {\n parserContext.lineNo++;\n\n try {\n const { line: processedLine, context: newContext, artifacts, option } = parseSingleSourceLine(\n logger,\n line,\n parserContext,\n fullSourceName.pkg,\n globalizeImports,\n );\n processedLines.push(processedLine);\n parserContext = newContext;\n\n for (const artifact of artifacts ?? []) {\n dependencySet.add(artifact);\n }\n if (option) {\n optionList.push(option);\n }\n } catch (error: unknown) {\n const err = error as Error;\n throw new Error(`[line ${parserContext.lineNo} in ${fullNameToString(fullSourceName)}]: ${err.message}\\n\\t${line}`, { cause: err });\n }\n }\n\n return {\n normalized: processedLines.join('\\n'),\n deps: dependencySet,\n opts: optionList,\n };\n}\n\nexport type sourceParserContext = {\n isInCommentBlock: boolean;\n canDetectOptions: boolean;\n artifactImportREs: Map<string, [ArtifactType, RegExp][]>;\n importLikeREs: Map<string, [ArtifactType, RegExp][]>;\n multilineStatement: string;\n lineNo: number;\n};\n\nexport type lineProcessingResult = {\n line: string;\n context: sourceParserContext;\n artifacts: TypedArtifactName[];\n option: CompilerOption | undefined;\n};\n\nexport function parseSingleSourceLine(\n logger: MiLogger,\n line: string,\n context: sourceParserContext,\n localPackageName: string,\n globalizeImports?: boolean,\n): lineProcessingResult {\n if (context.isInCommentBlock) {\n if (multilineCommentEndRE.exec(line)) {\n context.isInCommentBlock = false;\n }\n return { line: '', context, artifacts: [], option: undefined };\n }\n\n if (compilerOptionRE.exec(line)) {\n if (!context.canDetectOptions) {\n logger.error(\n `[line ${context.lineNo}]: compiler option '//tengo:' was detected, but it cannot be applied as compiler options can be set only at the file header, before any code line'`,\n );\n throw new Error('tengo compiler options (\\'//tengo:\\' comments) can be set only in file header');\n }\n return { line, context, artifacts: [], option: parseComplierOption(line) };\n }\n\n if (wrongCompilerOptionRE.exec(line) && context.canDetectOptions) {\n logger.warn(\n `[line ${context.lineNo}]: text simillar to compiler option ('//tengo:...') was detected, but it has wrong format. Leave it as is, if you did not mean to use a line as compiler option. Or format it to '//tengo:<option>' otherwise (no spaces between '//' and 'tengo', no spaces between ':' and option name)`,\n );\n return { line, context, artifacts: [], option: undefined };\n }\n\n if (singlelineCommentRE.test(line) || singlelineTerminatedCommentRE.test(line)) {\n return { line: '', context, artifacts: [], option: undefined };\n }\n\n const canBeInlinedComment = line.includes('*/');\n if (multilineCommentStartRE.exec(line) && !canBeInlinedComment) {\n context.isInCommentBlock = true;\n return { line: '', context, artifacts: [], option: undefined };\n }\n\n const statement = context.multilineStatement + line.trim();\n\n const mayContainAComment = line.includes('//') || line.includes('/*');\n if (multilineStatementRE.test(line) && !mayContainAComment) {\n // We accumulate multiline statements into single line before analyzing them.\n // This dramatically simplifies parsing logic: things like\n //\n // assets.\n // importSoftware(\"a:b\");\n //\n // become simple 'assets.importSoftware(\"a:b\");' for parser checks.\n //\n // For safety reasons, we never consider anything that 'may look like a comment'\n // as a part of multiline statement to prevent joining things like\n //\n // someFnCall() // looks like multiline statement because of dot in the end of a comment.\n //\n // This problem also appears in multiline string literals, but I hope this will not\n // cause problems in real life.\n\n // We still try to process each line to globalize imports in case of complex constructions, when\n // statements are stacked one into another:\n // a.\n // use(assets.importSoftware(\":soft1\")).\n // use(assets.importSoftware(\":soft2\")).\n // run()\n // It is multiline, and it still requires import globalization mid-way, not just for the last line of statement\n const result = processAssetImport(line, statement, context, localPackageName, globalizeImports);\n context.multilineStatement += result.line.trim(); // accumulate the line after imports globalization.\n return result;\n }\n\n context.multilineStatement = ''; // reset accumulated multiline statement parts once we reach statement end.\n\n if (emptyLineRE.exec(statement)) {\n return { line, context, artifacts: [], option: undefined };\n }\n\n // options could be only at the top of the file.\n context.canDetectOptions = false;\n\n return processAssetImport(line, statement, context, localPackageName, globalizeImports);\n}\n\nfunction processModuleImport(\n importInstruction: RegExpExecArray,\n originalLine: string,\n statement: string,\n context: sourceParserContext,\n localPackageName: string,\n globalizeImports?: boolean,\n): lineProcessingResult {\n const iInfo = parseImport(statement);\n\n // If we have plapi, ll or assets, then try to parse\n // getTemplateId, getSoftwareInfo, getSoftware and getAsset calls.\n\n if (iInfo.module === 'plapi') {\n if (!context.artifactImportREs.has(iInfo.module)) {\n context.artifactImportREs.set(iInfo.module, [\n ['template', newGetTemplateIdRE(iInfo.alias)],\n ['software', newGetSoftwareInfoRE(iInfo.alias)],\n ]);\n }\n return { line: originalLine, context, artifacts: [], option: undefined };\n }\n\n if (\n iInfo.module === '@milaboratory/tengo-sdk:ll'\n || iInfo.module === '@platforma-sdk/workflow-tengo:ll'\n || ((localPackageName === '@milaboratory/tengo-sdk'\n || localPackageName === '@platforma-sdk/workflow-tengo')\n && iInfo.module === ':ll')\n ) {\n if (!context.artifactImportREs.has(iInfo.module)) {\n context.artifactImportREs.set(iInfo.module, [\n ['template', newImportTemplateRE(iInfo.alias)],\n ['software', newImportSoftwareRE(iInfo.alias)],\n ]);\n }\n }\n\n if (\n iInfo.module === '@milaboratory/tengo-sdk:assets'\n || iInfo.module === '@platforma-sdk/workflow-tengo:assets'\n || ((localPackageName === '@milaboratory/tengo-sdk'\n || localPackageName === '@platforma-sdk/workflow-tengo')\n && iInfo.module === ':assets')\n ) {\n if (!context.artifactImportREs.has(iInfo.module)) {\n context.artifactImportREs.set(iInfo.module, [\n ['template', newImportTemplateRE(iInfo.alias)],\n ['software', newImportSoftwareRE(iInfo.alias)],\n ['asset', newImportAssetRE(iInfo.alias)],\n ]);\n context.importLikeREs.set(iInfo.module, [\n ['template', newImportTemplateDetector(iInfo.alias)],\n ['software', newImportSoftwareDetector(iInfo.alias)],\n ['asset', newImportAssetDetector(iInfo.alias)],\n ]);\n }\n }\n\n const artifact = parseArtifactName(iInfo.module, 'library', localPackageName);\n if (!artifact) {\n // not a Platforma Tengo library import\n return { line: originalLine, context, artifacts: [], option: undefined };\n }\n\n if (globalizeImports) {\n originalLine = originalLine.replace(importInstruction[0], ` := import(\"${artifact.pkg}:${artifact.id}\")`);\n }\n\n return { line: originalLine, context, artifacts: [artifact], option: undefined };\n}\n\nfunction processAssetImport(\n originalLine: string,\n statement: string,\n context: sourceParserContext,\n localPackageName: string,\n globalizeImports?: boolean,\n): lineProcessingResult {\n if (emptyLineRE.exec(statement)) {\n return { line: originalLine, context, artifacts: [], option: undefined };\n }\n\n // options could be only at the top of the file.\n context.canDetectOptions = false;\n\n const importInstruction = importRE.exec(statement);\n\n if (importInstruction) {\n return processModuleImport(importInstruction, originalLine, statement, context, localPackageName, globalizeImports);\n }\n\n if (context.artifactImportREs.size > 0) {\n for (const [_, artifactRE] of context.artifactImportREs) {\n for (const [artifactType, re] of artifactRE) {\n // Find all matches in the statement\n const matches = Array.from(statement.matchAll(re));\n if (matches.length === 0) {\n continue;\n }\n\n const artifacts: TypedArtifactName[] = [];\n for (let i = matches.length - 1; i >= 0; i--) {\n const match = matches[i];\n if (!match || !match.groups) {\n continue;\n }\n\n const { fnCall, templateName, fnName } = match.groups;\n\n if (!fnCall || !templateName || !fnName) {\n throw Error(`failed to parse template import statement`);\n }\n\n const artifact = parseArtifactName(templateName, artifactType, localPackageName);\n if (!artifact) {\n throw Error(`failed to parse artifact name in ${fnName} import statement`);\n }\n artifacts.push(artifact);\n\n if (globalizeImports) {\n // Replace all occurrences of this fnCall in originalLine\n originalLine = originalLine.replaceAll(fnCall, `${fnName}(\"${artifact.pkg}:${artifact.id}\")`);\n }\n }\n\n return { line: originalLine, context, artifacts, option: undefined };\n }\n }\n }\n\n if (context.importLikeREs.size > 0) {\n for (const [_, artifactRE] of context.importLikeREs) {\n for (const [artifactType, re] of artifactRE) {\n const match = re.exec(statement);\n if (!match || !match.groups) {\n continue;\n }\n\n throw Error(`incorrect '${artifactType}' import statement: use string literal as ID (variables are not allowed) in the same line with brackets (i.e. 'importSoftware(\"sw:main\")').`);\n }\n }\n }\n\n return { line: originalLine, context, artifacts: [], option: undefined };\n}\n\ninterface ImportInfo {\n module: string; // the module name without wrapping quotes: import(\"<module>\")\n alias: string; // the name of variable that keeps imported module: <alias> := import(\"<module>\")\n}\n\nfunction parseImport(line: string): ImportInfo {\n const match = importNameRE.exec(line);\n\n if (!match || !match.groups) {\n throw Error(`failed to parse 'import' statement`);\n }\n\n const { importName, moduleName } = match.groups;\n if (!importName || !moduleName) {\n throw Error(`failed to parse 'import' statement`);\n }\n\n return {\n module: moduleName, // the module name without wrapping quotes: import(\"<module>\")\n alias: importName, // the name of variable that keeps imported module: <alias> := import(\"<module>\")\n };\n}\n\nfunction parseArtifactName(\n moduleName: string,\n aType: ArtifactType,\n localPackageName: string,\n): TypedArtifactName | undefined {\n const depInfo = dependencyRE.exec(moduleName);\n if (!depInfo) {\n return;\n }\n\n if (!depInfo.groups) {\n throw Error(\n `failed to parse dependency name inside 'import' statement. The dependency name should have format '<package>:<templateName>'`,\n );\n }\n\n const { pkgName, depID } = depInfo.groups;\n if (!depID) {\n throw Error(\n `failed to parse dependency name inside 'import' statement. The dependency name should have format '<package>:<templateName>'`,\n );\n }\n\n return { type: aType, pkg: pkgName ?? localPackageName, id: depID };\n}\n\nexport function getSha256(source: string): string {\n return createHash('sha256').update(source).digest('hex');\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"source.js","sources":["../../src/compiler/source.ts"],"sourcesContent":["import { readFileSync } from \"node:fs\";\nimport {\n type TypedArtifactName,\n type FullArtifactName,\n type ArtifactType,\n type CompileMode,\n type CompilerOption,\n fullNameToString,\n} from \"./package\";\nimport type { ArtifactMap } from \"./artifactset\";\nimport { createArtifactNameSet } from \"./artifactset\";\nimport { createHash } from \"node:crypto\";\nimport type { MiLogger } from \"@milaboratories/ts-helpers\";\n\n// matches any valid name in tengo. Don't forget to use '\\b' when needed to limit the boundaries!\nconst namePattern = \"[_a-zA-Z][_a-zA-Z0-9]*\";\n\nconst functionCallRE = (moduleName: string, fnName: string) => {\n return new RegExp(\n `\\\\b${moduleName}\\\\.(?<fnCall>(?<fnName>` +\n fnName +\n `)\\\\s*\\\\(\\\\s*\"(?<templateName>[^\"]+)\"\\\\s*\\\\))`,\n \"g\",\n );\n};\n\nconst functionCallLikeRE = (moduleName: string, fnName: string) => {\n return new RegExp(`\\\\b${moduleName}\\\\.(?<fnName>` + fnName + `)\\\\s*\\\\(`, \"g\");\n};\n\nexport const newGetTemplateIdRE = (moduleName: string) =>\n functionCallRE(moduleName, \"getTemplateId\");\nexport const newGetSoftwareInfoRE = (moduleName: string) =>\n functionCallRE(moduleName, \"getSoftwareInfo\");\n\nconst newImportTemplateRE = (moduleName: string) => functionCallRE(moduleName, \"importTemplate\");\nconst newImportTemplateDetector = (moduleName: string) =>\n functionCallLikeRE(moduleName, \"importTemplate\");\nconst newImportSoftwareRE = (moduleName: string) => functionCallRE(moduleName, \"importSoftware\");\nconst newImportSoftwareDetector = (moduleName: string) =>\n functionCallLikeRE(moduleName, \"importSoftware\");\nconst newImportAssetRE = (moduleName: string) => functionCallRE(moduleName, \"importAsset\");\nconst newImportAssetDetector = (moduleName: string) =>\n functionCallLikeRE(moduleName, \"importAsset\");\n\nconst emptyLineRE = /^\\s*$/;\nconst compilerOptionRE = /^\\/\\/tengo:[\\w]/;\nconst wrongCompilerOptionRE = /^\\s*\\/\\/\\s*tengo:\\s*./;\nconst singlelineCommentRE = /^\\s*(\\/\\/)/;\nconst singlelineTerminatedCommentRE = /^\\s*\\/\\*.*\\*\\/\\s*$/; // matches '^/* ... */$' comment lines as a special case of singleline comments.\nconst multilineCommentStartRE = /^\\s*\\/\\*/;\nconst multilineCommentEndRE = /\\*\\//;\nconst multilineStatementRE = /[.,]\\s*$/; // it is hard to consistently treat (\\n\"a\"\\n) multiline statements, we forbid them for now.\n\n// import could only be an assignment in a statement,\n// other ways could break a compilation.\nconst importRE = /\\s*:=\\s*import\\s*\\(\\s*\"(?<moduleName>[^\"]+)\"\\s*\\)/;\nconst importNameRE = new RegExp(\n `\\\\b(?<importName>${namePattern}(\\\\.${namePattern})*)${importRE.source}`,\n);\nconst dependencyRE = /(?<pkgName>[^\"]+)?:(?<depID>[^\"]+)/; // use it to parse <moduleName> from importPattern or <templateName> from getTemplateID\n\n/**\n * Parse compiler option string representation\n * Compiler option line is a comment starting with '//tengo:', say\n * //tengo:hash_override tralala\n *\n * The common compiler option syntax is:\n * //tengo:<option name> [<option arg1> [<option arg 2> [...]]]\n */\nconst parseComplierOption = (opt: string): CompilerOption => {\n const parts = opt.split(\" \");\n const namePart = parts[0].split(\":\");\n if (namePart.length != 2) {\n throw new Error(\n \"compiler option format is wrong: expect to have option name after 'tengo:' prefix, like 'tengo:MyOption'\",\n );\n }\n const optName = namePart[1];\n\n return {\n name: optName,\n args: parts.slice(1),\n };\n};\n\nexport class ArtifactSource {\n constructor(\n /** The mode this artifact was built (dev or dist) */\n public readonly compileMode: CompileMode,\n /** Full artifact id, including package version */\n public readonly fullName: FullArtifactName,\n /** Hash of the source code */\n public readonly sourceHash: string,\n /** Normalized source code */\n public readonly src: string,\n /** Path to source file where artifact came from */\n public readonly srcName: string,\n /** List of dependencies */\n public readonly dependencies: TypedArtifactName[],\n /** Additional compiler options detected in source code */\n public readonly compilerOptions: CompilerOption[],\n ) {}\n}\n\nexport function parseSourceFile(\n logger: MiLogger,\n mode: CompileMode,\n srcFile: string,\n fullSourceName: FullArtifactName,\n normalize: boolean,\n): ArtifactSource {\n const src = readFileSync(srcFile).toString();\n const { deps, normalized, opts } = parseSourceData(logger, src, fullSourceName, normalize);\n\n return new ArtifactSource(\n mode,\n fullSourceName,\n getSha256(normalized),\n normalized,\n srcFile,\n deps.array,\n opts,\n );\n}\n\nexport function parseSource(\n logger: MiLogger,\n mode: CompileMode,\n src: string,\n fullSourceName: FullArtifactName,\n normalize: boolean,\n): ArtifactSource {\n const { deps, normalized, opts } = parseSourceData(logger, src, fullSourceName, normalize);\n\n return new ArtifactSource(\n mode,\n fullSourceName,\n getSha256(normalized),\n normalized,\n \"\",\n deps.array,\n opts,\n );\n}\n\n/**\n * Reads src\n * returns normalized source code,\n * gets dependencies from imports,\n * maps imports to global names if globalizeImports is true,\n * and collects compiler options like hashOverride.\n */\nfunction parseSourceData(\n logger: MiLogger,\n src: string,\n fullSourceName: FullArtifactName,\n globalizeImports: boolean,\n): {\n normalized: string;\n deps: ArtifactMap<TypedArtifactName>;\n opts: CompilerOption[];\n} {\n const dependencySet = createArtifactNameSet();\n const optionList: CompilerOption[] = [];\n\n // iterating over lines\n const lines = src.split(\"\\n\");\n\n // processedLines keep all the original lines from <src>.\n // If <globalizeImport>==true, the parser modifies 'import' and 'getTemplateId' lines\n // with Platforma Tengo lib and template usages, resolving local names (\":<item>\") to\n // global (\"@milaboratory/pkg:<item>\")\n const processedLines: string[] = [];\n let parserContext: sourceParserContext = {\n isInCommentBlock: false,\n canDetectOptions: true,\n artifactImportREs: new Map<string, [ArtifactType, RegExp][]>(),\n importLikeREs: new Map<string, [ArtifactType, RegExp][]>(),\n multilineStatement: \"\",\n lineNo: 0,\n };\n\n for (const line of lines) {\n parserContext.lineNo++;\n\n try {\n const {\n line: processedLine,\n context: newContext,\n artifacts,\n option,\n } = parseSingleSourceLine(logger, line, parserContext, fullSourceName.pkg, globalizeImports);\n processedLines.push(processedLine);\n parserContext = newContext;\n\n for (const artifact of artifacts ?? []) {\n dependencySet.add(artifact);\n }\n if (option) {\n optionList.push(option);\n }\n } catch (error: unknown) {\n const err = error as Error;\n throw new Error(\n `[line ${parserContext.lineNo} in ${fullNameToString(fullSourceName)}]: ${err.message}\\n\\t${line}`,\n { cause: err },\n );\n }\n }\n\n return {\n normalized: processedLines.join(\"\\n\"),\n deps: dependencySet,\n opts: optionList,\n };\n}\n\nexport type sourceParserContext = {\n isInCommentBlock: boolean;\n canDetectOptions: boolean;\n artifactImportREs: Map<string, [ArtifactType, RegExp][]>;\n importLikeREs: Map<string, [ArtifactType, RegExp][]>;\n multilineStatement: string;\n lineNo: number;\n};\n\nexport type lineProcessingResult = {\n line: string;\n context: sourceParserContext;\n artifacts: TypedArtifactName[];\n option: CompilerOption | undefined;\n};\n\nexport function parseSingleSourceLine(\n logger: MiLogger,\n line: string,\n context: sourceParserContext,\n localPackageName: string,\n globalizeImports?: boolean,\n): lineProcessingResult {\n if (context.isInCommentBlock) {\n if (multilineCommentEndRE.exec(line)) {\n context.isInCommentBlock = false;\n }\n return { line: \"\", context, artifacts: [], option: undefined };\n }\n\n if (compilerOptionRE.exec(line)) {\n if (!context.canDetectOptions) {\n logger.error(\n `[line ${context.lineNo}]: compiler option '//tengo:' was detected, but it cannot be applied as compiler options can be set only at the file header, before any code line'`,\n );\n throw new Error(\n \"tengo compiler options ('//tengo:' comments) can be set only in file header\",\n );\n }\n return { line, context, artifacts: [], option: parseComplierOption(line) };\n }\n\n if (wrongCompilerOptionRE.exec(line) && context.canDetectOptions) {\n logger.warn(\n `[line ${context.lineNo}]: text simillar to compiler option ('//tengo:...') was detected, but it has wrong format. Leave it as is, if you did not mean to use a line as compiler option. Or format it to '//tengo:<option>' otherwise (no spaces between '//' and 'tengo', no spaces between ':' and option name)`,\n );\n return { line, context, artifacts: [], option: undefined };\n }\n\n if (singlelineCommentRE.test(line) || singlelineTerminatedCommentRE.test(line)) {\n return { line: \"\", context, artifacts: [], option: undefined };\n }\n\n const canBeInlinedComment = line.includes(\"*/\");\n if (multilineCommentStartRE.exec(line) && !canBeInlinedComment) {\n context.isInCommentBlock = true;\n return { line: \"\", context, artifacts: [], option: undefined };\n }\n\n const statement = context.multilineStatement + line.trim();\n\n const mayContainAComment = line.includes(\"//\") || line.includes(\"/*\");\n if (multilineStatementRE.test(line) && !mayContainAComment) {\n // We accumulate multiline statements into single line before analyzing them.\n // This dramatically simplifies parsing logic: things like\n //\n // assets.\n // importSoftware(\"a:b\");\n //\n // become simple 'assets.importSoftware(\"a:b\");' for parser checks.\n //\n // For safety reasons, we never consider anything that 'may look like a comment'\n // as a part of multiline statement to prevent joining things like\n //\n // someFnCall() // looks like multiline statement because of dot in the end of a comment.\n //\n // This problem also appears in multiline string literals, but I hope this will not\n // cause problems in real life.\n\n // We still try to process each line to globalize imports in case of complex constructions, when\n // statements are stacked one into another:\n // a.\n // use(assets.importSoftware(\":soft1\")).\n // use(assets.importSoftware(\":soft2\")).\n // run()\n // It is multiline, and it still requires import globalization mid-way, not just for the last line of statement\n const result = processAssetImport(line, statement, context, localPackageName, globalizeImports);\n context.multilineStatement += result.line.trim(); // accumulate the line after imports globalization.\n return result;\n }\n\n context.multilineStatement = \"\"; // reset accumulated multiline statement parts once we reach statement end.\n\n if (emptyLineRE.exec(statement)) {\n return { line, context, artifacts: [], option: undefined };\n }\n\n // options could be only at the top of the file.\n context.canDetectOptions = false;\n\n return processAssetImport(line, statement, context, localPackageName, globalizeImports);\n}\n\nfunction processModuleImport(\n importInstruction: RegExpExecArray,\n originalLine: string,\n statement: string,\n context: sourceParserContext,\n localPackageName: string,\n globalizeImports?: boolean,\n): lineProcessingResult {\n const iInfo = parseImport(statement);\n\n // If we have plapi, ll or assets, then try to parse\n // getTemplateId, getSoftwareInfo, getSoftware and getAsset calls.\n\n if (iInfo.module === \"plapi\") {\n if (!context.artifactImportREs.has(iInfo.module)) {\n context.artifactImportREs.set(iInfo.module, [\n [\"template\", newGetTemplateIdRE(iInfo.alias)],\n [\"software\", newGetSoftwareInfoRE(iInfo.alias)],\n ]);\n }\n return { line: originalLine, context, artifacts: [], option: undefined };\n }\n\n if (\n iInfo.module === \"@milaboratory/tengo-sdk:ll\" ||\n iInfo.module === \"@platforma-sdk/workflow-tengo:ll\" ||\n ((localPackageName === \"@milaboratory/tengo-sdk\" ||\n localPackageName === \"@platforma-sdk/workflow-tengo\") &&\n iInfo.module === \":ll\")\n ) {\n if (!context.artifactImportREs.has(iInfo.module)) {\n context.artifactImportREs.set(iInfo.module, [\n [\"template\", newImportTemplateRE(iInfo.alias)],\n [\"software\", newImportSoftwareRE(iInfo.alias)],\n ]);\n }\n }\n\n if (\n iInfo.module === \"@milaboratory/tengo-sdk:assets\" ||\n iInfo.module === \"@platforma-sdk/workflow-tengo:assets\" ||\n ((localPackageName === \"@milaboratory/tengo-sdk\" ||\n localPackageName === \"@platforma-sdk/workflow-tengo\") &&\n iInfo.module === \":assets\")\n ) {\n if (!context.artifactImportREs.has(iInfo.module)) {\n context.artifactImportREs.set(iInfo.module, [\n [\"template\", newImportTemplateRE(iInfo.alias)],\n [\"software\", newImportSoftwareRE(iInfo.alias)],\n [\"asset\", newImportAssetRE(iInfo.alias)],\n ]);\n context.importLikeREs.set(iInfo.module, [\n [\"template\", newImportTemplateDetector(iInfo.alias)],\n [\"software\", newImportSoftwareDetector(iInfo.alias)],\n [\"asset\", newImportAssetDetector(iInfo.alias)],\n ]);\n }\n }\n\n const artifact = parseArtifactName(iInfo.module, \"library\", localPackageName);\n if (!artifact) {\n // not a Platforma Tengo library import\n return { line: originalLine, context, artifacts: [], option: undefined };\n }\n\n if (globalizeImports) {\n originalLine = originalLine.replace(\n importInstruction[0],\n ` := import(\"${artifact.pkg}:${artifact.id}\")`,\n );\n }\n\n return { line: originalLine, context, artifacts: [artifact], option: undefined };\n}\n\nfunction processAssetImport(\n originalLine: string,\n statement: string,\n context: sourceParserContext,\n localPackageName: string,\n globalizeImports?: boolean,\n): lineProcessingResult {\n if (emptyLineRE.exec(statement)) {\n return { line: originalLine, context, artifacts: [], option: undefined };\n }\n\n // options could be only at the top of the file.\n context.canDetectOptions = false;\n\n const importInstruction = importRE.exec(statement);\n\n if (importInstruction) {\n return processModuleImport(\n importInstruction,\n originalLine,\n statement,\n context,\n localPackageName,\n globalizeImports,\n );\n }\n\n if (context.artifactImportREs.size > 0) {\n for (const [_, artifactRE] of context.artifactImportREs) {\n for (const [artifactType, re] of artifactRE) {\n // Find all matches in the statement\n const matches = Array.from(statement.matchAll(re));\n if (matches.length === 0) {\n continue;\n }\n\n const artifacts: TypedArtifactName[] = [];\n for (let i = matches.length - 1; i >= 0; i--) {\n const match = matches[i];\n if (!match || !match.groups) {\n continue;\n }\n\n const { fnCall, templateName, fnName } = match.groups;\n\n if (!fnCall || !templateName || !fnName) {\n throw Error(`failed to parse template import statement`);\n }\n\n const artifact = parseArtifactName(templateName, artifactType, localPackageName);\n if (!artifact) {\n throw Error(`failed to parse artifact name in ${fnName} import statement`);\n }\n artifacts.push(artifact);\n\n if (globalizeImports) {\n // Replace all occurrences of this fnCall in originalLine\n originalLine = originalLine.replaceAll(\n fnCall,\n `${fnName}(\"${artifact.pkg}:${artifact.id}\")`,\n );\n }\n }\n\n return { line: originalLine, context, artifacts, option: undefined };\n }\n }\n }\n\n if (context.importLikeREs.size > 0) {\n for (const [_, artifactRE] of context.importLikeREs) {\n for (const [artifactType, re] of artifactRE) {\n const match = re.exec(statement);\n if (!match || !match.groups) {\n continue;\n }\n\n throw Error(\n `incorrect '${artifactType}' import statement: use string literal as ID (variables are not allowed) in the same line with brackets (i.e. 'importSoftware(\"sw:main\")').`,\n );\n }\n }\n }\n\n return { line: originalLine, context, artifacts: [], option: undefined };\n}\n\ninterface ImportInfo {\n module: string; // the module name without wrapping quotes: import(\"<module>\")\n alias: string; // the name of variable that keeps imported module: <alias> := import(\"<module>\")\n}\n\nfunction parseImport(line: string): ImportInfo {\n const match = importNameRE.exec(line);\n\n if (!match || !match.groups) {\n throw Error(`failed to parse 'import' statement`);\n }\n\n const { importName, moduleName } = match.groups;\n if (!importName || !moduleName) {\n throw Error(`failed to parse 'import' statement`);\n }\n\n return {\n module: moduleName, // the module name without wrapping quotes: import(\"<module>\")\n alias: importName, // the name of variable that keeps imported module: <alias> := import(\"<module>\")\n };\n}\n\nfunction parseArtifactName(\n moduleName: string,\n aType: ArtifactType,\n localPackageName: string,\n): TypedArtifactName | undefined {\n const depInfo = dependencyRE.exec(moduleName);\n if (!depInfo) {\n return;\n }\n\n if (!depInfo.groups) {\n throw Error(\n `failed to parse dependency name inside 'import' statement. The dependency name should have format '<package>:<templateName>'`,\n );\n }\n\n const { pkgName, depID } = depInfo.groups;\n if (!depID) {\n throw Error(\n `failed to parse dependency name inside 'import' statement. The dependency name should have format '<package>:<templateName>'`,\n );\n }\n\n return { type: aType, pkg: pkgName ?? localPackageName, id: depID };\n}\n\nexport function getSha256(source: string): string {\n return createHash(\"sha256\").update(source).digest(\"hex\");\n}\n"],"names":[],"mappings":";;;;;AAcA;AACA,MAAM,WAAW,GAAG,wBAAwB;AAE5C,MAAM,cAAc,GAAG,CAAC,UAAkB,EAAE,MAAc,KAAI;AAC5D,IAAA,OAAO,IAAI,MAAM,CACf,CAAA,GAAA,EAAM,UAAU,CAAA,uBAAA,CAAyB;QACvC,MAAM;QACN,CAAA,4CAAA,CAA8C,EAChD,GAAG,CACJ;AACH,CAAC;AAED,MAAM,kBAAkB,GAAG,CAAC,UAAkB,EAAE,MAAc,KAAI;AAChE,IAAA,OAAO,IAAI,MAAM,CAAC,CAAA,GAAA,EAAM,UAAU,CAAA,aAAA,CAAe,GAAG,MAAM,GAAG,CAAA,QAAA,CAAU,EAAE,GAAG,CAAC;AAC/E,CAAC;AAEM,MAAM,kBAAkB,GAAG,CAAC,UAAkB,KACnD,cAAc,CAAC,UAAU,EAAE,eAAe;AACrC,MAAM,oBAAoB,GAAG,CAAC,UAAkB,KACrD,cAAc,CAAC,UAAU,EAAE,iBAAiB;AAE9C,MAAM,mBAAmB,GAAG,CAAC,UAAkB,KAAK,cAAc,CAAC,UAAU,EAAE,gBAAgB,CAAC;AAChG,MAAM,yBAAyB,GAAG,CAAC,UAAkB,KACnD,kBAAkB,CAAC,UAAU,EAAE,gBAAgB,CAAC;AAClD,MAAM,mBAAmB,GAAG,CAAC,UAAkB,KAAK,cAAc,CAAC,UAAU,EAAE,gBAAgB,CAAC;AAChG,MAAM,yBAAyB,GAAG,CAAC,UAAkB,KACnD,kBAAkB,CAAC,UAAU,EAAE,gBAAgB,CAAC;AAClD,MAAM,gBAAgB,GAAG,CAAC,UAAkB,KAAK,cAAc,CAAC,UAAU,EAAE,aAAa,CAAC;AAC1F,MAAM,sBAAsB,GAAG,CAAC,UAAkB,KAChD,kBAAkB,CAAC,UAAU,EAAE,aAAa,CAAC;AAE/C,MAAM,WAAW,GAAG,OAAO;AAC3B,MAAM,gBAAgB,GAAG,iBAAiB;AAC1C,MAAM,qBAAqB,GAAG,uBAAuB;AACrD,MAAM,mBAAmB,GAAG,YAAY;AACxC,MAAM,6BAA6B,GAAG,oBAAoB,CAAC;AAC3D,MAAM,uBAAuB,GAAG,UAAU;AAC1C,MAAM,qBAAqB,GAAG,MAAM;AACpC,MAAM,oBAAoB,GAAG,UAAU,CAAC;AAExC;AACA;AACA,MAAM,QAAQ,GAAG,mDAAmD;AACpE,MAAM,YAAY,GAAG,IAAI,MAAM,CAC7B,CAAA,iBAAA,EAAoB,WAAW,CAAA,IAAA,EAAO,WAAW,MAAM,QAAQ,CAAC,MAAM,CAAA,CAAE,CACzE;AACD,MAAM,YAAY,GAAG,oCAAoC,CAAC;AAE1D;;;;;;;AAOG;AACH,MAAM,mBAAmB,GAAG,CAAC,GAAW,KAAoB;IAC1D,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC;IAC5B,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC;AACpC,IAAA,IAAI,QAAQ,CAAC,MAAM,IAAI,CAAC,EAAE;AACxB,QAAA,MAAM,IAAI,KAAK,CACb,0GAA0G,CAC3G;IACH;AACA,IAAA,MAAM,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC;IAE3B,OAAO;AACL,QAAA,IAAI,EAAE,OAAO;AACb,QAAA,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;KACrB;AACH,CAAC;MAEY,cAAc,CAAA;AAGP,IAAA,WAAA;AAEA,IAAA,QAAA;AAEA,IAAA,UAAA;AAEA,IAAA,GAAA;AAEA,IAAA,OAAA;AAEA,IAAA,YAAA;AAEA,IAAA,eAAA;AAdlB,IAAA,WAAA;;IAEkB,WAAwB;;IAExB,QAA0B;;IAE1B,UAAkB;;IAElB,GAAW;;IAEX,OAAe;;IAEf,YAAiC;;IAEjC,eAAiC,EAAA;QAZjC,IAAA,CAAA,WAAW,GAAX,WAAW;QAEX,IAAA,CAAA,QAAQ,GAAR,QAAQ;QAER,IAAA,CAAA,UAAU,GAAV,UAAU;QAEV,IAAA,CAAA,GAAG,GAAH,GAAG;QAEH,IAAA,CAAA,OAAO,GAAP,OAAO;QAEP,IAAA,CAAA,YAAY,GAAZ,YAAY;QAEZ,IAAA,CAAA,eAAe,GAAf,eAAe;IAC9B;AACJ;AAEK,SAAU,eAAe,CAC7B,MAAgB,EAChB,IAAiB,EACjB,OAAe,EACf,cAAgC,EAChC,SAAkB,EAAA;IAElB,MAAM,GAAG,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE;AAC5C,IAAA,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,eAAe,CAAC,MAAM,EAAE,GAAG,EAAE,cAAc,EAAE,SAAS,CAAC;IAE1F,OAAO,IAAI,cAAc,CACvB,IAAI,EACJ,cAAc,EACd,SAAS,CAAC,UAAU,CAAC,EACrB,UAAU,EACV,OAAO,EACP,IAAI,CAAC,KAAK,EACV,IAAI,CACL;AACH;AAsBA;;;;;;AAMG;AACH,SAAS,eAAe,CACtB,MAAgB,EAChB,GAAW,EACX,cAAgC,EAChC,gBAAyB,EAAA;AAMzB,IAAA,MAAM,aAAa,GAAG,qBAAqB,EAAE;IAC7C,MAAM,UAAU,GAAqB,EAAE;;IAGvC,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC;;;;;IAM7B,MAAM,cAAc,GAAa,EAAE;AACnC,IAAA,IAAI,aAAa,GAAwB;AACvC,QAAA,gBAAgB,EAAE,KAAK;AACvB,QAAA,gBAAgB,EAAE,IAAI;QACtB,iBAAiB,EAAE,IAAI,GAAG,EAAoC;QAC9D,aAAa,EAAE,IAAI,GAAG,EAAoC;AAC1D,QAAA,kBAAkB,EAAE,EAAE;AACtB,QAAA,MAAM,EAAE,CAAC;KACV;AAED,IAAA,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;QACxB,aAAa,CAAC,MAAM,EAAE;AAEtB,QAAA,IAAI;AACF,YAAA,MAAM,EACJ,IAAI,EAAE,aAAa,EACnB,OAAO,EAAE,UAAU,EACnB,SAAS,EACT,MAAM,GACP,GAAG,qBAAqB,CAAC,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,cAAc,CAAC,GAAG,EAAE,gBAAgB,CAAC;AAC5F,YAAA,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC;YAClC,aAAa,GAAG,UAAU;AAE1B,YAAA,KAAK,MAAM,QAAQ,IAAI,SAAS,IAAI,EAAE,EAAE;AACtC,gBAAA,aAAa,CAAC,GAAG,CAAC,QAAQ,CAAC;YAC7B;YACA,IAAI,MAAM,EAAE;AACV,gBAAA,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC;YACzB;QACF;QAAE,OAAO,KAAc,EAAE;YACvB,MAAM,GAAG,GAAG,KAAc;YAC1B,MAAM,IAAI,KAAK,CACb,CAAA,MAAA,EAAS,aAAa,CAAC,MAAM,CAAA,IAAA,EAAO,gBAAgB,CAAC,cAAc,CAAC,CAAA,GAAA,EAAM,GAAG,CAAC,OAAO,CAAA,IAAA,EAAO,IAAI,CAAA,CAAE,EAClG,EAAE,KAAK,EAAE,GAAG,EAAE,CACf;QACH;IACF;IAEA,OAAO;AACL,QAAA,UAAU,EAAE,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC;AACrC,QAAA,IAAI,EAAE,aAAa;AACnB,QAAA,IAAI,EAAE,UAAU;KACjB;AACH;AAkBM,SAAU,qBAAqB,CACnC,MAAgB,EAChB,IAAY,EACZ,OAA4B,EAC5B,gBAAwB,EACxB,gBAA0B,EAAA;AAE1B,IAAA,IAAI,OAAO,CAAC,gBAAgB,EAAE;AAC5B,QAAA,IAAI,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;AACpC,YAAA,OAAO,CAAC,gBAAgB,GAAG,KAAK;QAClC;AACA,QAAA,OAAO,EAAE,IAAI,EAAE,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE;IAChE;AAEA,IAAA,IAAI,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;AAC/B,QAAA,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE;YAC7B,MAAM,CAAC,KAAK,CACV,CAAA,MAAA,EAAS,OAAO,CAAC,MAAM,CAAA,kJAAA,CAAoJ,CAC5K;AACD,YAAA,MAAM,IAAI,KAAK,CACb,6EAA6E,CAC9E;QACH;AACA,QAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,mBAAmB,CAAC,IAAI,CAAC,EAAE;IAC5E;IAEA,IAAI,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,gBAAgB,EAAE;QAChE,MAAM,CAAC,IAAI,CACT,CAAA,MAAA,EAAS,OAAO,CAAC,MAAM,CAAA,yRAAA,CAA2R,CACnT;AACD,QAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE;IAC5D;AAEA,IAAA,IAAI,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,6BAA6B,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;AAC9E,QAAA,OAAO,EAAE,IAAI,EAAE,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE;IAChE;IAEA,MAAM,mBAAmB,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;IAC/C,IAAI,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE;AAC9D,QAAA,OAAO,CAAC,gBAAgB,GAAG,IAAI;AAC/B,QAAA,OAAO,EAAE,IAAI,EAAE,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE;IAChE;IAEA,MAAM,SAAS,GAAG,OAAO,CAAC,kBAAkB,GAAG,IAAI,CAAC,IAAI,EAAE;AAE1D,IAAA,MAAM,kBAAkB,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;IACrE,IAAI,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE;;;;;;;;;;;;;;;;;;;;;;;AAwB1D,QAAA,MAAM,MAAM,GAAG,kBAAkB,CAAC,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,gBAAkC,CAAC;QAC/F,OAAO,CAAC,kBAAkB,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;AACjD,QAAA,OAAO,MAAM;IACf;AAEA,IAAA,OAAO,CAAC,kBAAkB,GAAG,EAAE,CAAC;AAEhC,IAAA,IAAI,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;AAC/B,QAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE;IAC5D;;AAGA,IAAA,OAAO,CAAC,gBAAgB,GAAG,KAAK;AAEhC,IAAA,OAAO,kBAAkB,CAAC,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,gBAAkC,CAAC;AACzF;AAEA,SAAS,mBAAmB,CAC1B,iBAAkC,EAClC,YAAoB,EACpB,SAAiB,EACjB,OAA4B,EAC5B,gBAAwB,EACxB,gBAA0B,EAAA;AAE1B,IAAA,MAAM,KAAK,GAAG,WAAW,CAAC,SAAS,CAAC;;;AAKpC,IAAA,IAAI,KAAK,CAAC,MAAM,KAAK,OAAO,EAAE;AAC5B,QAAA,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;YAChD,OAAO,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE;gBAC1C,CAAC,UAAU,EAAE,kBAAkB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBAC7C,CAAC,UAAU,EAAE,oBAAoB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AAChD,aAAA,CAAC;QACJ;AACA,QAAA,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE;IAC1E;AAEA,IAAA,IACE,KAAK,CAAC,MAAM,KAAK,4BAA4B;QAC7C,KAAK,CAAC,MAAM,KAAK,kCAAkC;SAClD,CAAC,gBAAgB,KAAK,yBAAyB;YAC9C,gBAAgB,KAAK,+BAA+B;AACpD,YAAA,KAAK,CAAC,MAAM,KAAK,KAAK,CAAC,EACzB;AACA,QAAA,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;YAChD,OAAO,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE;gBAC1C,CAAC,UAAU,EAAE,mBAAmB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBAC9C,CAAC,UAAU,EAAE,mBAAmB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AAC/C,aAAA,CAAC;QACJ;IACF;AAEA,IAAA,IACE,KAAK,CAAC,MAAM,KAAK,gCAAgC;QACjD,KAAK,CAAC,MAAM,KAAK,sCAAsC;SACtD,CAAC,gBAAgB,KAAK,yBAAyB;YAC9C,gBAAgB,KAAK,+BAA+B;AACpD,YAAA,KAAK,CAAC,MAAM,KAAK,SAAS,CAAC,EAC7B;AACA,QAAA,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;YAChD,OAAO,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE;gBAC1C,CAAC,UAAU,EAAE,mBAAmB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBAC9C,CAAC,UAAU,EAAE,mBAAmB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBAC9C,CAAC,OAAO,EAAE,gBAAgB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AACzC,aAAA,CAAC;YACF,OAAO,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE;gBACtC,CAAC,UAAU,EAAE,yBAAyB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBACpD,CAAC,UAAU,EAAE,yBAAyB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBACpD,CAAC,OAAO,EAAE,sBAAsB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AAC/C,aAAA,CAAC;QACJ;IACF;AAEA,IAAA,MAAM,QAAQ,GAAG,iBAAiB,CAAC,KAAK,CAAC,MAAM,EAAE,SAAS,EAAE,gBAAgB,CAAC;IAC7E,IAAI,CAAC,QAAQ,EAAE;;AAEb,QAAA,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE;IAC1E;IAEsB;QACpB,YAAY,GAAG,YAAY,CAAC,OAAO,CACjC,iBAAiB,CAAC,CAAC,CAAC,EACpB,eAAe,QAAQ,CAAC,GAAG,CAAA,CAAA,EAAI,QAAQ,CAAC,EAAE,CAAA,EAAA,CAAI,CAC/C;IACH;AAEA,IAAA,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,QAAQ,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE;AAClF;AAEA,SAAS,kBAAkB,CACzB,YAAoB,EACpB,SAAiB,EACjB,OAA4B,EAC5B,gBAAwB,EACxB,gBAA0B,EAAA;AAE1B,IAAA,IAAI,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;AAC/B,QAAA,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE;IAC1E;;AAGA,IAAA,OAAO,CAAC,gBAAgB,GAAG,KAAK;IAEhC,MAAM,iBAAiB,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC;IAElD,IAAI,iBAAiB,EAAE;AACrB,QAAA,OAAO,mBAAmB,CACxB,iBAAiB,EACjB,YAAY,EACZ,SAAS,EACT,OAAO,EACP,gBACgB,CACjB;IACH;IAEA,IAAI,OAAO,CAAC,iBAAiB,CAAC,IAAI,GAAG,CAAC,EAAE;QACtC,KAAK,MAAM,CAAC,CAAC,EAAE,UAAU,CAAC,IAAI,OAAO,CAAC,iBAAiB,EAAE;YACvD,KAAK,MAAM,CAAC,YAAY,EAAE,EAAE,CAAC,IAAI,UAAU,EAAE;;AAE3C,gBAAA,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;AAClD,gBAAA,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;oBACxB;gBACF;gBAEA,MAAM,SAAS,GAAwB,EAAE;AACzC,gBAAA,KAAK,IAAI,CAAC,GAAG,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;AAC5C,oBAAA,MAAM,KAAK,GAAG,OAAO,CAAC,CAAC,CAAC;oBACxB,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;wBAC3B;oBACF;oBAEA,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC,MAAM;oBAErD,IAAI,CAAC,MAAM,IAAI,CAAC,YAAY,IAAI,CAAC,MAAM,EAAE;AACvC,wBAAA,MAAM,KAAK,CAAC,CAAA,yCAAA,CAA2C,CAAC;oBAC1D;oBAEA,MAAM,QAAQ,GAAG,iBAAiB,CAAC,YAAY,EAAE,YAAY,EAAE,gBAAgB,CAAC;oBAChF,IAAI,CAAC,QAAQ,EAAE;AACb,wBAAA,MAAM,KAAK,CAAC,CAAA,iCAAA,EAAoC,MAAM,CAAA,iBAAA,CAAmB,CAAC;oBAC5E;AACA,oBAAA,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;oBAEF;;AAEpB,wBAAA,YAAY,GAAG,YAAY,CAAC,UAAU,CACpC,MAAM,EACN,CAAA,EAAG,MAAM,KAAK,QAAQ,CAAC,GAAG,CAAA,CAAA,EAAI,QAAQ,CAAC,EAAE,CAAA,EAAA,CAAI,CAC9C;oBACH;gBACF;AAEA,gBAAA,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;YACtE;QACF;IACF;IAEA,IAAI,OAAO,CAAC,aAAa,CAAC,IAAI,GAAG,CAAC,EAAE;QAClC,KAAK,MAAM,CAAC,CAAC,EAAE,UAAU,CAAC,IAAI,OAAO,CAAC,aAAa,EAAE;YACnD,KAAK,MAAM,CAAC,YAAY,EAAE,EAAE,CAAC,IAAI,UAAU,EAAE;gBAC3C,MAAM,KAAK,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC;gBAChC,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;oBAC3B;gBACF;AAEA,gBAAA,MAAM,KAAK,CACT,CAAA,WAAA,EAAc,YAAY,CAAA,2IAAA,CAA6I,CACxK;YACH;QACF;IACF;AAEA,IAAA,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE;AAC1E;AAOA,SAAS,WAAW,CAAC,IAAY,EAAA;IAC/B,MAAM,KAAK,GAAG,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC;IAErC,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;AAC3B,QAAA,MAAM,KAAK,CAAC,CAAA,kCAAA,CAAoC,CAAC;IACnD;IAEA,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,KAAK,CAAC,MAAM;AAC/C,IAAA,IAAI,CAAC,UAAU,IAAI,CAAC,UAAU,EAAE;AAC9B,QAAA,MAAM,KAAK,CAAC,CAAA,kCAAA,CAAoC,CAAC;IACnD;IAEA,OAAO;QACL,MAAM,EAAE,UAAU;QAClB,KAAK,EAAE,UAAU;KAClB;AACH;AAEA,SAAS,iBAAiB,CACxB,UAAkB,EAClB,KAAmB,EACnB,gBAAwB,EAAA;IAExB,MAAM,OAAO,GAAG,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC;IAC7C,IAAI,CAAC,OAAO,EAAE;QACZ;IACF;AAEA,IAAA,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;AACnB,QAAA,MAAM,KAAK,CACT,CAAA,4HAAA,CAA8H,CAC/H;IACH;IAEA,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC,MAAM;IACzC,IAAI,CAAC,KAAK,EAAE;AACV,QAAA,MAAM,KAAK,CACT,CAAA,4HAAA,CAA8H,CAC/H;IACH;AAEA,IAAA,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,OAAO,IAAI,gBAAgB,EAAE,EAAE,EAAE,KAAK,EAAE;AACrE;AAEM,SAAU,SAAS,CAAC,MAAc,EAAA;AACtC,IAAA,OAAO,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;AAC1D;;;;"}
@@ -14,8 +14,8 @@ function newTemplateWithSource(compileMode, fullName, data, source) {
14
14
  }
15
15
  function newTemplateFromContent(compileMode, fullName, content) {
16
16
  const data = plModelBackend.parseTemplate(content);
17
- if (data.type !== 'pl.tengo-template.v3') {
18
- throw new Error('malformed v3 template');
17
+ if (data.type !== "pl.tengo-template.v3") {
18
+ throw new Error("malformed v3 template");
19
19
  }
20
20
  validateTemplateName(fullName, data);
21
21
  return {
@@ -35,11 +35,11 @@ function templateToSource(tpl) {
35
35
  }
36
36
  function validateTemplateName(fullName, data) {
37
37
  const nameFromData = _package.parseArtefactNameAndVersion(data.template);
38
- if (nameFromData.pkg !== fullName.pkg
39
- || nameFromData.id !== fullName.id
40
- || nameFromData.version !== fullName.version)
41
- throw new Error(`Compiled template name don't match it's package and file names: `
42
- + `${_package.fullNameWithoutTypeToString(nameFromData)} != ${_package.fullNameWithoutTypeToString(fullName)}`);
38
+ if (nameFromData.pkg !== fullName.pkg ||
39
+ nameFromData.id !== fullName.id ||
40
+ nameFromData.version !== fullName.version)
41
+ throw new Error(`Compiled template name don't match it's package and file names: ` +
42
+ `${_package.fullNameWithoutTypeToString(nameFromData)} != ${_package.fullNameWithoutTypeToString(fullName)}`);
43
43
  }
44
44
 
45
45
  exports.newTemplateFromContent = newTemplateFromContent;
@@ -1 +1 @@
1
- {"version":3,"file":"template.cjs","sources":["../../src/compiler/template.ts"],"sourcesContent":["import type {\n CompileMode,\n FullArtifactName,\n FullArtifactNameWithoutType,\n} from './package';\nimport {\n fullNameWithoutTypeToString,\n parseArtefactNameAndVersion,\n} from './package';\nimport type { CompiledTemplateV3 } from '@milaboratories/pl-model-backend';\nimport {\n parseTemplate,\n serializeTemplate,\n} from '@milaboratories/pl-model-backend';\n\n/** Just a holder for template data, compilation options, full name and source code.\n * It mimics ArtifactSource interface.\n */\nexport type TemplateWithSource = {\n readonly compileMode: CompileMode;\n readonly fullName: FullArtifactName;\n readonly source: string;\n readonly data: CompiledTemplateV3;\n};\n\nexport function newTemplateWithSource(\n compileMode: CompileMode,\n fullName: FullArtifactName,\n data: CompiledTemplateV3,\n source: string,\n): TemplateWithSource {\n validateTemplateName(fullName, data);\n\n return {\n compileMode,\n fullName,\n data,\n source,\n };\n}\n\nexport type Template = {\n readonly compileMode: CompileMode;\n readonly fullName: FullArtifactName;\n readonly data: CompiledTemplateV3;\n readonly content: Uint8Array;\n};\n\nexport function newTemplateFromData(\n compileMode: CompileMode,\n fullName: FullArtifactName,\n data: CompiledTemplateV3,\n): Template {\n validateTemplateName(fullName, data);\n return {\n compileMode,\n fullName,\n data,\n content: serializeTemplate(data),\n };\n}\n\nexport function newTemplateFromContent(\n compileMode: CompileMode,\n fullName: FullArtifactName,\n content: Uint8Array,\n): Template {\n const data = parseTemplate(content);\n if (data.type !== 'pl.tengo-template.v3') {\n throw new Error('malformed v3 template');\n }\n\n validateTemplateName(fullName, data);\n return {\n compileMode,\n fullName,\n data,\n content,\n };\n}\n\nexport function templateToSource(tpl: Template): TemplateWithSource {\n return {\n compileMode: tpl.compileMode,\n fullName: tpl.fullName,\n data: tpl.data,\n source: tpl.data.hashToSource[tpl.data.template.sourceHash],\n };\n}\nfunction validateTemplateName(fullName: FullArtifactName, data: CompiledTemplateV3) {\n const nameFromData: FullArtifactNameWithoutType = parseArtefactNameAndVersion(data.template);\n\n if (\n nameFromData.pkg !== fullName.pkg\n || nameFromData.id !== fullName.id\n || nameFromData.version !== fullName.version\n )\n throw new Error(\n `Compiled template name don't match it's package and file names: `\n + `${fullNameWithoutTypeToString(nameFromData)} != ${fullNameWithoutTypeToString(fullName)}`,\n );\n}\n"],"names":["parseTemplate","parseArtefactNameAndVersion","fullNameWithoutTypeToString"],"mappings":";;;;;AAyBM,SAAU,qBAAqB,CACnC,WAAwB,EACxB,QAA0B,EAC1B,IAAwB,EACxB,MAAc,EAAA;AAEd,IAAA,oBAAoB,CAAC,QAAQ,EAAE,IAAI,CAAC;IAEpC,OAAO;QACL,WAAW;QACX,QAAQ;QACR,IAAI;QACJ,MAAM;KACP;AACH;SAuBgB,sBAAsB,CACpC,WAAwB,EACxB,QAA0B,EAC1B,OAAmB,EAAA;AAEnB,IAAA,MAAM,IAAI,GAAGA,4BAAa,CAAC,OAAO,CAAC;AACnC,IAAA,IAAI,IAAI,CAAC,IAAI,KAAK,sBAAsB,EAAE;AACxC,QAAA,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC;IAC1C;AAEA,IAAA,oBAAoB,CAAC,QAAQ,EAAE,IAAI,CAAC;IACpC,OAAO;QACL,WAAW;QACX,QAAQ;QACR,IAAI;QACJ,OAAO;KACR;AACH;AAEM,SAAU,gBAAgB,CAAC,GAAa,EAAA;IAC5C,OAAO;QACL,WAAW,EAAE,GAAG,CAAC,WAAW;QAC5B,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,IAAI,EAAE,GAAG,CAAC,IAAI;AACd,QAAA,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC;KAC5D;AACH;AACA,SAAS,oBAAoB,CAAC,QAA0B,EAAE,IAAwB,EAAA;IAChF,MAAM,YAAY,GAAgCC,oCAA2B,CAAC,IAAI,CAAC,QAAQ,CAAC;AAE5F,IAAA,IACE,YAAY,CAAC,GAAG,KAAK,QAAQ,CAAC;AAC3B,WAAA,YAAY,CAAC,EAAE,KAAK,QAAQ,CAAC;AAC7B,WAAA,YAAY,CAAC,OAAO,KAAK,QAAQ,CAAC,OAAO;QAE5C,MAAM,IAAI,KAAK,CACb,CAAA,gEAAA;cACE,CAAA,EAAGC,oCAA2B,CAAC,YAAY,CAAC,CAAA,IAAA,EAAOA,oCAA2B,CAAC,QAAQ,CAAC,CAAA,CAAE,CAC7F;AACL;;;;;;"}
1
+ {"version":3,"file":"template.cjs","sources":["../../src/compiler/template.ts"],"sourcesContent":["import type { CompileMode, FullArtifactName, FullArtifactNameWithoutType } from \"./package\";\nimport { fullNameWithoutTypeToString, parseArtefactNameAndVersion } from \"./package\";\nimport type { CompiledTemplateV3 } from \"@milaboratories/pl-model-backend\";\nimport { parseTemplate, serializeTemplate } from \"@milaboratories/pl-model-backend\";\n\n/** Just a holder for template data, compilation options, full name and source code.\n * It mimics ArtifactSource interface.\n */\nexport type TemplateWithSource = {\n readonly compileMode: CompileMode;\n readonly fullName: FullArtifactName;\n readonly source: string;\n readonly data: CompiledTemplateV3;\n};\n\nexport function newTemplateWithSource(\n compileMode: CompileMode,\n fullName: FullArtifactName,\n data: CompiledTemplateV3,\n source: string,\n): TemplateWithSource {\n validateTemplateName(fullName, data);\n\n return {\n compileMode,\n fullName,\n data,\n source,\n };\n}\n\nexport type Template = {\n readonly compileMode: CompileMode;\n readonly fullName: FullArtifactName;\n readonly data: CompiledTemplateV3;\n readonly content: Uint8Array;\n};\n\nexport function newTemplateFromData(\n compileMode: CompileMode,\n fullName: FullArtifactName,\n data: CompiledTemplateV3,\n): Template {\n validateTemplateName(fullName, data);\n return {\n compileMode,\n fullName,\n data,\n content: serializeTemplate(data),\n };\n}\n\nexport function newTemplateFromContent(\n compileMode: CompileMode,\n fullName: FullArtifactName,\n content: Uint8Array,\n): Template {\n const data = parseTemplate(content);\n if (data.type !== \"pl.tengo-template.v3\") {\n throw new Error(\"malformed v3 template\");\n }\n\n validateTemplateName(fullName, data);\n return {\n compileMode,\n fullName,\n data,\n content,\n };\n}\n\nexport function templateToSource(tpl: Template): TemplateWithSource {\n return {\n compileMode: tpl.compileMode,\n fullName: tpl.fullName,\n data: tpl.data,\n source: tpl.data.hashToSource[tpl.data.template.sourceHash],\n };\n}\nfunction validateTemplateName(fullName: FullArtifactName, data: CompiledTemplateV3) {\n const nameFromData: FullArtifactNameWithoutType = parseArtefactNameAndVersion(data.template);\n\n if (\n nameFromData.pkg !== fullName.pkg ||\n nameFromData.id !== fullName.id ||\n nameFromData.version !== fullName.version\n )\n throw new Error(\n `Compiled template name don't match it's package and file names: ` +\n `${fullNameWithoutTypeToString(nameFromData)} != ${fullNameWithoutTypeToString(fullName)}`,\n );\n}\n"],"names":["parseTemplate","parseArtefactNameAndVersion","fullNameWithoutTypeToString"],"mappings":";;;;;AAeM,SAAU,qBAAqB,CACnC,WAAwB,EACxB,QAA0B,EAC1B,IAAwB,EACxB,MAAc,EAAA;AAEd,IAAA,oBAAoB,CAAC,QAAQ,EAAE,IAAI,CAAC;IAEpC,OAAO;QACL,WAAW;QACX,QAAQ;QACR,IAAI;QACJ,MAAM;KACP;AACH;SAuBgB,sBAAsB,CACpC,WAAwB,EACxB,QAA0B,EAC1B,OAAmB,EAAA;AAEnB,IAAA,MAAM,IAAI,GAAGA,4BAAa,CAAC,OAAO,CAAC;AACnC,IAAA,IAAI,IAAI,CAAC,IAAI,KAAK,sBAAsB,EAAE;AACxC,QAAA,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC;IAC1C;AAEA,IAAA,oBAAoB,CAAC,QAAQ,EAAE,IAAI,CAAC;IACpC,OAAO;QACL,WAAW;QACX,QAAQ;QACR,IAAI;QACJ,OAAO;KACR;AACH;AAEM,SAAU,gBAAgB,CAAC,GAAa,EAAA;IAC5C,OAAO;QACL,WAAW,EAAE,GAAG,CAAC,WAAW;QAC5B,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,IAAI,EAAE,GAAG,CAAC,IAAI;AACd,QAAA,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC;KAC5D;AACH;AACA,SAAS,oBAAoB,CAAC,QAA0B,EAAE,IAAwB,EAAA;IAChF,MAAM,YAAY,GAAgCC,oCAA2B,CAAC,IAAI,CAAC,QAAQ,CAAC;AAE5F,IAAA,IACE,YAAY,CAAC,GAAG,KAAK,QAAQ,CAAC,GAAG;AACjC,QAAA,YAAY,CAAC,EAAE,KAAK,QAAQ,CAAC,EAAE;AAC/B,QAAA,YAAY,CAAC,OAAO,KAAK,QAAQ,CAAC,OAAO;QAEzC,MAAM,IAAI,KAAK,CACb,CAAA,gEAAA,CAAkE;YAChE,CAAA,EAAGC,oCAA2B,CAAC,YAAY,CAAC,CAAA,IAAA,EAAOA,oCAA2B,CAAC,QAAQ,CAAC,CAAA,CAAE,CAC7F;AACL;;;;;;"}
@@ -1,5 +1,5 @@
1
- import type { CompileMode, FullArtifactName } from './package';
2
- import type { CompiledTemplateV3 } from '@milaboratories/pl-model-backend';
1
+ import type { CompileMode, FullArtifactName } from "./package";
2
+ import type { CompiledTemplateV3 } from "@milaboratories/pl-model-backend";
3
3
  /** Just a holder for template data, compilation options, full name and source code.
4
4
  * It mimics ArtifactSource interface.
5
5
  */
@@ -1 +1 @@
1
- {"version":3,"file":"template.d.ts","sourceRoot":"","sources":["../../src/compiler/template.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,WAAW,EACX,gBAAgB,EAEjB,MAAM,WAAW,CAAC;AAKnB,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AAM3E;;GAEG;AACH,MAAM,MAAM,kBAAkB,GAAG;IAC/B,QAAQ,CAAC,WAAW,EAAE,WAAW,CAAC;IAClC,QAAQ,CAAC,QAAQ,EAAE,gBAAgB,CAAC;IACpC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,IAAI,EAAE,kBAAkB,CAAC;CACnC,CAAC;AAEF,wBAAgB,qBAAqB,CACnC,WAAW,EAAE,WAAW,EACxB,QAAQ,EAAE,gBAAgB,EAC1B,IAAI,EAAE,kBAAkB,EACxB,MAAM,EAAE,MAAM,GACb,kBAAkB,CASpB;AAED,MAAM,MAAM,QAAQ,GAAG;IACrB,QAAQ,CAAC,WAAW,EAAE,WAAW,CAAC;IAClC,QAAQ,CAAC,QAAQ,EAAE,gBAAgB,CAAC;IACpC,QAAQ,CAAC,IAAI,EAAE,kBAAkB,CAAC;IAClC,QAAQ,CAAC,OAAO,EAAE,UAAU,CAAC;CAC9B,CAAC;AAEF,wBAAgB,mBAAmB,CACjC,WAAW,EAAE,WAAW,EACxB,QAAQ,EAAE,gBAAgB,EAC1B,IAAI,EAAE,kBAAkB,GACvB,QAAQ,CAQV;AAED,wBAAgB,sBAAsB,CACpC,WAAW,EAAE,WAAW,EACxB,QAAQ,EAAE,gBAAgB,EAC1B,OAAO,EAAE,UAAU,GAClB,QAAQ,CAaV;AAED,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,QAAQ,GAAG,kBAAkB,CAOlE"}
1
+ {"version":3,"file":"template.d.ts","sourceRoot":"","sources":["../../src/compiler/template.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAA+B,MAAM,WAAW,CAAC;AAE5F,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AAG3E;;GAEG;AACH,MAAM,MAAM,kBAAkB,GAAG;IAC/B,QAAQ,CAAC,WAAW,EAAE,WAAW,CAAC;IAClC,QAAQ,CAAC,QAAQ,EAAE,gBAAgB,CAAC;IACpC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,IAAI,EAAE,kBAAkB,CAAC;CACnC,CAAC;AAEF,wBAAgB,qBAAqB,CACnC,WAAW,EAAE,WAAW,EACxB,QAAQ,EAAE,gBAAgB,EAC1B,IAAI,EAAE,kBAAkB,EACxB,MAAM,EAAE,MAAM,GACb,kBAAkB,CASpB;AAED,MAAM,MAAM,QAAQ,GAAG;IACrB,QAAQ,CAAC,WAAW,EAAE,WAAW,CAAC;IAClC,QAAQ,CAAC,QAAQ,EAAE,gBAAgB,CAAC;IACpC,QAAQ,CAAC,IAAI,EAAE,kBAAkB,CAAC;IAClC,QAAQ,CAAC,OAAO,EAAE,UAAU,CAAC;CAC9B,CAAC;AAEF,wBAAgB,mBAAmB,CACjC,WAAW,EAAE,WAAW,EACxB,QAAQ,EAAE,gBAAgB,EAC1B,IAAI,EAAE,kBAAkB,GACvB,QAAQ,CAQV;AAED,wBAAgB,sBAAsB,CACpC,WAAW,EAAE,WAAW,EACxB,QAAQ,EAAE,gBAAgB,EAC1B,OAAO,EAAE,UAAU,GAClB,QAAQ,CAaV;AAED,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,QAAQ,GAAG,kBAAkB,CAOlE"}
@@ -12,8 +12,8 @@ function newTemplateWithSource(compileMode, fullName, data, source) {
12
12
  }
13
13
  function newTemplateFromContent(compileMode, fullName, content) {
14
14
  const data = parseTemplate(content);
15
- if (data.type !== 'pl.tengo-template.v3') {
16
- throw new Error('malformed v3 template');
15
+ if (data.type !== "pl.tengo-template.v3") {
16
+ throw new Error("malformed v3 template");
17
17
  }
18
18
  validateTemplateName(fullName, data);
19
19
  return {
@@ -33,11 +33,11 @@ function templateToSource(tpl) {
33
33
  }
34
34
  function validateTemplateName(fullName, data) {
35
35
  const nameFromData = parseArtefactNameAndVersion(data.template);
36
- if (nameFromData.pkg !== fullName.pkg
37
- || nameFromData.id !== fullName.id
38
- || nameFromData.version !== fullName.version)
39
- throw new Error(`Compiled template name don't match it's package and file names: `
40
- + `${fullNameWithoutTypeToString(nameFromData)} != ${fullNameWithoutTypeToString(fullName)}`);
36
+ if (nameFromData.pkg !== fullName.pkg ||
37
+ nameFromData.id !== fullName.id ||
38
+ nameFromData.version !== fullName.version)
39
+ throw new Error(`Compiled template name don't match it's package and file names: ` +
40
+ `${fullNameWithoutTypeToString(nameFromData)} != ${fullNameWithoutTypeToString(fullName)}`);
41
41
  }
42
42
 
43
43
  export { newTemplateFromContent, newTemplateWithSource, templateToSource };
@@ -1 +1 @@
1
- {"version":3,"file":"template.js","sources":["../../src/compiler/template.ts"],"sourcesContent":["import type {\n CompileMode,\n FullArtifactName,\n FullArtifactNameWithoutType,\n} from './package';\nimport {\n fullNameWithoutTypeToString,\n parseArtefactNameAndVersion,\n} from './package';\nimport type { CompiledTemplateV3 } from '@milaboratories/pl-model-backend';\nimport {\n parseTemplate,\n serializeTemplate,\n} from '@milaboratories/pl-model-backend';\n\n/** Just a holder for template data, compilation options, full name and source code.\n * It mimics ArtifactSource interface.\n */\nexport type TemplateWithSource = {\n readonly compileMode: CompileMode;\n readonly fullName: FullArtifactName;\n readonly source: string;\n readonly data: CompiledTemplateV3;\n};\n\nexport function newTemplateWithSource(\n compileMode: CompileMode,\n fullName: FullArtifactName,\n data: CompiledTemplateV3,\n source: string,\n): TemplateWithSource {\n validateTemplateName(fullName, data);\n\n return {\n compileMode,\n fullName,\n data,\n source,\n };\n}\n\nexport type Template = {\n readonly compileMode: CompileMode;\n readonly fullName: FullArtifactName;\n readonly data: CompiledTemplateV3;\n readonly content: Uint8Array;\n};\n\nexport function newTemplateFromData(\n compileMode: CompileMode,\n fullName: FullArtifactName,\n data: CompiledTemplateV3,\n): Template {\n validateTemplateName(fullName, data);\n return {\n compileMode,\n fullName,\n data,\n content: serializeTemplate(data),\n };\n}\n\nexport function newTemplateFromContent(\n compileMode: CompileMode,\n fullName: FullArtifactName,\n content: Uint8Array,\n): Template {\n const data = parseTemplate(content);\n if (data.type !== 'pl.tengo-template.v3') {\n throw new Error('malformed v3 template');\n }\n\n validateTemplateName(fullName, data);\n return {\n compileMode,\n fullName,\n data,\n content,\n };\n}\n\nexport function templateToSource(tpl: Template): TemplateWithSource {\n return {\n compileMode: tpl.compileMode,\n fullName: tpl.fullName,\n data: tpl.data,\n source: tpl.data.hashToSource[tpl.data.template.sourceHash],\n };\n}\nfunction validateTemplateName(fullName: FullArtifactName, data: CompiledTemplateV3) {\n const nameFromData: FullArtifactNameWithoutType = parseArtefactNameAndVersion(data.template);\n\n if (\n nameFromData.pkg !== fullName.pkg\n || nameFromData.id !== fullName.id\n || nameFromData.version !== fullName.version\n )\n throw new Error(\n `Compiled template name don't match it's package and file names: `\n + `${fullNameWithoutTypeToString(nameFromData)} != ${fullNameWithoutTypeToString(fullName)}`,\n );\n}\n"],"names":[],"mappings":";;;AAyBM,SAAU,qBAAqB,CACnC,WAAwB,EACxB,QAA0B,EAC1B,IAAwB,EACxB,MAAc,EAAA;AAEd,IAAA,oBAAoB,CAAC,QAAQ,EAAE,IAAI,CAAC;IAEpC,OAAO;QACL,WAAW;QACX,QAAQ;QACR,IAAI;QACJ,MAAM;KACP;AACH;SAuBgB,sBAAsB,CACpC,WAAwB,EACxB,QAA0B,EAC1B,OAAmB,EAAA;AAEnB,IAAA,MAAM,IAAI,GAAG,aAAa,CAAC,OAAO,CAAC;AACnC,IAAA,IAAI,IAAI,CAAC,IAAI,KAAK,sBAAsB,EAAE;AACxC,QAAA,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC;IAC1C;AAEA,IAAA,oBAAoB,CAAC,QAAQ,EAAE,IAAI,CAAC;IACpC,OAAO;QACL,WAAW;QACX,QAAQ;QACR,IAAI;QACJ,OAAO;KACR;AACH;AAEM,SAAU,gBAAgB,CAAC,GAAa,EAAA;IAC5C,OAAO;QACL,WAAW,EAAE,GAAG,CAAC,WAAW;QAC5B,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,IAAI,EAAE,GAAG,CAAC,IAAI;AACd,QAAA,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC;KAC5D;AACH;AACA,SAAS,oBAAoB,CAAC,QAA0B,EAAE,IAAwB,EAAA;IAChF,MAAM,YAAY,GAAgC,2BAA2B,CAAC,IAAI,CAAC,QAAQ,CAAC;AAE5F,IAAA,IACE,YAAY,CAAC,GAAG,KAAK,QAAQ,CAAC;AAC3B,WAAA,YAAY,CAAC,EAAE,KAAK,QAAQ,CAAC;AAC7B,WAAA,YAAY,CAAC,OAAO,KAAK,QAAQ,CAAC,OAAO;QAE5C,MAAM,IAAI,KAAK,CACb,CAAA,gEAAA;cACE,CAAA,EAAG,2BAA2B,CAAC,YAAY,CAAC,CAAA,IAAA,EAAO,2BAA2B,CAAC,QAAQ,CAAC,CAAA,CAAE,CAC7F;AACL;;;;"}
1
+ {"version":3,"file":"template.js","sources":["../../src/compiler/template.ts"],"sourcesContent":["import type { CompileMode, FullArtifactName, FullArtifactNameWithoutType } from \"./package\";\nimport { fullNameWithoutTypeToString, parseArtefactNameAndVersion } from \"./package\";\nimport type { CompiledTemplateV3 } from \"@milaboratories/pl-model-backend\";\nimport { parseTemplate, serializeTemplate } from \"@milaboratories/pl-model-backend\";\n\n/** Just a holder for template data, compilation options, full name and source code.\n * It mimics ArtifactSource interface.\n */\nexport type TemplateWithSource = {\n readonly compileMode: CompileMode;\n readonly fullName: FullArtifactName;\n readonly source: string;\n readonly data: CompiledTemplateV3;\n};\n\nexport function newTemplateWithSource(\n compileMode: CompileMode,\n fullName: FullArtifactName,\n data: CompiledTemplateV3,\n source: string,\n): TemplateWithSource {\n validateTemplateName(fullName, data);\n\n return {\n compileMode,\n fullName,\n data,\n source,\n };\n}\n\nexport type Template = {\n readonly compileMode: CompileMode;\n readonly fullName: FullArtifactName;\n readonly data: CompiledTemplateV3;\n readonly content: Uint8Array;\n};\n\nexport function newTemplateFromData(\n compileMode: CompileMode,\n fullName: FullArtifactName,\n data: CompiledTemplateV3,\n): Template {\n validateTemplateName(fullName, data);\n return {\n compileMode,\n fullName,\n data,\n content: serializeTemplate(data),\n };\n}\n\nexport function newTemplateFromContent(\n compileMode: CompileMode,\n fullName: FullArtifactName,\n content: Uint8Array,\n): Template {\n const data = parseTemplate(content);\n if (data.type !== \"pl.tengo-template.v3\") {\n throw new Error(\"malformed v3 template\");\n }\n\n validateTemplateName(fullName, data);\n return {\n compileMode,\n fullName,\n data,\n content,\n };\n}\n\nexport function templateToSource(tpl: Template): TemplateWithSource {\n return {\n compileMode: tpl.compileMode,\n fullName: tpl.fullName,\n data: tpl.data,\n source: tpl.data.hashToSource[tpl.data.template.sourceHash],\n };\n}\nfunction validateTemplateName(fullName: FullArtifactName, data: CompiledTemplateV3) {\n const nameFromData: FullArtifactNameWithoutType = parseArtefactNameAndVersion(data.template);\n\n if (\n nameFromData.pkg !== fullName.pkg ||\n nameFromData.id !== fullName.id ||\n nameFromData.version !== fullName.version\n )\n throw new Error(\n `Compiled template name don't match it's package and file names: ` +\n `${fullNameWithoutTypeToString(nameFromData)} != ${fullNameWithoutTypeToString(fullName)}`,\n );\n}\n"],"names":[],"mappings":";;;AAeM,SAAU,qBAAqB,CACnC,WAAwB,EACxB,QAA0B,EAC1B,IAAwB,EACxB,MAAc,EAAA;AAEd,IAAA,oBAAoB,CAAC,QAAQ,EAAE,IAAI,CAAC;IAEpC,OAAO;QACL,WAAW;QACX,QAAQ;QACR,IAAI;QACJ,MAAM;KACP;AACH;SAuBgB,sBAAsB,CACpC,WAAwB,EACxB,QAA0B,EAC1B,OAAmB,EAAA;AAEnB,IAAA,MAAM,IAAI,GAAG,aAAa,CAAC,OAAO,CAAC;AACnC,IAAA,IAAI,IAAI,CAAC,IAAI,KAAK,sBAAsB,EAAE;AACxC,QAAA,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC;IAC1C;AAEA,IAAA,oBAAoB,CAAC,QAAQ,EAAE,IAAI,CAAC;IACpC,OAAO;QACL,WAAW;QACX,QAAQ;QACR,IAAI;QACJ,OAAO;KACR;AACH;AAEM,SAAU,gBAAgB,CAAC,GAAa,EAAA;IAC5C,OAAO;QACL,WAAW,EAAE,GAAG,CAAC,WAAW;QAC5B,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,IAAI,EAAE,GAAG,CAAC,IAAI;AACd,QAAA,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC;KAC5D;AACH;AACA,SAAS,oBAAoB,CAAC,QAA0B,EAAE,IAAwB,EAAA;IAChF,MAAM,YAAY,GAAgC,2BAA2B,CAAC,IAAI,CAAC,QAAQ,CAAC;AAE5F,IAAA,IACE,YAAY,CAAC,GAAG,KAAK,QAAQ,CAAC,GAAG;AACjC,QAAA,YAAY,CAAC,EAAE,KAAK,QAAQ,CAAC,EAAE;AAC/B,QAAA,YAAY,CAAC,OAAO,KAAK,QAAQ,CAAC,OAAO;QAEzC,MAAM,IAAI,KAAK,CACb,CAAA,gEAAA,CAAkE;YAChE,CAAA,EAAG,2BAA2B,CAAC,YAAY,CAAC,CAAA,IAAA,EAAO,2BAA2B,CAAC,QAAQ,CAAC,CAAA,CAAE,CAC7F;AACL;;;;"}
@@ -1,4 +1,4 @@
1
- import type { FullArtifactName } from './package';
1
+ import type { FullArtifactName } from "./package";
2
2
  export interface TestArtifactSource {
3
3
  fullName: FullArtifactName;
4
4
  src: string;
@@ -1 +1 @@
1
- {"version":3,"file":"test.artifacts.d.ts","sourceRoot":"","sources":["../../src/compiler/test.artifacts.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAElD,MAAM,WAAW,kBAAkB;IACjC,QAAQ,EAAE,gBAAgB,CAAC;IAC3B,GAAG,EAAE,MAAM,CAAC;CACb;AA4BD,eAAO,MAAM,iBAAiB,EAAE,gBAK/B,CAAC;AACF,eAAO,MAAM,gBAAgB,8hBAgB5B,CAAC;AACF,eAAO,MAAM,0BAA0B,wjBAgBtC,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,gBAK/B,CAAC;AACF,eAAO,MAAM,gBAAgB,qfAiB5B,CAAC;AACF,eAAO,MAAM,0BAA0B,maAiBtC,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,gBAK/B,CAAC;AACF,eAAO,MAAM,gBAAgB,6CAI5B,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,gBAK/B,CAAC;AACF,eAAO,MAAM,gBAAgB,0LAM5B,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,gBAK/B,CAAC;AACF,eAAO,MAAM,gBAAgB,gDAE5B,CAAC;AACF,eAAO,MAAM,0BAA0B,gDAEtC,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,gBAK/B,CAAC;AAEF,eAAO,MAAM,gBAAgB,qIAK5B,CAAC;AAEF,eAAO,MAAM,6BAA6B,qHAKzC,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,kBAG3B,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,kBAG3B,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,kBAG3B,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,kBAG3B,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,kBAG3B,CAAC;AAEF,eAAO,MAAM,gBAAgB,sBAAgD,CAAC;AAE9E,eAAO,MAAM,oBAAoB,EAAE,gBAKlC,CAAC;AACF,eAAO,MAAM,mBAAmB,8CAI/B,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,gBAKnC,CAAC;AACF,eAAO,MAAM,oBAAoB,wEAEhC,CAAC;AAEF,eAAO,MAAM,sBAAsB,EAAE,gBAKpC,CAAC;AACF,eAAO,MAAM,qBAAqB,qEAEjC,CAAC;AAEF,eAAO,MAAM,oBAAoB,EAAE,gBAKlC,CAAC;AACF,eAAO,MAAM,mBAAmB,kJAM/B,CAAC;AAEF,eAAO,MAAM,oBAAoB,EAAE,gBAKlC,CAAC;AACF,eAAO,MAAM,mBAAmB,gDAE/B,CAAC;AAEF,eAAO,MAAM,8BAA8B,yOAC+L,CAAC;AAE3O,eAAO,MAAM,gBAAgB,EAAE,kBAG9B,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,kBAG9B,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,kBAG9B,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,kBAAkB,EAI5C,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,kBAAkB,EAAmC,CAAC;AAEjF,eAAO,MAAM,sBAAsB,EAAE,kBAAkB,EAMtD,CAAC;AAEF,eAAO,MAAM,kBAAkB,uUAU9B,CAAC;AAEF,eAAO,MAAM,yBAAyB,uVAUrC,CAAC"}
1
+ {"version":3,"file":"test.artifacts.d.ts","sourceRoot":"","sources":["../../src/compiler/test.artifacts.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAElD,MAAM,WAAW,kBAAkB;IACjC,QAAQ,EAAE,gBAAgB,CAAC;IAC3B,GAAG,EAAE,MAAM,CAAC;CACb;AA4BD,eAAO,MAAM,iBAAiB,EAAE,gBAK/B,CAAC;AACF,eAAO,MAAM,gBAAgB,8hBAgB5B,CAAC;AACF,eAAO,MAAM,0BAA0B,wjBAgBtC,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,gBAK/B,CAAC;AACF,eAAO,MAAM,gBAAgB,qfAiB5B,CAAC;AACF,eAAO,MAAM,0BAA0B,maAiBtC,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,gBAK/B,CAAC;AACF,eAAO,MAAM,gBAAgB,6CAI5B,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,gBAK/B,CAAC;AACF,eAAO,MAAM,gBAAgB,0LAM5B,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,gBAK/B,CAAC;AACF,eAAO,MAAM,gBAAgB,gDAE5B,CAAC;AACF,eAAO,MAAM,0BAA0B,gDAEtC,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,gBAK/B,CAAC;AAEF,eAAO,MAAM,gBAAgB,qIAK5B,CAAC;AAEF,eAAO,MAAM,6BAA6B,qHAKzC,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,kBAG3B,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,kBAG3B,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,kBAG3B,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,kBAG3B,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,kBAG3B,CAAC;AAEF,eAAO,MAAM,gBAAgB,sBAAgD,CAAC;AAE9E,eAAO,MAAM,oBAAoB,EAAE,gBAKlC,CAAC;AACF,eAAO,MAAM,mBAAmB,8CAI/B,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,gBAKnC,CAAC;AACF,eAAO,MAAM,oBAAoB,wEAEhC,CAAC;AAEF,eAAO,MAAM,sBAAsB,EAAE,gBAKpC,CAAC;AACF,eAAO,MAAM,qBAAqB,qEAEjC,CAAC;AAEF,eAAO,MAAM,oBAAoB,EAAE,gBAKlC,CAAC;AACF,eAAO,MAAM,mBAAmB,kJAM/B,CAAC;AAEF,eAAO,MAAM,oBAAoB,EAAE,gBAKlC,CAAC;AACF,eAAO,MAAM,mBAAmB,gDAE/B,CAAC;AAEF,eAAO,MAAM,8BAA8B,yOAC6L,CAAC;AAEzO,eAAO,MAAM,gBAAgB,EAAE,kBAG9B,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,kBAG9B,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,kBAG9B,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,kBAAkB,EAI5C,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,kBAAkB,EAAmC,CAAC;AAEjF,eAAO,MAAM,sBAAsB,EAAE,kBAAkB,EAMtD,CAAC;AAEF,eAAO,MAAM,kBAAkB,uUAU9B,CAAC;AAEF,eAAO,MAAM,yBAAyB,uVAUrC,CAAC"}
@@ -25,18 +25,18 @@ var winston__namespace = /*#__PURE__*/_interopNamespaceDefault(winston);
25
25
 
26
26
  function assertNever(x) {
27
27
  // eslint-disable-next-line @typescript-eslint/restrict-plus-operands
28
- throw new Error('Unexpected object: ' + x);
28
+ throw new Error("Unexpected object: " + x);
29
29
  }
30
- function createLogger(level = 'debug') {
30
+ function createLogger(level = "debug") {
31
31
  return winston__namespace.createLogger({
32
32
  level: level,
33
33
  format: winston__namespace.format.combine(winston__namespace.format.errors({ stack: true }), winston__namespace.format.printf(({ level, message, stack }) => {
34
- const baseMessage = `${level.padStart(6, ' ')}: ${message}`;
34
+ const baseMessage = `${level.padStart(6, " ")}: ${message}`;
35
35
  return stack ? `${baseMessage}\n${stack}` : baseMessage;
36
36
  })),
37
37
  transports: [
38
38
  new winston__namespace.transports.Console({
39
- stderrLevels: ['error', 'warn', 'info', 'debug'],
39
+ stderrLevels: ["error", "warn", "info", "debug"],
40
40
  handleExceptions: true,
41
41
  }),
42
42
  ],
@@ -46,19 +46,19 @@ function pathType(path) {
46
46
  try {
47
47
  const s = fs__namespace.statSync(path);
48
48
  if (s.isDirectory())
49
- return 'dir';
49
+ return "dir";
50
50
  if (s.isFile())
51
- return 'file';
51
+ return "file";
52
52
  if (s.isSymbolicLink())
53
- return 'link';
54
- return 'unknown';
53
+ return "link";
54
+ return "unknown";
55
55
  }
56
56
  catch (error) {
57
57
  const err = error;
58
- if (err.code == 'ENOENT')
59
- return 'absent';
60
- if (err.code == 'ENOTDIR')
61
- return 'absent';
58
+ if (err.code == "ENOENT")
59
+ return "absent";
60
+ if (err.code == "ENOTDIR")
61
+ return "absent";
62
62
  else
63
63
  throw err;
64
64
  }
@@ -1 +1 @@
1
- {"version":3,"file":"util.cjs","sources":["../../src/compiler/util.ts"],"sourcesContent":["import * as fs from 'node:fs';\nimport * as path from 'node:path';\nimport * as winston from 'winston';\n\nexport function assertNever(x: never): never {\n // eslint-disable-next-line @typescript-eslint/restrict-plus-operands\n throw new Error('Unexpected object: ' + x);\n}\n\nexport function createLogger(level: string = 'debug'): winston.Logger {\n return winston.createLogger({\n level: level,\n format: winston.format.combine(\n winston.format.errors({ stack: true }),\n winston.format.printf(({ level, message, stack }) => {\n const baseMessage = `${level.padStart(6, ' ')}: ${message as string}`;\n return stack ? `${baseMessage}\\n${stack as string}` : baseMessage;\n }),\n ),\n transports: [\n new winston.transports.Console({\n stderrLevels: ['error', 'warn', 'info', 'debug'],\n handleExceptions: true,\n }),\n ],\n });\n}\n\nexport function findNodeModules(): string {\n let currentDir = process.cwd();\n\n while (currentDir) {\n const possibleNodeModulesPath = path.join(currentDir, 'node_modules');\n\n if (fs.existsSync(possibleNodeModulesPath)) return possibleNodeModulesPath;\n\n const parentDir = path.resolve(currentDir, '..');\n if (parentDir === currentDir) break; // reached the root directory\n\n currentDir = parentDir;\n }\n\n throw new Error('Unable to find node_modules directory.');\n}\n\nexport type PathType = 'absent' | 'file' | 'dir' | 'link' | 'unknown';\n\nexport function pathType(path: string): PathType {\n try {\n const s = fs.statSync(path);\n if (s.isDirectory()) return 'dir';\n if (s.isFile()) return 'file';\n if (s.isSymbolicLink()) return 'link';\n return 'unknown';\n } catch (error: unknown) {\n const err = error as NodeJS.ErrnoException;\n if (err.code == 'ENOENT') return 'absent';\n if (err.code == 'ENOTDIR') return 'absent';\n else throw err;\n }\n}\n\nexport function isUUID(uuid: string): boolean {\n const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;\n return uuidRegex.test(uuid.toLowerCase());\n}\n"],"names":["winston","fs"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAIM,SAAU,WAAW,CAAC,CAAQ,EAAA;;AAElC,IAAA,MAAM,IAAI,KAAK,CAAC,qBAAqB,GAAG,CAAC,CAAC;AAC5C;AAEM,SAAU,YAAY,CAAC,KAAA,GAAgB,OAAO,EAAA;IAClD,OAAOA,kBAAO,CAAC,YAAY,CAAC;AAC1B,QAAA,KAAK,EAAE,KAAK;AACZ,QAAA,MAAM,EAAEA,kBAAO,CAAC,MAAM,CAAC,OAAO,CAC5BA,kBAAO,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,EACtCA,kBAAO,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,KAAI;AAClD,YAAA,MAAM,WAAW,GAAG,CAAA,EAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA,EAAA,EAAK,OAAiB,EAAE;AACrE,YAAA,OAAO,KAAK,GAAG,CAAA,EAAG,WAAW,CAAA,EAAA,EAAK,KAAe,CAAA,CAAE,GAAG,WAAW;AACnE,QAAA,CAAC,CAAC,CACH;AACD,QAAA,UAAU,EAAE;AACV,YAAA,IAAIA,kBAAO,CAAC,UAAU,CAAC,OAAO,CAAC;gBAC7B,YAAY,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC;AAChD,gBAAA,gBAAgB,EAAE,IAAI;aACvB,CAAC;AACH,SAAA;AACF,KAAA,CAAC;AACJ;AAqBM,SAAU,QAAQ,CAAC,IAAY,EAAA;AACnC,IAAA,IAAI;QACF,MAAM,CAAC,GAAGC,aAAE,CAAC,QAAQ,CAAC,IAAI,CAAC;QAC3B,IAAI,CAAC,CAAC,WAAW,EAAE;AAAE,YAAA,OAAO,KAAK;QACjC,IAAI,CAAC,CAAC,MAAM,EAAE;AAAE,YAAA,OAAO,MAAM;QAC7B,IAAI,CAAC,CAAC,cAAc,EAAE;AAAE,YAAA,OAAO,MAAM;AACrC,QAAA,OAAO,SAAS;IAClB;IAAE,OAAO,KAAc,EAAE;QACvB,MAAM,GAAG,GAAG,KAA8B;AAC1C,QAAA,IAAI,GAAG,CAAC,IAAI,IAAI,QAAQ;AAAE,YAAA,OAAO,QAAQ;AACzC,QAAA,IAAI,GAAG,CAAC,IAAI,IAAI,SAAS;AAAE,YAAA,OAAO,QAAQ;;AACrC,YAAA,MAAM,GAAG;IAChB;AACF;AAEM,SAAU,MAAM,CAAC,IAAY,EAAA;IACjC,MAAM,SAAS,GAAG,4EAA4E;IAC9F,OAAO,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;AAC3C;;;;;;;"}
1
+ {"version":3,"file":"util.cjs","sources":["../../src/compiler/util.ts"],"sourcesContent":["import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport * as winston from \"winston\";\n\nexport function assertNever(x: never): never {\n // eslint-disable-next-line @typescript-eslint/restrict-plus-operands\n throw new Error(\"Unexpected object: \" + x);\n}\n\nexport function createLogger(level: string = \"debug\"): winston.Logger {\n return winston.createLogger({\n level: level,\n format: winston.format.combine(\n winston.format.errors({ stack: true }),\n winston.format.printf(({ level, message, stack }) => {\n const baseMessage = `${level.padStart(6, \" \")}: ${message as string}`;\n return stack ? `${baseMessage}\\n${stack as string}` : baseMessage;\n }),\n ),\n transports: [\n new winston.transports.Console({\n stderrLevels: [\"error\", \"warn\", \"info\", \"debug\"],\n handleExceptions: true,\n }),\n ],\n });\n}\n\nexport function findNodeModules(): string {\n let currentDir = process.cwd();\n\n while (currentDir) {\n const possibleNodeModulesPath = path.join(currentDir, \"node_modules\");\n\n if (fs.existsSync(possibleNodeModulesPath)) return possibleNodeModulesPath;\n\n const parentDir = path.resolve(currentDir, \"..\");\n if (parentDir === currentDir) break; // reached the root directory\n\n currentDir = parentDir;\n }\n\n throw new Error(\"Unable to find node_modules directory.\");\n}\n\nexport type PathType = \"absent\" | \"file\" | \"dir\" | \"link\" | \"unknown\";\n\nexport function pathType(path: string): PathType {\n try {\n const s = fs.statSync(path);\n if (s.isDirectory()) return \"dir\";\n if (s.isFile()) return \"file\";\n if (s.isSymbolicLink()) return \"link\";\n return \"unknown\";\n } catch (error: unknown) {\n const err = error as NodeJS.ErrnoException;\n if (err.code == \"ENOENT\") return \"absent\";\n if (err.code == \"ENOTDIR\") return \"absent\";\n else throw err;\n }\n}\n\nexport function isUUID(uuid: string): boolean {\n const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;\n return uuidRegex.test(uuid.toLowerCase());\n}\n"],"names":["winston","fs"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAIM,SAAU,WAAW,CAAC,CAAQ,EAAA;;AAElC,IAAA,MAAM,IAAI,KAAK,CAAC,qBAAqB,GAAG,CAAC,CAAC;AAC5C;AAEM,SAAU,YAAY,CAAC,KAAA,GAAgB,OAAO,EAAA;IAClD,OAAOA,kBAAO,CAAC,YAAY,CAAC;AAC1B,QAAA,KAAK,EAAE,KAAK;AACZ,QAAA,MAAM,EAAEA,kBAAO,CAAC,MAAM,CAAC,OAAO,CAC5BA,kBAAO,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,EACtCA,kBAAO,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,KAAI;AAClD,YAAA,MAAM,WAAW,GAAG,CAAA,EAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA,EAAA,EAAK,OAAiB,EAAE;AACrE,YAAA,OAAO,KAAK,GAAG,CAAA,EAAG,WAAW,CAAA,EAAA,EAAK,KAAe,CAAA,CAAE,GAAG,WAAW;AACnE,QAAA,CAAC,CAAC,CACH;AACD,QAAA,UAAU,EAAE;AACV,YAAA,IAAIA,kBAAO,CAAC,UAAU,CAAC,OAAO,CAAC;gBAC7B,YAAY,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC;AAChD,gBAAA,gBAAgB,EAAE,IAAI;aACvB,CAAC;AACH,SAAA;AACF,KAAA,CAAC;AACJ;AAqBM,SAAU,QAAQ,CAAC,IAAY,EAAA;AACnC,IAAA,IAAI;QACF,MAAM,CAAC,GAAGC,aAAE,CAAC,QAAQ,CAAC,IAAI,CAAC;QAC3B,IAAI,CAAC,CAAC,WAAW,EAAE;AAAE,YAAA,OAAO,KAAK;QACjC,IAAI,CAAC,CAAC,MAAM,EAAE;AAAE,YAAA,OAAO,MAAM;QAC7B,IAAI,CAAC,CAAC,cAAc,EAAE;AAAE,YAAA,OAAO,MAAM;AACrC,QAAA,OAAO,SAAS;IAClB;IAAE,OAAO,KAAc,EAAE;QACvB,MAAM,GAAG,GAAG,KAA8B;AAC1C,QAAA,IAAI,GAAG,CAAC,IAAI,IAAI,QAAQ;AAAE,YAAA,OAAO,QAAQ;AACzC,QAAA,IAAI,GAAG,CAAC,IAAI,IAAI,SAAS;AAAE,YAAA,OAAO,QAAQ;;AACrC,YAAA,MAAM,GAAG;IAChB;AACF;AAEM,SAAU,MAAM,CAAC,IAAY,EAAA;IACjC,MAAM,SAAS,GAAG,4EAA4E;IAC9F,OAAO,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;AAC3C;;;;;;;"}
@@ -1,8 +1,8 @@
1
- import * as winston from 'winston';
1
+ import * as winston from "winston";
2
2
  export declare function assertNever(x: never): never;
3
3
  export declare function createLogger(level?: string): winston.Logger;
4
4
  export declare function findNodeModules(): string;
5
- export type PathType = 'absent' | 'file' | 'dir' | 'link' | 'unknown';
5
+ export type PathType = "absent" | "file" | "dir" | "link" | "unknown";
6
6
  export declare function pathType(path: string): PathType;
7
7
  export declare function isUUID(uuid: string): boolean;
8
8
  //# sourceMappingURL=util.d.ts.map