@nlabs/lex 1.46.2 → 1.47.1

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 (149) hide show
  1. package/__mocks__/LexConfig.js +20 -0
  2. package/__mocks__/boxen.js +7 -0
  3. package/__mocks__/build.js +16 -0
  4. package/__mocks__/chalk.js +23 -0
  5. package/__mocks__/compile.js +8 -0
  6. package/__mocks__/execa.js +21 -0
  7. package/__mocks__/ora.js +17 -0
  8. package/__mocks__/versions.js +12 -0
  9. package/dist/LexConfig.d.ts +79 -0
  10. package/dist/LexConfig.js +83 -15
  11. package/dist/commands/ai/ai.d.ts +17 -0
  12. package/dist/commands/ai/ai.js +303 -0
  13. package/dist/commands/ai/index.d.ts +8 -0
  14. package/dist/commands/ai/index.js +7 -0
  15. package/dist/commands/build/build.cli.test.d.ts +5 -0
  16. package/dist/commands/build/build.d.ts +18 -0
  17. package/dist/commands/build/build.integration.test.d.ts +1 -0
  18. package/dist/commands/build/build.js +400 -0
  19. package/dist/commands/build/build.options.test.d.ts +5 -0
  20. package/dist/commands/clean/clean.cli.test.d.ts +1 -0
  21. package/dist/commands/clean/clean.d.ts +7 -0
  22. package/dist/commands/clean/clean.integration.test.d.ts +1 -0
  23. package/dist/commands/clean/clean.js +31 -0
  24. package/dist/commands/clean/clean.options.test.d.ts +1 -0
  25. package/dist/commands/compile/compile.cli.test.d.ts +1 -0
  26. package/dist/commands/compile/compile.d.ts +2 -0
  27. package/dist/commands/compile/compile.integration.test.d.ts +1 -0
  28. package/dist/commands/compile/compile.js +239 -0
  29. package/dist/commands/compile/compile.options.test.d.ts +1 -0
  30. package/dist/commands/config/config.cli.test.d.ts +1 -0
  31. package/dist/commands/config/config.d.ts +7 -0
  32. package/dist/commands/config/config.integration.test.d.ts +1 -0
  33. package/dist/commands/config/config.js +43 -0
  34. package/dist/commands/config/config.options.test.d.ts +1 -0
  35. package/dist/commands/copy/copy.cli.test.d.ts +1 -0
  36. package/dist/commands/copy/copy.d.ts +6 -0
  37. package/dist/commands/copy/copy.integration.test.d.ts +1 -0
  38. package/dist/commands/copy/copy.js +38 -0
  39. package/dist/commands/copy/copy.options.test.d.ts +1 -0
  40. package/dist/commands/create/create.cli.test.d.ts +1 -0
  41. package/dist/commands/create/create.d.ts +8 -0
  42. package/dist/commands/create/create.integration.test.d.ts +1 -0
  43. package/dist/commands/create/create.js +124 -0
  44. package/dist/commands/create/create.options.test.d.ts +1 -0
  45. package/dist/commands/dev/dev.cli.test.d.ts +1 -0
  46. package/dist/commands/dev/dev.d.ts +11 -0
  47. package/dist/commands/dev/dev.integration.test.d.ts +1 -0
  48. package/dist/commands/dev/dev.js +70 -0
  49. package/dist/commands/dev/dev.options.test.d.ts +1 -0
  50. package/dist/commands/init/init.cli.test.d.ts +1 -0
  51. package/dist/commands/init/init.d.ts +9 -0
  52. package/dist/commands/init/init.integration.test.d.ts +1 -0
  53. package/dist/commands/init/init.js +93 -0
  54. package/dist/commands/init/init.options.test.d.ts +1 -0
  55. package/dist/commands/link/link.cli.test.d.ts +1 -0
  56. package/dist/commands/link/link.d.ts +6 -0
  57. package/dist/commands/link/link.integration.test.d.ts +1 -0
  58. package/dist/commands/link/link.js +15 -0
  59. package/dist/commands/link/link.options.test.d.ts +1 -0
  60. package/dist/commands/lint/autofix.d.ts +2 -0
  61. package/dist/commands/lint/lint.cli.test.d.ts +1 -0
  62. package/dist/commands/lint/lint.d.ts +39 -0
  63. package/dist/commands/lint/lint.integration.test.d.ts +1 -0
  64. package/dist/commands/lint/lint.js +820 -0
  65. package/dist/commands/lint/lint.options.test.d.ts +1 -0
  66. package/dist/commands/migrate/migrate.cli.test.d.ts +1 -0
  67. package/dist/commands/migrate/migrate.d.ts +7 -0
  68. package/dist/commands/migrate/migrate.integration.test.d.ts +1 -0
  69. package/dist/commands/migrate/migrate.js +37 -0
  70. package/dist/commands/migrate/migrate.options.test.d.ts +1 -0
  71. package/dist/commands/publish/publish.cli.test.d.ts +1 -0
  72. package/dist/commands/publish/publish.d.ts +12 -0
  73. package/dist/commands/publish/publish.integration.test.d.ts +1 -0
  74. package/dist/commands/publish/publish.js +104 -0
  75. package/dist/commands/publish/publish.options.test.d.ts +1 -0
  76. package/dist/commands/test/test.cli.test.d.ts +1 -0
  77. package/dist/commands/test/test.d.ts +50 -0
  78. package/dist/commands/test/test.integration.test.d.ts +1 -0
  79. package/dist/commands/test/test.js +327 -0
  80. package/dist/commands/test/test.options.test.d.ts +1 -0
  81. package/dist/commands/test/test.test.d.ts +1 -0
  82. package/dist/commands/update/update.cli.test.d.ts +1 -0
  83. package/dist/commands/update/update.d.ts +9 -0
  84. package/dist/commands/update/update.integration.test.d.ts +1 -0
  85. package/dist/commands/update/update.js +131 -0
  86. package/dist/commands/update/update.options.test.d.ts +1 -0
  87. package/dist/commands/upgrade/upgrade.cli.test.d.ts +1 -0
  88. package/dist/commands/upgrade/upgrade.d.ts +7 -0
  89. package/dist/commands/upgrade/upgrade.integration.test.d.ts +1 -0
  90. package/dist/commands/upgrade/upgrade.js +47 -0
  91. package/dist/commands/upgrade/upgrade.options.test.d.ts +1 -0
  92. package/dist/commands/versions/versions.cli.test.d.ts +1 -0
  93. package/dist/commands/versions/versions.d.ts +13 -0
  94. package/dist/commands/versions/versions.integration.test.d.ts +1 -0
  95. package/dist/commands/versions/versions.js +41 -0
  96. package/dist/commands/versions/versions.options.test.d.ts +1 -0
  97. package/dist/create/changelog.d.ts +6 -0
  98. package/dist/create/changelog.js +3 -3
  99. package/dist/index.d.ts +31 -0
  100. package/dist/index.js +35 -0
  101. package/dist/lex.d.ts +2 -0
  102. package/dist/lex.js +25 -22
  103. package/dist/types.d.ts +5 -0
  104. package/dist/types.js +1 -0
  105. package/dist/utils/aiService.d.ts +9 -0
  106. package/dist/utils/aiService.js +299 -0
  107. package/dist/utils/app.d.ts +41 -0
  108. package/dist/utils/app.js +53 -3
  109. package/dist/utils/file.d.ts +3 -0
  110. package/dist/utils/file.js +18 -3
  111. package/dist/utils/log.d.ts +1 -0
  112. package/dist/utils/log.js +2 -1
  113. package/dist/utils/reactShim.d.ts +2 -0
  114. package/dist/utils/reactShim.js +3 -3
  115. package/eslint.config.js +5 -0
  116. package/index.cjs +20 -0
  117. package/jest.config.cjs +31 -27
  118. package/jest.config.lex.d.ts +2 -0
  119. package/jest.config.lex.js +86 -38
  120. package/jest.setup.js +5 -0
  121. package/lex.config.js +50 -0
  122. package/package.json +73 -53
  123. package/{.postcssrc.js → postcss.config.js} +21 -9
  124. package/resolver.cjs +125 -14
  125. package/tsconfig.json +2 -1
  126. package/webpack.config.d.ts +2 -0
  127. package/webpack.config.js +27 -11
  128. package/dist/commands/build.js +0 -265
  129. package/dist/commands/bulid.test.js +0 -317
  130. package/dist/commands/clean.js +0 -31
  131. package/dist/commands/clean.test.js +0 -63
  132. package/dist/commands/compile.js +0 -195
  133. package/dist/commands/compile.test.js +0 -93
  134. package/dist/commands/config.js +0 -43
  135. package/dist/commands/copy.js +0 -38
  136. package/dist/commands/create.js +0 -120
  137. package/dist/commands/dev.js +0 -70
  138. package/dist/commands/init.js +0 -93
  139. package/dist/commands/link.js +0 -15
  140. package/dist/commands/lint.js +0 -179
  141. package/dist/commands/migrate.js +0 -37
  142. package/dist/commands/publish.js +0 -104
  143. package/dist/commands/test.js +0 -190
  144. package/dist/commands/update.js +0 -64
  145. package/dist/commands/upgrade.js +0 -47
  146. package/dist/commands/versions.js +0 -41
  147. package/dist/commands/versions.test.js +0 -49
  148. package/dist/lint.js +0 -11
  149. package/jest.setup.ts +0 -3
@@ -0,0 +1,400 @@
1
+ import GraphqlLoaderPlugin from "@luckycatfactory/esbuild-graphql-loader";
2
+ import { execa } from "execa";
3
+ import { readFileSync } from "fs";
4
+ import { sync as globSync } from "glob";
5
+ import { resolve as pathResolve } from "path";
6
+ import { URL } from "url";
7
+ import { LexConfig } from "../../LexConfig.js";
8
+ import { checkLinkedModules, copyConfiguredFiles, createSpinner, removeFiles } from "../../utils/app.js";
9
+ import { relativeNodePath } from "../../utils/file.js";
10
+ import { log } from "../../utils/log.js";
11
+ import { aiFunction } from "../ai/ai.js";
12
+ const buildWithEsBuild = async (spinner, commandOptions, callback) => {
13
+ const {
14
+ cliName = "Lex",
15
+ format = "cjs",
16
+ outputPath,
17
+ quiet,
18
+ sourcePath,
19
+ watch
20
+ } = commandOptions;
21
+ const {
22
+ outputFullPath,
23
+ sourceFullPath,
24
+ targetEnvironment,
25
+ useGraphQl,
26
+ useTypescript
27
+ } = LexConfig.config;
28
+ const sourceDir = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath;
29
+ const loader = {
30
+ ".js": "js"
31
+ };
32
+ if (useTypescript) {
33
+ loader[".ts"] = "ts";
34
+ loader[".tsx"] = "tsx";
35
+ }
36
+ const plugins = [];
37
+ if (useGraphQl) {
38
+ plugins.push(GraphqlLoaderPlugin());
39
+ }
40
+ const globOptions = {
41
+ cwd: sourceDir,
42
+ dot: false,
43
+ nodir: true,
44
+ nosort: true
45
+ };
46
+ const tsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test).ts*`, globOptions);
47
+ const jsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test).js`, globOptions);
48
+ const sourceFiles = [...tsFiles, ...jsFiles];
49
+ const packageJsonData = readFileSync(pathResolve(process.cwd(), "./package.json"));
50
+ const packageJson = JSON.parse(packageJsonData.toString());
51
+ const external = [
52
+ ...Object.keys(packageJson.dependencies || {}),
53
+ ...Object.keys(packageJson.peerDependencies || {})
54
+ ];
55
+ const dirName = new URL(".", import.meta.url).pathname;
56
+ const dirPath = pathResolve(dirName, "../..");
57
+ const outputDir = outputPath || outputFullPath;
58
+ const esbuildPath = relativeNodePath("esbuild/bin/esbuild", dirPath);
59
+ const esbuildConfig = LexConfig.config.esbuild || {};
60
+ const esbuildOptions = [
61
+ ...sourceFiles,
62
+ "--bundle",
63
+ "--color=true",
64
+ `--format=${format}`,
65
+ `--outdir=${outputDir}`,
66
+ `--platform=${esbuildConfig.platform || "node"}`,
67
+ `--target=${esbuildConfig.target || (targetEnvironment === "node" ? "node20" : "es2020")}`,
68
+ `--sourcemap=${esbuildConfig.sourcemap || "inline"}`
69
+ ];
70
+ if (esbuildConfig.minify !== false) {
71
+ esbuildOptions.push("--minify");
72
+ }
73
+ if (esbuildConfig.treeShaking !== false) {
74
+ esbuildOptions.push("--tree-shaking=true");
75
+ }
76
+ if (esbuildConfig.drop && esbuildConfig.drop.length > 0) {
77
+ esbuildConfig.drop.forEach((item) => {
78
+ esbuildOptions.push(`--drop:${item}`);
79
+ });
80
+ }
81
+ if (esbuildConfig.pure && esbuildConfig.pure.length > 0) {
82
+ esbuildConfig.pure.forEach((item) => {
83
+ esbuildOptions.push(`--pure:${item}`);
84
+ });
85
+ }
86
+ if (esbuildConfig.legalComments) {
87
+ esbuildOptions.push(`--legal-comments=${esbuildConfig.legalComments}`);
88
+ }
89
+ if (esbuildConfig.splitting !== false) {
90
+ esbuildOptions.push("--splitting");
91
+ }
92
+ if (esbuildConfig.metafile) {
93
+ esbuildOptions.push("--metafile");
94
+ }
95
+ if (esbuildConfig.banner) {
96
+ Object.entries(esbuildConfig.banner).forEach(([type, content]) => {
97
+ esbuildOptions.push(`--banner:${type}=${content}`);
98
+ });
99
+ }
100
+ if (esbuildConfig.footer) {
101
+ Object.entries(esbuildConfig.footer).forEach(([type, content]) => {
102
+ esbuildOptions.push(`--footer:${type}=${content}`);
103
+ });
104
+ }
105
+ if (esbuildConfig.define) {
106
+ Object.entries(esbuildConfig.define).forEach(([key, value]) => {
107
+ esbuildOptions.push(`--define:${key}=${value}`);
108
+ });
109
+ }
110
+ if (external.length) {
111
+ esbuildOptions.push(`--external:${external.join(",")}`);
112
+ }
113
+ if (plugins.length) {
114
+ esbuildOptions.push(`--plugins=${plugins.join(",")}`);
115
+ }
116
+ if (watch) {
117
+ esbuildOptions.push("--watch");
118
+ }
119
+ try {
120
+ await execa(esbuildPath, esbuildOptions, { encoding: "utf8" });
121
+ spinner.succeed("Build completed successfully!");
122
+ } catch (error) {
123
+ log(`
124
+ ${cliName} Error: ${error.message}`, "error", quiet);
125
+ if (!quiet) {
126
+ console.error(error);
127
+ }
128
+ spinner.fail("Code build failed.");
129
+ if (commandOptions.assist) {
130
+ spinner.start("AI is analyzing the error...");
131
+ try {
132
+ await aiFunction({
133
+ prompt: `Fix this esbuild error: ${error.message}
134
+
135
+ Error details:
136
+ ${error.toString()}`,
137
+ task: "help",
138
+ context: true,
139
+ quiet
140
+ });
141
+ spinner.succeed("AI analysis complete");
142
+ } catch (aiError) {
143
+ spinner.fail("Could not generate AI assistance");
144
+ if (!quiet) {
145
+ console.error("AI assistance error:", aiError);
146
+ }
147
+ }
148
+ }
149
+ callback(1);
150
+ return 1;
151
+ }
152
+ callback(0);
153
+ return 0;
154
+ };
155
+ const buildWithWebpack = async (spinner, cmd, callback) => {
156
+ const {
157
+ analyze,
158
+ cliName = "Lex",
159
+ config,
160
+ configName,
161
+ defineProcessEnvNodeEnv,
162
+ devtool,
163
+ disableInterpret,
164
+ entry,
165
+ env,
166
+ failOnWarnings,
167
+ json,
168
+ merge,
169
+ mode,
170
+ name,
171
+ nodeEnv,
172
+ noDevtool,
173
+ noStats,
174
+ noTarget,
175
+ noWatch,
176
+ noWatchOptionsStdin,
177
+ outputPath,
178
+ quiet = false,
179
+ stats,
180
+ target,
181
+ watch,
182
+ watchOptionsStdin
183
+ } = cmd;
184
+ let webpackConfig;
185
+ const dirName = new URL(".", import.meta.url).pathname;
186
+ if (config) {
187
+ const isRelativeConfig = config.substr(0, 2) === "./";
188
+ webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;
189
+ } else {
190
+ webpackConfig = pathResolve(dirName, "../../webpack.config.js");
191
+ }
192
+ const webpackOptions = [
193
+ "--color",
194
+ "--progress",
195
+ "--config",
196
+ webpackConfig
197
+ ];
198
+ if (analyze) {
199
+ webpackOptions.push("--analyze");
200
+ }
201
+ if (configName) {
202
+ webpackOptions.push("--configName", configName);
203
+ }
204
+ if (defineProcessEnvNodeEnv) {
205
+ webpackOptions.push("--defineProcessEnvNodeEnv", defineProcessEnvNodeEnv);
206
+ }
207
+ if (devtool) {
208
+ webpackOptions.push("--devtool", devtool);
209
+ }
210
+ if (disableInterpret) {
211
+ webpackOptions.push("--disableInterpret");
212
+ }
213
+ if (entry) {
214
+ webpackOptions.push("--entry", entry);
215
+ }
216
+ if (env) {
217
+ webpackOptions.push("--env", env);
218
+ }
219
+ if (failOnWarnings) {
220
+ webpackOptions.push("--failOnWarnings");
221
+ }
222
+ if (json) {
223
+ webpackOptions.push("--json", json);
224
+ }
225
+ if (mode) {
226
+ webpackOptions.push("--mode", mode);
227
+ }
228
+ if (merge) {
229
+ webpackOptions.push("--merge");
230
+ }
231
+ if (name) {
232
+ webpackOptions.push("--name", name);
233
+ }
234
+ if (noDevtool) {
235
+ webpackOptions.push("--noDevtool");
236
+ }
237
+ if (noStats) {
238
+ webpackOptions.push("--noStats");
239
+ }
240
+ if (noTarget) {
241
+ webpackOptions.push("--noTarget");
242
+ }
243
+ if (noWatch) {
244
+ webpackOptions.push("--noWatch");
245
+ }
246
+ if (noWatchOptionsStdin) {
247
+ webpackOptions.push("--noWatchOptionsStdin");
248
+ }
249
+ if (nodeEnv) {
250
+ webpackOptions.push("--nodeEnv", nodeEnv);
251
+ }
252
+ if (outputPath) {
253
+ webpackOptions.push("--outputPath", outputPath);
254
+ }
255
+ if (stats) {
256
+ webpackOptions.push("--stats", stats);
257
+ }
258
+ if (target) {
259
+ webpackOptions.push("--target", target);
260
+ }
261
+ if (watch) {
262
+ webpackOptions.push("--watch");
263
+ }
264
+ if (watchOptionsStdin) {
265
+ webpackOptions.push("--watchOptionsStdin");
266
+ }
267
+ const dirPath = pathResolve(dirName, "../..");
268
+ try {
269
+ const webpackPath = relativeNodePath("webpack-cli/bin/cli.js", dirPath);
270
+ await execa(webpackPath, webpackOptions, { encoding: "utf8", stdio: "inherit" });
271
+ spinner.succeed("Build completed successfully!");
272
+ callback(0);
273
+ return 0;
274
+ } catch (error) {
275
+ log(`
276
+ ${cliName} Error: ${error.message}`, "error", quiet);
277
+ spinner.fail("Build failed.");
278
+ if (cmd.assist) {
279
+ spinner.start("AI is analyzing the webpack error...");
280
+ try {
281
+ await aiFunction({
282
+ prompt: `Fix this webpack build error: ${error.message}
283
+
284
+ Error details:
285
+ ${error.toString()}
286
+
287
+ Configuration used:
288
+ ${JSON.stringify(webpackOptions, null, 2)}`,
289
+ task: "help",
290
+ context: true,
291
+ quiet
292
+ });
293
+ spinner.succeed("AI analysis complete");
294
+ } catch (aiError) {
295
+ spinner.fail("Could not generate AI assistance");
296
+ if (!quiet) {
297
+ console.error("AI assistance error:", aiError);
298
+ }
299
+ }
300
+ }
301
+ callback(1);
302
+ return 1;
303
+ }
304
+ };
305
+ const build = async (cmd, callback = () => ({})) => {
306
+ const {
307
+ bundler = "webpack",
308
+ cliName = "Lex",
309
+ quiet = false,
310
+ remove = false,
311
+ variables = "{}"
312
+ } = cmd;
313
+ const spinner = createSpinner(quiet);
314
+ log(`${cliName} building...`, "info", quiet);
315
+ await LexConfig.parseConfig(cmd);
316
+ const { outputFullPath, useTypescript } = LexConfig.config;
317
+ checkLinkedModules();
318
+ let variablesObj = { NODE_ENV: "production" };
319
+ if (variables) {
320
+ try {
321
+ variablesObj = JSON.parse(variables);
322
+ } catch (error) {
323
+ log(`
324
+ ${cliName} Error: Environment variables option is not a valid JSON object.`, "error", quiet);
325
+ callback(1);
326
+ return 1;
327
+ }
328
+ }
329
+ process.env = { ...process.env, ...variablesObj };
330
+ spinner.start("Building code...");
331
+ if (remove) {
332
+ await removeFiles(outputFullPath);
333
+ }
334
+ if (useTypescript) {
335
+ LexConfig.checkTypescriptConfig();
336
+ }
337
+ let buildResult = 0;
338
+ if (bundler === "esbuild") {
339
+ buildResult = await buildWithEsBuild(spinner, cmd, (status) => {
340
+ buildResult = status;
341
+ });
342
+ } else {
343
+ buildResult = await buildWithWebpack(spinner, cmd, (status) => {
344
+ buildResult = status;
345
+ });
346
+ }
347
+ if (buildResult === 0 && cmd.analyze) {
348
+ spinner.start("AI is analyzing the build output for optimization opportunities...");
349
+ try {
350
+ const stats = {
351
+ outputPath: LexConfig.config.outputFullPath,
352
+ entryPoints: bundler === "esbuild" ? `Source files: ${LexConfig.config.sourceFullPath}/**/*.{ts,js}` : LexConfig.config.webpack?.entry || "Unknown entry points"
353
+ };
354
+ await aiFunction({
355
+ prompt: `Analyze this build for optimization opportunities:
356
+
357
+ Build Type: ${bundler}
358
+ Format: ${cmd.format || "default"}
359
+ Environment: ${LexConfig.config.targetEnvironment}
360
+ ${JSON.stringify(stats, null, 2)}
361
+
362
+ What are the key optimization opportunities for this build configuration? Consider:
363
+ 1. Bundle size optimization strategies
364
+ 2. Code splitting recommendations
365
+ 3. Tree-shaking improvements
366
+ 4. Performance enhancements
367
+ 5. Dependency optimizations`,
368
+ task: "optimize",
369
+ context: true,
370
+ quiet
371
+ });
372
+ spinner.succeed("AI build analysis complete");
373
+ } catch (aiError) {
374
+ spinner.fail("Could not generate AI optimization analysis");
375
+ if (!quiet) {
376
+ console.error("AI analysis error:", aiError);
377
+ }
378
+ }
379
+ }
380
+ if (buildResult === 0) {
381
+ try {
382
+ await copyConfiguredFiles(spinner, LexConfig.config, quiet);
383
+ } catch (copyError) {
384
+ log(`
385
+ ${cliName} Error: Failed to copy configured files: ${copyError.message}`, "error", quiet);
386
+ callback(1);
387
+ return 1;
388
+ }
389
+ }
390
+ callback(buildResult);
391
+ return buildResult;
392
+ };
393
+ var build_default = build;
394
+ export {
395
+ build,
396
+ buildWithEsBuild,
397
+ buildWithWebpack,
398
+ build_default as default
399
+ };
400
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2NvbW1hbmRzL2J1aWxkL2J1aWxkLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IEdyYXBocWxMb2FkZXJQbHVnaW4gZnJvbSAnQGx1Y2t5Y2F0ZmFjdG9yeS9lc2J1aWxkLWdyYXBocWwtbG9hZGVyJztcbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcbmltcG9ydCB7cmVhZEZpbGVTeW5jfSBmcm9tICdmcyc7XG5pbXBvcnQge3N5bmMgYXMgZ2xvYlN5bmN9IGZyb20gJ2dsb2InO1xuaW1wb3J0IHtyZXNvbHZlIGFzIHBhdGhSZXNvbHZlfSBmcm9tICdwYXRoJztcbmltcG9ydCB7VVJMfSBmcm9tICd1cmwnO1xuXG5pbXBvcnQge0xleENvbmZpZ30gZnJvbSAnLi4vLi4vTGV4Q29uZmlnLmpzJztcbmltcG9ydCB7Y2hlY2tMaW5rZWRNb2R1bGVzLCBjb3B5Q29uZmlndXJlZEZpbGVzLCBjcmVhdGVTcGlubmVyLCByZW1vdmVGaWxlc30gZnJvbSAnLi4vLi4vdXRpbHMvYXBwLmpzJztcbmltcG9ydCB7cmVsYXRpdmVOb2RlUGF0aH0gZnJvbSAnLi4vLi4vdXRpbHMvZmlsZS5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vLi4vdXRpbHMvbG9nLmpzJztcbmltcG9ydCB7YWlGdW5jdGlvbn0gZnJvbSAnLi4vYWkvYWkuanMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJ1aWxkT3B0aW9ucyB7XG4gIHJlYWRvbmx5IGFzc2lzdD86IGJvb2xlYW47XG4gIHJlYWRvbmx5IGFuYWx5emU/OiBib29sZWFuO1xuICByZWFkb25seSBidW5kbGVyPzogJ3dlYnBhY2snIHwgJ2VzYnVpbGQnO1xuICByZWFkb25seSBjbGlOYW1lPzogc3RyaW5nO1xuICByZWFkb25seSBmb3JtYXQ/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IG91dHB1dFBhdGg/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHF1aWV0PzogYm9vbGVhbjtcbiAgcmVhZG9ubHkgcmVtb3ZlPzogYm9vbGVhbjtcbiAgcmVhZG9ubHkgc291cmNlUGF0aD86IHN0cmluZztcbiAgcmVhZG9ubHkgdmFyaWFibGVzPzogc3RyaW5nO1xuICByZWFkb25seSB3YXRjaD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCB0eXBlIEJ1aWxkQ2FsbGJhY2sgPSAoc3RhdHVzOiBudW1iZXIpID0+IHZvaWQ7XG5cbmV4cG9ydCBjb25zdCBidWlsZFdpdGhFc0J1aWxkID0gYXN5bmMgKHNwaW5uZXIsIGNvbW1hbmRPcHRpb25zOiBCdWlsZE9wdGlvbnMsIGNhbGxiYWNrOiBCdWlsZENhbGxiYWNrKSA9PiB7XG4gIGNvbnN0IHtcbiAgICBjbGlOYW1lID0gJ0xleCcsXG4gICAgZm9ybWF0ID0gJ2NqcycsXG4gICAgb3V0cHV0UGF0aCxcbiAgICBxdWlldCxcbiAgICBzb3VyY2VQYXRoLFxuICAgIHdhdGNoXG4gIH0gPSBjb21tYW5kT3B0aW9ucztcbiAgY29uc3Qge1xuICAgIG91dHB1dEZ1bGxQYXRoLFxuICAgIHNvdXJjZUZ1bGxQYXRoLFxuICAgIHRhcmdldEVudmlyb25tZW50LFxuICAgIHVzZUdyYXBoUWwsXG4gICAgdXNlVHlwZXNjcmlwdFxuICB9ID0gTGV4Q29uZmlnLmNvbmZpZztcbiAgY29uc3Qgc291cmNlRGlyOiBzdHJpbmcgPSBzb3VyY2VQYXRoID8gcGF0aFJlc29sdmUocHJvY2Vzcy5jd2QoKSwgYC4vJHtzb3VyY2VQYXRofWApIDogc291cmNlRnVsbFBhdGg7XG4gIGNvbnN0IGxvYWRlciA9IHtcbiAgICAnLmpzJzogJ2pzJ1xuICB9O1xuXG4gIGlmKHVzZVR5cGVzY3JpcHQpIHtcbiAgICBsb2FkZXJbJy50cyddID0gJ3RzJztcbiAgICBsb2FkZXJbJy50c3gnXSA9ICd0c3gnO1xuICB9XG5cbiAgY29uc3QgcGx1Z2lucyA9IFtdO1xuXG4gIGlmKHVzZUdyYXBoUWwpIHtcbiAgICBwbHVnaW5zLnB1c2goKEdyYXBocWxMb2FkZXJQbHVnaW4gYXMgdW5rbm93biBhcyAoKSA9PiB2b2lkKSgpKTtcbiAgfVxuXG4gIGNvbnN0IGdsb2JPcHRpb25zID0ge1xuICAgIGN3ZDogc291cmNlRGlyLFxuICAgIGRvdDogZmFsc2UsXG4gICAgbm9kaXI6IHRydWUsXG4gICAgbm9zb3J0OiB0cnVlXG4gIH07XG4gIGNvbnN0IHRzRmlsZXM6IHN0cmluZ1tdID0gZ2xvYlN5bmMoYCR7c291cmNlRGlyfS8qKi8hKCouc3BlY3wqLnRlc3QpLnRzKmAsIGdsb2JPcHRpb25zKTtcbiAgY29uc3QganNGaWxlczogc3RyaW5nW10gPSBnbG9iU3luYyhgJHtzb3VyY2VEaXJ9LyoqLyEoKi5zcGVjfCoudGVzdCkuanNgLCBnbG9iT3B0aW9ucyk7XG4gIGNvbnN0IHNvdXJjZUZpbGVzOiBzdHJpbmdbXSA9IFsuLi50c0ZpbGVzLCAuLi5qc0ZpbGVzXTtcblxuICBjb25zdCBwYWNrYWdlSnNvbkRhdGEgPSByZWFkRmlsZVN5bmMocGF0aFJlc29sdmUocHJvY2Vzcy5jd2QoKSwgJy4vcGFja2FnZS5qc29uJykpO1xuICBjb25zdCBwYWNrYWdlSnNvbiA9IEpTT04ucGFyc2UocGFja2FnZUpzb25EYXRhLnRvU3RyaW5nKCkpO1xuICBjb25zdCBleHRlcm5hbCA9IFtcbiAgICAuLi5PYmplY3Qua2V5cyhwYWNrYWdlSnNvbi5kZXBlbmRlbmNpZXMgfHwge30pLFxuICAgIC4uLk9iamVjdC5rZXlzKHBhY2thZ2VKc29uLnBlZXJEZXBlbmRlbmNpZXMgfHwge30pXG4gIF07XG5cbiAgY29uc3QgZGlyTmFtZSA9IG5ldyBVUkwoJy4nLCBpbXBvcnQubWV0YS51cmwpLnBhdGhuYW1lO1xuICBjb25zdCBkaXJQYXRoOiBzdHJpbmcgPSBwYXRoUmVzb2x2ZShkaXJOYW1lLCAnLi4vLi4nKTtcbiAgY29uc3Qgb3V0cHV0RGlyOiBzdHJpbmcgPSBvdXRwdXRQYXRoIHx8IG91dHB1dEZ1bGxQYXRoO1xuICBjb25zdCBlc2J1aWxkUGF0aDogc3RyaW5nID0gcmVsYXRpdmVOb2RlUGF0aCgnZXNidWlsZC9iaW4vZXNidWlsZCcsIGRpclBhdGgpO1xuICAvLyBHZXQgZXNidWlsZCBjb25maWd1cmF0aW9uIHdpdGggZGVmYXVsdHNcbiAgY29uc3QgZXNidWlsZENvbmZpZyA9IExleENvbmZpZy5jb25maWcuZXNidWlsZCB8fCB7fTtcblxuICBjb25zdCBlc2J1aWxkT3B0aW9uczogc3RyaW5nW10gPSBbXG4gICAgLi4uc291cmNlRmlsZXMsXG4gICAgJy0tYnVuZGxlJyxcbiAgICAnLS1jb2xvcj10cnVlJyxcbiAgICBgLS1mb3JtYXQ9JHtmb3JtYXR9YCxcbiAgICBgLS1vdXRkaXI9JHtvdXRwdXREaXJ9YCxcbiAgICBgLS1wbGF0Zm9ybT0ke2VzYnVpbGRDb25maWcucGxhdGZvcm0gfHwgJ25vZGUnfWAsXG4gICAgYC0tdGFyZ2V0PSR7ZXNidWlsZENvbmZpZy50YXJnZXQgfHwgKHRhcmdldEVudmlyb25tZW50ID09PSAnbm9kZScgPyAnbm9kZTIwJyA6ICdlczIwMjAnKX1gLFxuICAgIGAtLXNvdXJjZW1hcD0ke2VzYnVpbGRDb25maWcuc291cmNlbWFwIHx8ICdpbmxpbmUnfWBcbiAgXTtcblxuICAvLyBBcHBseSBvcHRpbWl6YXRpb24gb3B0aW9uc1xuICBpZiAoZXNidWlsZENvbmZpZy5taW5pZnkgIT09IGZhbHNlKSB7XG4gICAgZXNidWlsZE9wdGlvbnMucHVzaCgnLS1taW5pZnknKTtcbiAgfVxuXG4gIGlmIChlc2J1aWxkQ29uZmlnLnRyZWVTaGFraW5nICE9PSBmYWxzZSkge1xuICAgIGVzYnVpbGRPcHRpb25zLnB1c2goJy0tdHJlZS1zaGFraW5nPXRydWUnKTtcbiAgfVxuXG4gICAgaWYgKGVzYnVpbGRDb25maWcuZHJvcCAmJiBlc2J1aWxkQ29uZmlnLmRyb3AubGVuZ3RoID4gMCkge1xuICAgIGVzYnVpbGRDb25maWcuZHJvcC5mb3JFYWNoKGl0ZW0gPT4ge1xuICAgICAgZXNidWlsZE9wdGlvbnMucHVzaChgLS1kcm9wOiR7aXRlbX1gKTtcbiAgICB9KTtcbiAgfVxuXG4gIGlmIChlc2J1aWxkQ29uZmlnLnB1cmUgJiYgZXNidWlsZENvbmZpZy5wdXJlLmxlbmd0aCA+IDApIHtcbiAgICBlc2J1aWxkQ29uZmlnLnB1cmUuZm9yRWFjaChpdGVtID0+IHtcbiAgICAgIGVzYnVpbGRPcHRpb25zLnB1c2goYC0tcHVyZToke2l0ZW19YCk7XG4gICAgfSk7XG4gIH1cblxuICBpZiAoZXNidWlsZENvbmZpZy5sZWdhbENvbW1lbnRzKSB7XG4gICAgZXNidWlsZE9wdGlvbnMucHVzaChgLS1sZWdhbC1jb21tZW50cz0ke2VzYnVpbGRDb25maWcubGVnYWxDb21tZW50c31gKTtcbiAgfVxuXG4gIGlmIChlc2J1aWxkQ29uZmlnLnNwbGl0dGluZyAhPT0gZmFsc2UpIHtcbiAgICBlc2J1aWxkT3B0aW9ucy5wdXNoKCctLXNwbGl0dGluZycpO1xuICB9XG5cbiAgaWYgKGVzYnVpbGRDb25maWcubWV0YWZpbGUpIHtcbiAgICBlc2J1aWxkT3B0aW9ucy5wdXNoKCctLW1ldGFmaWxlJyk7XG4gIH1cblxuICBpZiAoZXNidWlsZENvbmZpZy5iYW5uZXIpIHtcbiAgICBPYmplY3QuZW50cmllcyhlc2J1aWxkQ29uZmlnLmJhbm5lcikuZm9yRWFjaCgoW3R5cGUsIGNvbnRlbnRdKSA9PiB7XG4gICAgICBlc2J1aWxkT3B0aW9ucy5wdXNoKGAtLWJhbm5lcjoke3R5cGV9PSR7Y29udGVudH1gKTtcbiAgICB9KTtcbiAgfVxuXG4gIGlmIChlc2J1aWxkQ29uZmlnLmZvb3Rlcikge1xuICAgIE9iamVjdC5lbnRyaWVzKGVzYnVpbGRDb25maWcuZm9vdGVyKS5mb3JFYWNoKChbdHlwZSwgY29udGVudF0pID0+IHtcbiAgICAgIGVzYnVpbGRPcHRpb25zLnB1c2goYC0tZm9vdGVyOiR7dHlwZX09JHtjb250ZW50fWApO1xuICAgIH0pO1xuICB9XG5cbiAgaWYgKGVzYnVpbGRDb25maWcuZGVmaW5lKSB7XG4gICAgT2JqZWN0LmVudHJpZXMoZXNidWlsZENvbmZpZy5kZWZpbmUpLmZvckVhY2goKFtrZXksIHZhbHVlXSkgPT4ge1xuICAgICAgZXNidWlsZE9wdGlvbnMucHVzaChgLS1kZWZpbmU6JHtrZXl9PSR7dmFsdWV9YCk7XG4gICAgfSk7XG4gIH1cblxuICBpZihleHRlcm5hbC5sZW5ndGgpIHtcbiAgICBlc2J1aWxkT3B0aW9ucy5wdXNoKGAtLWV4dGVybmFsOiR7ZXh0ZXJuYWwuam9pbignLCcpfWApO1xuICB9XG5cbiAgaWYocGx1Z2lucy5sZW5ndGgpIHtcbiAgICBlc2J1aWxkT3B0aW9ucy5wdXNoKGAtLXBsdWdpbnM9JHtwbHVnaW5zLmpvaW4oJywnKX1gKTtcbiAgfVxuICBpZih3YXRjaCkge1xuICAgIGVzYnVpbGRPcHRpb25zLnB1c2goJy0td2F0Y2gnKTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgYXdhaXQgZXhlY2EoZXNidWlsZFBhdGgsIGVzYnVpbGRPcHRpb25zLCB7ZW5jb2Rpbmc6ICd1dGY4J30pO1xuXG4gICAgc3Bpbm5lci5zdWNjZWVkKCdCdWlsZCBjb21wbGV0ZWQgc3VjY2Vzc2Z1bGx5IScpO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiAke2Vycm9yLm1lc3NhZ2V9YCwgJ2Vycm9yJywgcXVpZXQpO1xuXG4gICAgaWYoIXF1aWV0KSB7XG4gICAgICBjb25zb2xlLmVycm9yKGVycm9yKTtcbiAgICB9XG5cbiAgICBzcGlubmVyLmZhaWwoJ0NvZGUgYnVpbGQgZmFpbGVkLicpO1xuXG4gICAgaWYoY29tbWFuZE9wdGlvbnMuYXNzaXN0KSB7XG4gICAgICBzcGlubmVyLnN0YXJ0KCdBSSBpcyBhbmFseXppbmcgdGhlIGVycm9yLi4uJyk7XG5cbiAgICAgIHRyeSB7XG4gICAgICAgIGF3YWl0IGFpRnVuY3Rpb24oe1xuICAgICAgICAgIHByb21wdDogYEZpeCB0aGlzIGVzYnVpbGQgZXJyb3I6ICR7ZXJyb3IubWVzc2FnZX1cXG5cXG5FcnJvciBkZXRhaWxzOlxcbiR7ZXJyb3IudG9TdHJpbmcoKX1gLFxuICAgICAgICAgIHRhc2s6ICdoZWxwJyxcbiAgICAgICAgICBjb250ZXh0OiB0cnVlLFxuICAgICAgICAgIHF1aWV0XG4gICAgICAgIH0pO1xuXG4gICAgICAgIHNwaW5uZXIuc3VjY2VlZCgnQUkgYW5hbHlzaXMgY29tcGxldGUnKTtcbiAgICAgIH0gY2F0Y2goYWlFcnJvcikge1xuICAgICAgICBzcGlubmVyLmZhaWwoJ0NvdWxkIG5vdCBnZW5lcmF0ZSBBSSBhc3Npc3RhbmNlJyk7XG4gICAgICAgIGlmKCFxdWlldCkge1xuICAgICAgICAgIGNvbnNvbGUuZXJyb3IoJ0FJIGFzc2lzdGFuY2UgZXJyb3I6JywgYWlFcnJvcik7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG5cbiAgICBjYWxsYmFjaygxKTtcbiAgICByZXR1cm4gMTtcbiAgfVxuXG4gIGNhbGxiYWNrKDApO1xuICByZXR1cm4gMDtcbn07XG5cbmV4cG9ydCBjb25zdCBidWlsZFdpdGhXZWJwYWNrID0gYXN5bmMgKHNwaW5uZXIsIGNtZCwgY2FsbGJhY2spID0+IHtcbiAgY29uc3Qge1xuICAgIGFuYWx5emUsXG4gICAgY2xpTmFtZSA9ICdMZXgnLFxuICAgIGNvbmZpZyxcbiAgICBjb25maWdOYW1lLFxuICAgIGRlZmluZVByb2Nlc3NFbnZOb2RlRW52LFxuICAgIGRldnRvb2wsXG4gICAgZGlzYWJsZUludGVycHJldCxcbiAgICBlbnRyeSxcbiAgICBlbnYsXG4gICAgZmFpbE9uV2FybmluZ3MsXG4gICAganNvbixcbiAgICBtZXJnZSxcbiAgICBtb2RlLFxuICAgIG5hbWUsXG4gICAgbm9kZUVudixcbiAgICBub0RldnRvb2wsXG4gICAgbm9TdGF0cyxcbiAgICBub1RhcmdldCxcbiAgICBub1dhdGNoLFxuICAgIG5vV2F0Y2hPcHRpb25zU3RkaW4sXG4gICAgb3V0cHV0UGF0aCxcbiAgICBxdWlldCA9IGZhbHNlLFxuICAgIHN0YXRzLFxuICAgIHRhcmdldCxcbiAgICB3YXRjaCxcbiAgICB3YXRjaE9wdGlvbnNTdGRpblxuICB9ID0gY21kO1xuXG4gIGxldCB3ZWJwYWNrQ29uZmlnOiBzdHJpbmc7XG4gIGNvbnN0IGRpck5hbWUgPSBuZXcgVVJMKCcuJywgaW1wb3J0Lm1ldGEudXJsKS5wYXRobmFtZTtcblxuICBpZihjb25maWcpIHtcbiAgICBjb25zdCBpc1JlbGF0aXZlQ29uZmlnOiBib29sZWFuID0gY29uZmlnLnN1YnN0cigwLCAyKSA9PT0gJy4vJztcbiAgICB3ZWJwYWNrQ29uZmlnID0gaXNSZWxhdGl2ZUNvbmZpZyA/IHBhdGhSZXNvbHZlKHByb2Nlc3MuY3dkKCksIGNvbmZpZykgOiBjb25maWc7XG4gIH0gZWxzZSB7XG4gICAgd2VicGFja0NvbmZpZyA9IHBhdGhSZXNvbHZlKGRpck5hbWUsICcuLi8uLi93ZWJwYWNrLmNvbmZpZy5qcycpO1xuICB9XG5cbiAgY29uc3Qgd2VicGFja09wdGlvbnM6IHN0cmluZ1tdID0gW1xuICAgICctLWNvbG9yJyxcbiAgICAnLS1wcm9ncmVzcycsXG4gICAgJy0tY29uZmlnJywgd2VicGFja0NvbmZpZ1xuICBdO1xuXG4gIGlmKGFuYWx5emUpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLWFuYWx5emUnKTtcbiAgfVxuXG4gIGlmKGNvbmZpZ05hbWUpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLWNvbmZpZ05hbWUnLCBjb25maWdOYW1lKTtcbiAgfVxuXG4gIGlmKGRlZmluZVByb2Nlc3NFbnZOb2RlRW52KSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1kZWZpbmVQcm9jZXNzRW52Tm9kZUVudicsIGRlZmluZVByb2Nlc3NFbnZOb2RlRW52KTtcbiAgfVxuXG4gIGlmKGRldnRvb2wpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLWRldnRvb2wnLCBkZXZ0b29sKTtcbiAgfVxuXG4gIGlmKGRpc2FibGVJbnRlcnByZXQpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLWRpc2FibGVJbnRlcnByZXQnKTtcbiAgfVxuXG4gIGlmKGVudHJ5KSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1lbnRyeScsIGVudHJ5KTtcbiAgfVxuXG4gIGlmKGVudikge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tZW52JywgZW52KTtcbiAgfVxuXG4gIGlmKGZhaWxPbldhcm5pbmdzKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1mYWlsT25XYXJuaW5ncycpO1xuICB9XG5cbiAgaWYoanNvbikge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tanNvbicsIGpzb24pO1xuICB9XG5cbiAgaWYobW9kZSkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tbW9kZScsIG1vZGUpO1xuICB9XG5cbiAgaWYobWVyZ2UpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLW1lcmdlJyk7XG4gIH1cblxuICBpZihuYW1lKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1uYW1lJywgbmFtZSk7XG4gIH1cblxuICBpZihub0RldnRvb2wpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLW5vRGV2dG9vbCcpO1xuICB9XG5cbiAgaWYobm9TdGF0cykge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tbm9TdGF0cycpO1xuICB9XG5cbiAgaWYobm9UYXJnZXQpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLW5vVGFyZ2V0Jyk7XG4gIH1cblxuICBpZihub1dhdGNoKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1ub1dhdGNoJyk7XG4gIH1cblxuICBpZihub1dhdGNoT3B0aW9uc1N0ZGluKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1ub1dhdGNoT3B0aW9uc1N0ZGluJyk7XG4gIH1cblxuICBpZihub2RlRW52KSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1ub2RlRW52Jywgbm9kZUVudik7XG4gIH1cblxuICBpZihvdXRwdXRQYXRoKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1vdXRwdXRQYXRoJywgb3V0cHV0UGF0aCk7XG4gIH1cblxuICBpZihzdGF0cykge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tc3RhdHMnLCBzdGF0cyk7XG4gIH1cblxuICBpZih0YXJnZXQpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLXRhcmdldCcsIHRhcmdldCk7XG4gIH1cblxuICBpZih3YXRjaCkge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0td2F0Y2gnKTtcbiAgfVxuXG4gIGlmKHdhdGNoT3B0aW9uc1N0ZGluKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS13YXRjaE9wdGlvbnNTdGRpbicpO1xuICB9XG5cbiAgY29uc3QgZGlyUGF0aDogc3RyaW5nID0gcGF0aFJlc29sdmUoZGlyTmFtZSwgJy4uLy4uJyk7XG5cbiAgdHJ5IHtcbiAgICBjb25zdCB3ZWJwYWNrUGF0aDogc3RyaW5nID0gcmVsYXRpdmVOb2RlUGF0aCgnd2VicGFjay1jbGkvYmluL2NsaS5qcycsIGRpclBhdGgpO1xuICAgIGF3YWl0IGV4ZWNhKHdlYnBhY2tQYXRoLCB3ZWJwYWNrT3B0aW9ucywge2VuY29kaW5nOiAndXRmOCcsIHN0ZGlvOiAnaW5oZXJpdCd9KTtcblxuICAgIHNwaW5uZXIuc3VjY2VlZCgnQnVpbGQgY29tcGxldGVkIHN1Y2Nlc3NmdWxseSEnKTtcblxuICAgIGNhbGxiYWNrKDApO1xuICAgIHJldHVybiAwO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiAke2Vycm9yLm1lc3NhZ2V9YCwgJ2Vycm9yJywgcXVpZXQpO1xuXG4gICAgc3Bpbm5lci5mYWlsKCdCdWlsZCBmYWlsZWQuJyk7XG5cbiAgICBpZihjbWQuYXNzaXN0KSB7XG4gICAgICBzcGlubmVyLnN0YXJ0KCdBSSBpcyBhbmFseXppbmcgdGhlIHdlYnBhY2sgZXJyb3IuLi4nKTtcblxuICAgICAgdHJ5IHtcbiAgICAgICAgYXdhaXQgYWlGdW5jdGlvbih7XG4gICAgICAgICAgcHJvbXB0OiBgRml4IHRoaXMgd2VicGFjayBidWlsZCBlcnJvcjogJHtlcnJvci5tZXNzYWdlfVxcblxcbkVycm9yIGRldGFpbHM6XFxuJHtlcnJvci50b1N0cmluZygpfVxcblxcbkNvbmZpZ3VyYXRpb24gdXNlZDpcXG4ke0pTT04uc3RyaW5naWZ5KHdlYnBhY2tPcHRpb25zLCBudWxsLCAyKX1gLFxuICAgICAgICAgIHRhc2s6ICdoZWxwJyxcbiAgICAgICAgICBjb250ZXh0OiB0cnVlLFxuICAgICAgICAgIHF1aWV0XG4gICAgICAgIH0pO1xuXG4gICAgICAgIHNwaW5uZXIuc3VjY2VlZCgnQUkgYW5hbHlzaXMgY29tcGxldGUnKTtcbiAgICAgIH0gY2F0Y2goYWlFcnJvcikge1xuICAgICAgICBzcGlubmVyLmZhaWwoJ0NvdWxkIG5vdCBnZW5lcmF0ZSBBSSBhc3Npc3RhbmNlJyk7XG4gICAgICAgIGlmKCFxdWlldCkge1xuICAgICAgICAgIGNvbnNvbGUuZXJyb3IoJ0FJIGFzc2lzdGFuY2UgZXJyb3I6JywgYWlFcnJvcik7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG5cbiAgICBjYWxsYmFjaygxKTtcbiAgICByZXR1cm4gMTtcbiAgfVxufTtcblxuZXhwb3J0IGNvbnN0IGJ1aWxkID0gYXN5bmMgKGNtZDogQnVpbGRPcHRpb25zLCBjYWxsYmFjazogQnVpbGRDYWxsYmFjayA9ICgpID0+ICh7fSkpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7XG4gICAgYnVuZGxlciA9ICd3ZWJwYWNrJyxcbiAgICBjbGlOYW1lID0gJ0xleCcsXG4gICAgcXVpZXQgPSBmYWxzZSxcbiAgICByZW1vdmUgPSBmYWxzZSxcbiAgICB2YXJpYWJsZXMgPSAne30nXG4gIH0gPSBjbWQ7XG5cbiAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuXG4gIGxvZyhgJHtjbGlOYW1lfSBidWlsZGluZy4uLmAsICdpbmZvJywgcXVpZXQpO1xuXG4gIGF3YWl0IExleENvbmZpZy5wYXJzZUNvbmZpZyhjbWQpO1xuXG4gIGNvbnN0IHtvdXRwdXRGdWxsUGF0aCwgdXNlVHlwZXNjcmlwdH0gPSBMZXhDb25maWcuY29uZmlnO1xuXG4gIGNoZWNrTGlua2VkTW9kdWxlcygpO1xuXG4gIGxldCB2YXJpYWJsZXNPYmo6IG9iamVjdCA9IHtOT0RFX0VOVjogJ3Byb2R1Y3Rpb24nfTtcblxuICBpZih2YXJpYWJsZXMpIHtcbiAgICB0cnkge1xuICAgICAgdmFyaWFibGVzT2JqID0gSlNPTi5wYXJzZSh2YXJpYWJsZXMpO1xuICAgIH0gY2F0Y2goZXJyb3IpIHtcbiAgICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogRW52aXJvbm1lbnQgdmFyaWFibGVzIG9wdGlvbiBpcyBub3QgYSB2YWxpZCBKU09OIG9iamVjdC5gLCAnZXJyb3InLCBxdWlldCk7XG5cbiAgICAgIGNhbGxiYWNrKDEpO1xuICAgICAgcmV0dXJuIDE7XG4gICAgfVxuICB9XG5cbiAgcHJvY2Vzcy5lbnYgPSB7Li4ucHJvY2Vzcy5lbnYsIC4uLnZhcmlhYmxlc09ian07XG5cbiAgc3Bpbm5lci5zdGFydCgnQnVpbGRpbmcgY29kZS4uLicpO1xuXG4gIGlmKHJlbW92ZSkge1xuICAgIGF3YWl0IHJlbW92ZUZpbGVzKG91dHB1dEZ1bGxQYXRoKTtcbiAgfVxuXG4gIGlmKHVzZVR5cGVzY3JpcHQpIHtcbiAgICBMZXhDb25maWcuY2hlY2tUeXBlc2NyaXB0Q29uZmlnKCk7XG4gIH1cblxuICBsZXQgYnVpbGRSZXN1bHQgPSAwO1xuXG4gIGlmKGJ1bmRsZXIgPT09ICdlc2J1aWxkJykge1xuICAgIGJ1aWxkUmVzdWx0ID0gYXdhaXQgYnVpbGRXaXRoRXNCdWlsZChzcGlubmVyLCBjbWQsIChzdGF0dXMpID0+IHtcbiAgICAgIGJ1aWxkUmVzdWx0ID0gc3RhdHVzO1xuICAgIH0pO1xuICB9IGVsc2Uge1xuICAgIGJ1aWxkUmVzdWx0ID0gYXdhaXQgYnVpbGRXaXRoV2VicGFjayhzcGlubmVyLCBjbWQsIChzdGF0dXMpID0+IHtcbiAgICAgIGJ1aWxkUmVzdWx0ID0gc3RhdHVzO1xuICAgIH0pO1xuICB9XG5cbiAgaWYoYnVpbGRSZXN1bHQgPT09IDAgJiYgY21kLmFuYWx5emUpIHtcbiAgICBzcGlubmVyLnN0YXJ0KCdBSSBpcyBhbmFseXppbmcgdGhlIGJ1aWxkIG91dHB1dCBmb3Igb3B0aW1pemF0aW9uIG9wcG9ydHVuaXRpZXMuLi4nKTtcblxuICAgIHRyeSB7XG4gICAgICBjb25zdCBzdGF0cyA9IHtcbiAgICAgICAgb3V0cHV0UGF0aDogTGV4Q29uZmlnLmNvbmZpZy5vdXRwdXRGdWxsUGF0aCxcbiAgICAgICAgZW50cnlQb2ludHM6IGJ1bmRsZXIgPT09ICdlc2J1aWxkJyA/XG4gICAgICAgICAgYFNvdXJjZSBmaWxlczogJHtMZXhDb25maWcuY29uZmlnLnNvdXJjZUZ1bGxQYXRofS8qKi8qLnt0cyxqc31gIDpcbiAgICAgICAgICBMZXhDb25maWcuY29uZmlnLndlYnBhY2s/LmVudHJ5IHx8ICdVbmtub3duIGVudHJ5IHBvaW50cydcbiAgICAgIH07XG5cbiAgICAgIGF3YWl0IGFpRnVuY3Rpb24oe1xuICAgICAgICBwcm9tcHQ6IGBBbmFseXplIHRoaXMgYnVpbGQgZm9yIG9wdGltaXphdGlvbiBvcHBvcnR1bml0aWVzOlxuXG5CdWlsZCBUeXBlOiAke2J1bmRsZXJ9XG5Gb3JtYXQ6ICR7Y21kLmZvcm1hdCB8fCAnZGVmYXVsdCd9XG5FbnZpcm9ubWVudDogJHtMZXhDb25maWcuY29uZmlnLnRhcmdldEVudmlyb25tZW50fVxuJHtKU09OLnN0cmluZ2lmeShzdGF0cywgbnVsbCwgMil9XG5cbldoYXQgYXJlIHRoZSBrZXkgb3B0aW1pemF0aW9uIG9wcG9ydHVuaXRpZXMgZm9yIHRoaXMgYnVpbGQgY29uZmlndXJhdGlvbj8gQ29uc2lkZXI6XG4xLiBCdW5kbGUgc2l6ZSBvcHRpbWl6YXRpb24gc3RyYXRlZ2llc1xuMi4gQ29kZSBzcGxpdHRpbmcgcmVjb21tZW5kYXRpb25zXG4zLiBUcmVlLXNoYWtpbmcgaW1wcm92ZW1lbnRzXG40LiBQZXJmb3JtYW5jZSBlbmhhbmNlbWVudHNcbjUuIERlcGVuZGVuY3kgb3B0aW1pemF0aW9uc2AsXG4gICAgICAgIHRhc2s6ICdvcHRpbWl6ZScsXG4gICAgICAgIGNvbnRleHQ6IHRydWUsXG4gICAgICAgIHF1aWV0XG4gICAgICB9KTtcblxuICAgICAgc3Bpbm5lci5zdWNjZWVkKCdBSSBidWlsZCBhbmFseXNpcyBjb21wbGV0ZScpO1xuICAgIH0gY2F0Y2goYWlFcnJvcikge1xuICAgICAgc3Bpbm5lci5mYWlsKCdDb3VsZCBub3QgZ2VuZXJhdGUgQUkgb3B0aW1pemF0aW9uIGFuYWx5c2lzJyk7XG4gICAgICBpZighcXVpZXQpIHtcbiAgICAgICAgY29uc29sZS5lcnJvcignQUkgYW5hbHlzaXMgZXJyb3I6JywgYWlFcnJvcik7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgLy8gQ29weSBjb25maWd1cmVkIGZpbGVzIGFmdGVyIHN1Y2Nlc3NmdWwgYnVpbGRcbiAgaWYoYnVpbGRSZXN1bHQgPT09IDApIHtcbiAgICB0cnkge1xuICAgICAgYXdhaXQgY29weUNvbmZpZ3VyZWRGaWxlcyhzcGlubmVyLCBMZXhDb25maWcuY29uZmlnLCBxdWlldCk7XG4gICAgfSBjYXRjaChjb3B5RXJyb3IpIHtcbiAgICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogRmFpbGVkIHRvIGNvcHkgY29uZmlndXJlZCBmaWxlczogJHtjb3B5RXJyb3IubWVzc2FnZX1gLCAnZXJyb3InLCBxdWlldCk7XG4gICAgICBjYWxsYmFjaygxKTtcbiAgICAgIHJldHVybiAxO1xuICAgIH1cbiAgfVxuXG4gIGNhbGxiYWNrKGJ1aWxkUmVzdWx0KTtc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
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Test file for build CLI options coverage
3
+ * This test ensures all CLI options from lex.ts are properly handled
4
+ */
5
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,7 @@
1
+ export interface CleanOptions {
2
+ readonly cliName?: string;
3
+ readonly quiet?: boolean;
4
+ readonly snapshots?: boolean;
5
+ }
6
+ export type CleanCallback = (status: number) => void;
7
+ export declare const clean: (cmd: CleanOptions, callback?: CleanCallback) => Promise<number>;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,31 @@
1
+ import { LexConfig } from "../../LexConfig.js";
2
+ import { createSpinner, removeFiles, removeModules } from "../../utils/app.js";
3
+ import { log } from "../../utils/log.js";
4
+ const clean = async (cmd, callback = (_status) => ({})) => {
5
+ const { cliName = "Lex", quiet, snapshots } = cmd;
6
+ const spinner = createSpinner(quiet);
7
+ log(`${cliName} cleaning directory...`, "info", quiet);
8
+ await LexConfig.parseConfig(cmd);
9
+ spinner.start("Cleaning files...");
10
+ try {
11
+ await removeModules();
12
+ await removeFiles("./coverage", true);
13
+ await removeFiles("./npm-debug.log", true);
14
+ if (snapshots) {
15
+ await removeFiles("./**/__snapshots__", true);
16
+ }
17
+ spinner.succeed("Successfully cleaned!");
18
+ callback(0);
19
+ return 0;
20
+ } catch (error) {
21
+ log(`
22
+ ${cliName} Error: ${error.message}`, "error", quiet);
23
+ spinner.fail("Failed to clean project.");
24
+ callback(1);
25
+ return 1;
26
+ }
27
+ };
28
+ export {
29
+ clean
30
+ };
31
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2NvbW1hbmRzL2NsZWFuL2NsZWFuLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uLy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXIsIHJlbW92ZUZpbGVzLCByZW1vdmVNb2R1bGVzfSBmcm9tICcuLi8uLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uLy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2xlYW5PcHRpb25zIHtcbiAgcmVhZG9ubHkgY2xpTmFtZT86IHN0cmluZztcbiAgcmVhZG9ubHkgcXVpZXQ/OiBib29sZWFuO1xuICByZWFkb25seSBzbmFwc2hvdHM/OiBib29sZWFuO1xufVxuXG5leHBvcnQgdHlwZSBDbGVhbkNhbGxiYWNrID0gKHN0YXR1czogbnVtYmVyKSA9PiB2b2lkO1xuXG5leHBvcnQgY29uc3QgY2xlYW4gPSBhc3luYyAoY21kOiBDbGVhbk9wdGlvbnMsIGNhbGxiYWNrOiBDbGVhbkNhbGxiYWNrID0gKF9zdGF0dXM6IG51bWJlcikgPT4gKHt9KSk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGNvbnN0IHtjbGlOYW1lID0gJ0xleCcsIHF1aWV0LCBzbmFwc2hvdHN9ID0gY21kO1xuXG4gIC8vIFNwaW5uZXJcbiAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuXG4gIC8vIERpc3BsYXkgc3RhdHVzXG4gIGxvZyhgJHtjbGlOYW1lfSBjbGVhbmluZyBkaXJlY3RvcnkuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBHZXQgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAgYXdhaXQgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgLy8gU3RhcnQgY2xlYW5pbmcgc3Bpbm5lclxuICBzcGlubmVyLnN0YXJ0KCdDbGVhbmluZyBmaWxlcy4uLicpO1xuXG4gIHRyeSB7XG4gICAgLy8gUmVtb3ZlIG5vZGVfbW9kdWxlc1xuICAgIGF3YWl0IHJlbW92ZU1vZHVsZXMoKTtcblxuICAgIC8vIFJlbW92ZSB0ZXN0IGNvdmVyYWdlIHJlcG9ydHNcbiAgICBhd2FpdCByZW1vdmVGaWxlcygnLi9jb3ZlcmFnZScsIHRydWUpO1xuXG4gICAgLy8gUmVtb3ZlIG5wbSBsb2dzXG4gICAgYXdhaXQgcmVtb3ZlRmlsZXMoJy4vbnBtLWRlYnVnLmxvZycsIHRydWUpO1xuXG4gICAgaWYoc25hcHNob3RzKSB7XG4gICAgICBhd2FpdCByZW1vdmVGaWxlcygnLi8qKi9fX3NuYXBzaG90c19fJywgdHJ1ZSk7XG4gICAgfVxuXG4gICAgLy8gU3RvcCBzcGlubmVyXG4gICAgc3Bpbm5lci5zdWNjZWVkKCdTdWNjZXNzZnVsbHkgY2xlYW5lZCEnKTtcblxuICAgIC8vIFN0b3AgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKDApO1xuICAgIHJldHVybiAwO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgLy8gRGlzcGxheSBlcnJvciBtZXNzYWdlXG4gICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiAke2Vycm9yLm1lc3NhZ2V9YCwgJ2Vycm9yJywgcXVpZXQpO1xuXG4gICAgLy8gU3RvcCBzcGlubmVyXG4gICAgc3Bpbm5lci5mYWlsKCdGYWlsZWQgdG8gY2xlYW4gcHJvamVjdC4nKTtcblxuICAgIC8vIEtpbGwgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKDEpO1xuICAgIHJldHVybiAxO1xuICB9XG59OyJdLAogICJtYXBwaW5ncyI6ICJBQUlBLFNBQVEsaUJBQWdCO0FBQ3hCLFNBQVEsZUFBZSxhQUFhLHFCQUFvQjtBQUN4RCxTQUFRLFdBQVU7QUFVWCxNQUFNLFFBQVEsT0FBTyxLQUFtQixXQUEwQixDQUFDLGFBQXFCLENBQUMsT0FBd0I7QUFDdEgsUUFBTSxFQUFDLFVBQVUsT0FBTyxPQUFPLFVBQVMsSUFBSTtBQUc1QyxRQUFNLFVBQVUsY0FBYyxLQUFLO0FBR25DLE1BQUksR0FBRyxPQUFPLDBCQUEwQixRQUFRLEtBQUs7QUFHckQsUUFBTSxVQUFVLFlBQVksR0FBRztBQUcvQixVQUFRLE1BQU0sbUJBQW1CO0FBRWpDLE1BQUk7QUFFRixVQUFNLGNBQWM7QUFHcEIsVUFBTSxZQUFZLGNBQWMsSUFBSTtBQUdwQyxVQUFNLFlBQVksbUJBQW1CLElBQUk7QUFFekMsUUFBRyxXQUFXO0FBQ1osWUFBTSxZQUFZLHNCQUFzQixJQUFJO0FBQUEsSUFDOUM7QUFHQSxZQUFRLFFBQVEsdUJBQXVCO0FBR3ZDLGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNULFNBQVEsT0FBTztBQUViLFFBQUk7QUFBQSxFQUFLLE9BQU8sV0FBVyxNQUFNLE9BQU8sSUFBSSxTQUFTLEtBQUs7QUFHMUQsWUFBUSxLQUFLLDBCQUEwQjtBQUd2QyxhQUFTLENBQUM7QUFDVixXQUFPO0FBQUEsRUFDVDtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,2 @@
1
+ export declare const hasFileType: (startPath: string, ext: string[]) => boolean;
2
+ export declare const compile: (cmd: any, callback?: any) => Promise<number>;