@powerlines/plugin-nodejs 0.1.7 → 0.1.9

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 (127) hide show
  1. package/dist/components/env.cjs +14 -14
  2. package/dist/components/env.mjs +6 -6
  3. package/dist/index.cjs +8 -6
  4. package/dist/index.mjs +5 -5
  5. package/dist/plugin-alloy/src/types/components.d.mts +1 -2
  6. package/dist/plugin-alloy/src/typescript/components/typescript-file.d.mts +1 -1
  7. package/dist/plugin-alloy/src/typescript/components/typescript-interface.d.mts +2 -2
  8. package/dist/plugin-automd/src/types/plugin.d.mts +1 -3
  9. package/dist/plugin-env/src/types/plugin.d.mts +1 -2
  10. package/dist/powerlines/src/internal/helpers/hooks.d.mts +0 -2
  11. package/dist/powerlines/src/types/build.d.mts +6 -6
  12. package/dist/powerlines/src/types/commands.d.mts +0 -1
  13. package/dist/powerlines/src/types/config.d.mts +2 -3
  14. package/dist/powerlines/src/types/tsconfig.d.mts +1 -1
  15. package/dist/powerlines/src/types/unplugin.d.mts +0 -1
  16. package/package.json +11 -9
  17. package/dist/deepkit/schemas/reflection.cjs +0 -3940
  18. package/dist/deepkit/schemas/reflection.mjs +0 -3938
  19. package/dist/deepkit/schemas/reflection2.cjs +0 -4112
  20. package/dist/deepkit/schemas/reflection2.mjs +0 -4110
  21. package/dist/deepkit/src/capnp.cjs +0 -913
  22. package/dist/deepkit/src/capnp.mjs +0 -911
  23. package/dist/deepkit/src/esbuild-plugin.cjs +0 -47
  24. package/dist/deepkit/src/esbuild-plugin.mjs +0 -46
  25. package/dist/deepkit/src/reflect-type.cjs +0 -22
  26. package/dist/deepkit/src/reflect-type.mjs +0 -20
  27. package/dist/deepkit/src/resolve-reflections.cjs +0 -16
  28. package/dist/deepkit/src/resolve-reflections.mjs +0 -15
  29. package/dist/deepkit/src/transformer.cjs +0 -52
  30. package/dist/deepkit/src/transformer.mjs +0 -49
  31. package/dist/deepkit/src/transpile.cjs +0 -29
  32. package/dist/deepkit/src/transpile.mjs +0 -27
  33. package/dist/deepkit/src/utilities.cjs +0 -66
  34. package/dist/deepkit/src/utilities.mjs +0 -65
  35. package/dist/plugin-alloy/src/core/components/output.cjs +0 -45
  36. package/dist/plugin-alloy/src/core/components/output.mjs +0 -44
  37. package/dist/plugin-alloy/src/core/components/single-line-comment.cjs +0 -22
  38. package/dist/plugin-alloy/src/core/components/single-line-comment.mjs +0 -21
  39. package/dist/plugin-alloy/src/core/components/source-file.cjs +0 -64
  40. package/dist/plugin-alloy/src/core/components/source-file.mjs +0 -62
  41. package/dist/plugin-alloy/src/core/contexts/context.cjs +0 -60
  42. package/dist/plugin-alloy/src/core/contexts/context.mjs +0 -54
  43. package/dist/plugin-alloy/src/core/contexts/index.cjs +0 -2
  44. package/dist/plugin-alloy/src/core/contexts/index.mjs +0 -4
  45. package/dist/plugin-alloy/src/core/contexts/reflection.cjs +0 -46
  46. package/dist/plugin-alloy/src/core/contexts/reflection.mjs +0 -42
  47. package/dist/plugin-alloy/src/helpers/refkey.cjs +0 -16
  48. package/dist/plugin-alloy/src/helpers/refkey.mjs +0 -15
  49. package/dist/plugin-alloy/src/index.cjs +0 -106
  50. package/dist/plugin-alloy/src/index.mjs +0 -104
  51. package/dist/plugin-alloy/src/markdown/components/markdown-file.cjs +0 -7
  52. package/dist/plugin-alloy/src/markdown/components/markdown-file.mjs +0 -9
  53. package/dist/plugin-alloy/src/markdown/components/markdown-table.cjs +0 -5
  54. package/dist/plugin-alloy/src/markdown/components/markdown-table.mjs +0 -7
  55. package/dist/plugin-alloy/src/markdown/contexts/markdown-table.cjs +0 -17
  56. package/dist/plugin-alloy/src/markdown/contexts/markdown-table.mjs +0 -17
  57. package/dist/plugin-alloy/src/typescript/components/builtin-file.cjs +0 -57
  58. package/dist/plugin-alloy/src/typescript/components/builtin-file.mjs +0 -56
  59. package/dist/plugin-alloy/src/typescript/components/tsdoc-reflection.cjs +0 -126
  60. package/dist/plugin-alloy/src/typescript/components/tsdoc-reflection.mjs +0 -124
  61. package/dist/plugin-alloy/src/typescript/components/tsdoc.cjs +0 -442
  62. package/dist/plugin-alloy/src/typescript/components/tsdoc.mjs +0 -433
  63. package/dist/plugin-alloy/src/typescript/components/typescript-file.cjs +0 -212
  64. package/dist/plugin-alloy/src/typescript/components/typescript-file.mjs +0 -209
  65. package/dist/plugin-alloy/src/typescript/components/typescript-interface.cjs +0 -68
  66. package/dist/plugin-alloy/src/typescript/components/typescript-interface.mjs +0 -67
  67. package/dist/plugin-alloy/src/typescript/components/typescript-object.cjs +0 -124
  68. package/dist/plugin-alloy/src/typescript/components/typescript-object.mjs +0 -123
  69. package/dist/plugin-automd/src/index.cjs +0 -101
  70. package/dist/plugin-automd/src/index.mjs +0 -98
  71. package/dist/plugin-babel/src/helpers/ast-utils.cjs +0 -10
  72. package/dist/plugin-babel/src/helpers/ast-utils.mjs +0 -9
  73. package/dist/plugin-babel/src/helpers/create-plugin.cjs +0 -41
  74. package/dist/plugin-babel/src/helpers/create-plugin.mjs +0 -39
  75. package/dist/plugin-babel/src/helpers/filters.cjs +0 -23
  76. package/dist/plugin-babel/src/helpers/filters.mjs +0 -21
  77. package/dist/plugin-babel/src/helpers/index.cjs +0 -5
  78. package/dist/plugin-babel/src/helpers/index.mjs +0 -7
  79. package/dist/plugin-babel/src/helpers/module-helpers.cjs +0 -38
  80. package/dist/plugin-babel/src/helpers/module-helpers.mjs +0 -35
  81. package/dist/plugin-babel/src/helpers/options.cjs +0 -50
  82. package/dist/plugin-babel/src/helpers/options.mjs +0 -47
  83. package/dist/plugin-babel/src/index.cjs +0 -91
  84. package/dist/plugin-babel/src/index.mjs +0 -89
  85. package/dist/plugin-babel/src/types/index.d.mts +0 -1
  86. package/dist/plugin-env/src/babel/index.cjs +0 -1
  87. package/dist/plugin-env/src/babel/index.mjs +0 -3
  88. package/dist/plugin-env/src/babel/plugin.cjs +0 -121
  89. package/dist/plugin-env/src/babel/plugin.mjs +0 -119
  90. package/dist/plugin-env/src/components/docs.cjs +0 -9
  91. package/dist/plugin-env/src/components/docs.mjs +0 -11
  92. package/dist/plugin-env/src/components/env.cjs +0 -575
  93. package/dist/plugin-env/src/components/env.mjs +0 -572
  94. package/dist/plugin-env/src/components/index.cjs +0 -2
  95. package/dist/plugin-env/src/components/index.mjs +0 -4
  96. package/dist/plugin-env/src/helpers/automd-generator.cjs +0 -22
  97. package/dist/plugin-env/src/helpers/automd-generator.mjs +0 -21
  98. package/dist/plugin-env/src/helpers/create-reflection-resource.cjs +0 -55
  99. package/dist/plugin-env/src/helpers/create-reflection-resource.mjs +0 -54
  100. package/dist/plugin-env/src/helpers/index.cjs +0 -6
  101. package/dist/plugin-env/src/helpers/index.mjs +0 -8
  102. package/dist/plugin-env/src/helpers/load.cjs +0 -83
  103. package/dist/plugin-env/src/helpers/load.mjs +0 -80
  104. package/dist/plugin-env/src/helpers/persistence.cjs +0 -201
  105. package/dist/plugin-env/src/helpers/persistence.mjs +0 -190
  106. package/dist/plugin-env/src/helpers/reflect.cjs +0 -111
  107. package/dist/plugin-env/src/helpers/reflect.mjs +0 -103
  108. package/dist/plugin-env/src/helpers/source-file-env.cjs +0 -24
  109. package/dist/plugin-env/src/helpers/source-file-env.mjs +0 -23
  110. package/dist/plugin-env/src/helpers/template-helpers.cjs +0 -2
  111. package/dist/plugin-env/src/helpers/template-helpers.mjs +0 -4
  112. package/dist/plugin-env/src/index.cjs +0 -175
  113. package/dist/plugin-env/src/index.mjs +0 -173
  114. package/dist/powerlines/src/lib/build/esbuild.cjs +0 -102
  115. package/dist/powerlines/src/lib/build/esbuild.mjs +0 -100
  116. package/dist/powerlines/src/lib/entry.cjs +0 -12
  117. package/dist/powerlines/src/lib/entry.mjs +0 -14
  118. package/dist/powerlines/src/lib/logger.cjs +0 -41
  119. package/dist/powerlines/src/lib/logger.mjs +0 -39
  120. package/dist/powerlines/src/lib/typescript/tsconfig.cjs +0 -38
  121. package/dist/powerlines/src/lib/typescript/tsconfig.mjs +0 -35
  122. package/dist/powerlines/src/lib/utilities/bundle.cjs +0 -35
  123. package/dist/powerlines/src/lib/utilities/bundle.mjs +0 -34
  124. package/dist/powerlines/src/lib/utilities/resolve.cjs +0 -30
  125. package/dist/powerlines/src/lib/utilities/resolve.mjs +0 -29
  126. package/dist/powerlines/src/plugin-utils/paths.cjs +0 -1
  127. package/dist/powerlines/src/plugin-utils/paths.mjs +0 -3
@@ -1,101 +0,0 @@
1
- const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.cjs');
2
- let defu = require("defu");
3
- defu = require_rolldown_runtime.__toESM(defu);
4
- let __stryke_path_replace = require("@stryke/path/replace");
5
- let __stryke_convert_to_array = require("@stryke/convert/to-array");
6
- let __stryke_fs_is_file = require("@stryke/fs/is-file");
7
- let __stryke_fs_list_files = require("@stryke/fs/list-files");
8
- let __stryke_path_append = require("@stryke/path/append");
9
- let __stryke_path_is_type = require("@stryke/path/is-type");
10
- let __stryke_path_join_paths = require("@stryke/path/join-paths");
11
- let automd = require("automd");
12
- let c12 = require("c12");
13
- let markdown_toc = require("markdown-toc");
14
- markdown_toc = require_rolldown_runtime.__toESM(markdown_toc);
15
-
16
- //#region ../plugin-automd/src/index.ts
17
- /**
18
- * AutoMD Plugin
19
- *
20
- * @remarks
21
- * A Powerlines plugin to use the AutoMD markdown transformer during the prepare task.
22
- *
23
- * @see https://automd.unjs.io/
24
- *
25
- * @param options - The plugin options.
26
- * @returns A Powerlines plugin instance.
27
- */
28
- const plugin = (options = {}) => {
29
- return {
30
- name: "automd",
31
- async config() {
32
- const config = await (0, automd.loadConfig)((0, __stryke_path_join_paths.joinPaths)(this.workspaceConfig.workspaceRoot, this.config.projectRoot), options);
33
- if (!config.prefix || !Array.isArray(config.prefix)) config.prefix = (0, __stryke_convert_to_array.toArray)(config.prefix ?? []);
34
- if (!config.prefix.includes("automd")) config.prefix.push("automd");
35
- if (!config.prefix.includes("powerlines")) config.prefix.push("powerlines");
36
- return { automd: (0, defu.default)(config ?? {}, {
37
- configFile: options.configFile,
38
- allowIssues: true,
39
- dir: this.config.projectRoot,
40
- watch: false,
41
- input: "README.md",
42
- toc: {
43
- maxDepth: 6,
44
- bullets: "-"
45
- }
46
- }) };
47
- },
48
- async configResolved() {
49
- if (this.config.framework && !(0, __stryke_convert_to_array.toArray)(this.config.automd.prefix).includes(this.config.framework)) this.config.automd.prefix = (0, __stryke_convert_to_array.toArray)(this.config.automd.prefix).concat(this.config.framework);
50
- if (this.config.automd.configFile) {
51
- const { config } = await (0, c12.loadConfig)({
52
- cwd: this.config.automd.dir,
53
- configFile: this.config.automd.configFile,
54
- defaults: {
55
- ignore: [
56
- "**/node_modules",
57
- "**/dist",
58
- "**/.*"
59
- ],
60
- dir: this.config.automd.dir
61
- }
62
- });
63
- this.config.automd = (0, automd.resolveConfig)((0, defu.default)(this.config.automd, {
64
- ...config,
65
- prefix: (0, __stryke_convert_to_array.toArray)(config.prefix ?? [])
66
- }));
67
- }
68
- this.config.automd.input = (await Promise.all((0, __stryke_convert_to_array.toArray)(this.config.automd.input).map(async (input) => {
69
- if (input.includes("*")) return (0, __stryke_fs_list_files.listFiles)((0, __stryke_path_is_type.isAbsolutePath)(input) ? input : (0, __stryke_path_append.appendPath)(input, this.config.projectRoot), { ignore: this.config.automd.ignore });
70
- return (0, __stryke_path_is_type.isAbsolutePath)(input) ? input : (0, __stryke_path_append.appendPath)(input, this.config.projectRoot);
71
- }))).flat();
72
- if (this.config.automd.output && !(0, __stryke_path_is_type.isAbsolutePath)(this.config.automd.output)) this.config.automd.output = (0, __stryke_path_append.appendPath)(this.config.automd.output, this.config.projectRoot);
73
- this.config.automd.generators ??= {};
74
- if (this.config.automd.toc !== false) this.config.automd.generators.toc ??= {
75
- name: "toc",
76
- generate: (ctx) => {
77
- const opts = this.config.automd.toc ?? {};
78
- return { contents: (0, markdown_toc.default)(ctx.block.md, {
79
- ...opts,
80
- maxdepth: opts.maxDepth,
81
- first1: opts.firstH1
82
- }).content };
83
- }
84
- };
85
- },
86
- async docs() {
87
- await Promise.all((0, __stryke_convert_to_array.toArray)(this.config.automd.input).map(async (input) => {
88
- const contents = await this.fs.read(input);
89
- if (contents) {
90
- const result = await (0, automd.transform)(contents, this.config.automd);
91
- if (result.hasIssues && this.config.automd.allowIssues === false) throw new Error(`AutoMD found issues in file "${input}". Please resolve the issues or set \`allowIssues\` to true in the plugin configuration to ignore them.`);
92
- if (result.hasChanged) await this.fs.write((0, __stryke_path_append.appendPath)(this.config.automd.output ? (0, __stryke_fs_is_file.isDirectory)(this.config.automd.output) ? (0, __stryke_path_replace.replacePath)(input, this.config.automd.output) : this.config.automd.output : input, this.config.projectRoot), result.contents);
93
- }
94
- }));
95
- }
96
- };
97
- };
98
- var src_default = plugin;
99
-
100
- //#endregion
101
- exports.default = src_default;
@@ -1,98 +0,0 @@
1
- import defu from "defu";
2
- import { replacePath } from "@stryke/path/replace";
3
- import { toArray } from "@stryke/convert/to-array";
4
- import { isDirectory } from "@stryke/fs/is-file";
5
- import { listFiles } from "@stryke/fs/list-files";
6
- import { appendPath } from "@stryke/path/append";
7
- import { isAbsolutePath } from "@stryke/path/is-type";
8
- import { joinPaths } from "@stryke/path/join-paths";
9
- import { loadConfig, resolveConfig, transform } from "automd";
10
- import { loadConfig as loadConfig$1 } from "c12";
11
- import toc from "markdown-toc";
12
-
13
- //#region ../plugin-automd/src/index.ts
14
- /**
15
- * AutoMD Plugin
16
- *
17
- * @remarks
18
- * A Powerlines plugin to use the AutoMD markdown transformer during the prepare task.
19
- *
20
- * @see https://automd.unjs.io/
21
- *
22
- * @param options - The plugin options.
23
- * @returns A Powerlines plugin instance.
24
- */
25
- const plugin = (options = {}) => {
26
- return {
27
- name: "automd",
28
- async config() {
29
- const config = await loadConfig(joinPaths(this.workspaceConfig.workspaceRoot, this.config.projectRoot), options);
30
- if (!config.prefix || !Array.isArray(config.prefix)) config.prefix = toArray(config.prefix ?? []);
31
- if (!config.prefix.includes("automd")) config.prefix.push("automd");
32
- if (!config.prefix.includes("powerlines")) config.prefix.push("powerlines");
33
- return { automd: defu(config ?? {}, {
34
- configFile: options.configFile,
35
- allowIssues: true,
36
- dir: this.config.projectRoot,
37
- watch: false,
38
- input: "README.md",
39
- toc: {
40
- maxDepth: 6,
41
- bullets: "-"
42
- }
43
- }) };
44
- },
45
- async configResolved() {
46
- if (this.config.framework && !toArray(this.config.automd.prefix).includes(this.config.framework)) this.config.automd.prefix = toArray(this.config.automd.prefix).concat(this.config.framework);
47
- if (this.config.automd.configFile) {
48
- const { config } = await loadConfig$1({
49
- cwd: this.config.automd.dir,
50
- configFile: this.config.automd.configFile,
51
- defaults: {
52
- ignore: [
53
- "**/node_modules",
54
- "**/dist",
55
- "**/.*"
56
- ],
57
- dir: this.config.automd.dir
58
- }
59
- });
60
- this.config.automd = resolveConfig(defu(this.config.automd, {
61
- ...config,
62
- prefix: toArray(config.prefix ?? [])
63
- }));
64
- }
65
- this.config.automd.input = (await Promise.all(toArray(this.config.automd.input).map(async (input) => {
66
- if (input.includes("*")) return listFiles(isAbsolutePath(input) ? input : appendPath(input, this.config.projectRoot), { ignore: this.config.automd.ignore });
67
- return isAbsolutePath(input) ? input : appendPath(input, this.config.projectRoot);
68
- }))).flat();
69
- if (this.config.automd.output && !isAbsolutePath(this.config.automd.output)) this.config.automd.output = appendPath(this.config.automd.output, this.config.projectRoot);
70
- this.config.automd.generators ??= {};
71
- if (this.config.automd.toc !== false) this.config.automd.generators.toc ??= {
72
- name: "toc",
73
- generate: (ctx) => {
74
- const opts = this.config.automd.toc ?? {};
75
- return { contents: toc(ctx.block.md, {
76
- ...opts,
77
- maxdepth: opts.maxDepth,
78
- first1: opts.firstH1
79
- }).content };
80
- }
81
- };
82
- },
83
- async docs() {
84
- await Promise.all(toArray(this.config.automd.input).map(async (input) => {
85
- const contents = await this.fs.read(input);
86
- if (contents) {
87
- const result = await transform(contents, this.config.automd);
88
- if (result.hasIssues && this.config.automd.allowIssues === false) throw new Error(`AutoMD found issues in file "${input}". Please resolve the issues or set \`allowIssues\` to true in the plugin configuration to ignore them.`);
89
- if (result.hasChanged) await this.fs.write(appendPath(this.config.automd.output ? isDirectory(this.config.automd.output) ? replacePath(input, this.config.automd.output) : this.config.automd.output : input, this.config.projectRoot), result.contents);
90
- }
91
- }));
92
- }
93
- };
94
- };
95
- var src_default = plugin;
96
-
97
- //#endregion
98
- export { src_default as default };
@@ -1,10 +0,0 @@
1
- const require_rolldown_runtime = require('../../../_virtual/rolldown_runtime.cjs');
2
- let __babel_generator = require("@babel/generator");
3
- __babel_generator = require_rolldown_runtime.__toESM(__babel_generator);
4
- require("@babel/parser");
5
-
6
- //#region ../plugin-babel/src/helpers/ast-utils.ts
7
- let generate = __babel_generator.default;
8
- if ("default" in generate) generate = generate.default;
9
-
10
- //#endregion
@@ -1,9 +0,0 @@
1
- import _generate from "@babel/generator";
2
- import "@babel/parser";
3
-
4
- //#region ../plugin-babel/src/helpers/ast-utils.ts
5
- let generate = _generate;
6
- if ("default" in generate) generate = generate.default;
7
-
8
- //#endregion
9
- export { };
@@ -1,41 +0,0 @@
1
- const require_rolldown_runtime = require('../../../_virtual/rolldown_runtime.cjs');
2
- const require_logger = require('../../../powerlines/src/lib/logger.cjs');
3
- let __storm_software_config_tools_types = require("@storm-software/config-tools/types");
4
- let chalk = require("chalk");
5
- chalk = require_rolldown_runtime.__toESM(chalk);
6
- let __babel_helper_plugin_utils = require("@babel/helper-plugin-utils");
7
-
8
- //#region ../plugin-babel/src/helpers/create-plugin.ts
9
- /**
10
- * Create a Babel plugin using the provided builder function.
11
- *
12
- * @param name - The name of the plugin.
13
- * @param builder - The builder function that defines the plugin behavior.
14
- * @returns A Babel plugin declaration.
15
- */
16
- function createBabelPlugin(name, builder) {
17
- const plugin = (context) => {
18
- return (0, __babel_helper_plugin_utils.declare)((api, options, dirname) => {
19
- api.cache.using(() => context.meta.checksum);
20
- api.assertVersion("^7.0.0-0");
21
- const log = require_logger.extendLog(context.log, name);
22
- log(__storm_software_config_tools_types.LogLevelLabel.TRACE, `Initializing the ${chalk.default.bold.cyanBright(name)} Babel plugin`);
23
- const result = builder({
24
- log,
25
- name,
26
- api,
27
- options,
28
- context,
29
- dirname
30
- });
31
- result.name = name;
32
- log(__storm_software_config_tools_types.LogLevelLabel.TRACE, `Completed initialization of the ${chalk.default.bold.cyanBright(name)} Babel plugin`);
33
- return result;
34
- });
35
- };
36
- plugin.$$name = name;
37
- return plugin;
38
- }
39
-
40
- //#endregion
41
- exports.createBabelPlugin = createBabelPlugin;
@@ -1,39 +0,0 @@
1
- import { extendLog } from "../../../powerlines/src/lib/logger.mjs";
2
- import { LogLevelLabel } from "@storm-software/config-tools/types";
3
- import chalk from "chalk";
4
- import { declare } from "@babel/helper-plugin-utils";
5
-
6
- //#region ../plugin-babel/src/helpers/create-plugin.ts
7
- /**
8
- * Create a Babel plugin using the provided builder function.
9
- *
10
- * @param name - The name of the plugin.
11
- * @param builder - The builder function that defines the plugin behavior.
12
- * @returns A Babel plugin declaration.
13
- */
14
- function createBabelPlugin(name, builder) {
15
- const plugin = (context) => {
16
- return declare((api, options, dirname) => {
17
- api.cache.using(() => context.meta.checksum);
18
- api.assertVersion("^7.0.0-0");
19
- const log = extendLog(context.log, name);
20
- log(LogLevelLabel.TRACE, `Initializing the ${chalk.bold.cyanBright(name)} Babel plugin`);
21
- const result = builder({
22
- log,
23
- name,
24
- api,
25
- options,
26
- context,
27
- dirname
28
- });
29
- result.name = name;
30
- log(LogLevelLabel.TRACE, `Completed initialization of the ${chalk.bold.cyanBright(name)} Babel plugin`);
31
- return result;
32
- });
33
- };
34
- plugin.$$name = name;
35
- return plugin;
36
- }
37
-
38
- //#endregion
39
- export { createBabelPlugin };
@@ -1,23 +0,0 @@
1
- const require_rolldown_runtime = require('../../../_virtual/rolldown_runtime.cjs');
2
- let __stryke_type_checks_is_function = require("@stryke/type-checks/is-function");
3
- require("@stryke/type-checks/is-object");
4
- let __stryke_type_checks_is_set_string = require("@stryke/type-checks/is-set-string");
5
-
6
- //#region ../plugin-babel/src/helpers/filters.ts
7
- function getPluginName(plugin) {
8
- return (0, __stryke_type_checks_is_set_string.isSetString)(plugin) ? plugin : Array.isArray(plugin) && plugin.length > 0 ? getPluginName(plugin[0]) : plugin.$$name || plugin.name ? plugin.$$name || plugin.name : void 0;
9
- }
10
- /**
11
- * Check if a Babel plugin is a duplicate of another plugin in the list.
12
- *
13
- * @param plugins - The list of existing Babel plugins.
14
- * @param plugin - The Babel plugin to check for duplicates.
15
- * @returns True if the plugin is a duplicate, false otherwise.
16
- */
17
- function isDuplicatePlugin(plugins, plugin) {
18
- return !!(getPluginName(plugin) && plugins.some((existing) => Array.isArray(existing) && getPluginName(existing[0]) === getPluginName(plugin)));
19
- }
20
-
21
- //#endregion
22
- exports.getPluginName = getPluginName;
23
- exports.isDuplicatePlugin = isDuplicatePlugin;
@@ -1,21 +0,0 @@
1
- import { isFunction } from "@stryke/type-checks/is-function";
2
- import "@stryke/type-checks/is-object";
3
- import { isSetString } from "@stryke/type-checks/is-set-string";
4
-
5
- //#region ../plugin-babel/src/helpers/filters.ts
6
- function getPluginName(plugin) {
7
- return isSetString(plugin) ? plugin : Array.isArray(plugin) && plugin.length > 0 ? getPluginName(plugin[0]) : plugin.$$name || plugin.name ? plugin.$$name || plugin.name : void 0;
8
- }
9
- /**
10
- * Check if a Babel plugin is a duplicate of another plugin in the list.
11
- *
12
- * @param plugins - The list of existing Babel plugins.
13
- * @param plugin - The Babel plugin to check for duplicates.
14
- * @returns True if the plugin is a duplicate, false otherwise.
15
- */
16
- function isDuplicatePlugin(plugins, plugin) {
17
- return !!(getPluginName(plugin) && plugins.some((existing) => Array.isArray(existing) && getPluginName(existing[0]) === getPluginName(plugin)));
18
- }
19
-
20
- //#endregion
21
- export { getPluginName, isDuplicatePlugin };
@@ -1,5 +0,0 @@
1
- const require_filters = require('./filters.cjs');
2
- const require_options = require('./options.cjs');
3
- require('./ast-utils.cjs');
4
- const require_create_plugin = require('./create-plugin.cjs');
5
- const require_module_helpers = require('./module-helpers.cjs');
@@ -1,7 +0,0 @@
1
- import { getPluginName, isDuplicatePlugin } from "./filters.mjs";
2
- import { resolveBabelPlugin, resolvePluginFunction } from "./options.mjs";
3
- import "./ast-utils.mjs";
4
- import { createBabelPlugin } from "./create-plugin.mjs";
5
- import { addImport, addImportsToProgram } from "./module-helpers.mjs";
6
-
7
- export { };
@@ -1,38 +0,0 @@
1
- const require_rolldown_runtime = require('../../../_virtual/rolldown_runtime.cjs');
2
- require('./ast-utils.cjs');
3
- let __babel_types = require("@babel/types");
4
- __babel_types = require_rolldown_runtime.__toESM(__babel_types);
5
- let __stryke_type_checks_is_string = require("@stryke/type-checks/is-string");
6
-
7
- //#region ../plugin-babel/src/helpers/module-helpers.ts
8
- /**
9
- * Adds an import to the program if it doesn't already exist.
10
- *
11
- * @param path - The current NodePath in the AST.
12
- * @param specifier - The import specifier.
13
- */
14
- function addImport(path, specifier) {
15
- addImportsToProgram(path.scope.getProgramParent().path, specifier);
16
- }
17
- function isNonNamespacedImport(importDeclPath) {
18
- return importDeclPath.get("specifiers").filter(Boolean).every((specifier) => specifier?.isImportSpecifier()) && importDeclPath.node.importKind !== "type" && importDeclPath.node.importKind !== "typeof";
19
- }
20
- function getExistingImports(program) {
21
- const existingImports = /* @__PURE__ */ new Map();
22
- program.traverse({ ImportDeclaration(path) {
23
- if (isNonNamespacedImport(path)) existingImports.set(path.node.source.value, path);
24
- } });
25
- return existingImports;
26
- }
27
- function addImportsToProgram(path, specifier) {
28
- /**
29
- * If an existing import of this module exists (ie \`import \{ ... \} from
30
- * '<moduleName>'\`), inject new imported specifiers into the list of
31
- * destructured variables.
32
- */
33
- if (!getExistingImports(path).get(specifier.module)) path.unshiftContainer("body", __babel_types.importDeclaration([__babel_types.importSpecifier(__babel_types.identifier(specifier.name || specifier.imported), __babel_types.identifier(specifier.imported))], __babel_types.stringLiteral(specifier.module)));
34
- }
35
-
36
- //#endregion
37
- exports.addImport = addImport;
38
- exports.addImportsToProgram = addImportsToProgram;
@@ -1,35 +0,0 @@
1
- import "./ast-utils.mjs";
2
- import * as t from "@babel/types";
3
- import { isString } from "@stryke/type-checks/is-string";
4
-
5
- //#region ../plugin-babel/src/helpers/module-helpers.ts
6
- /**
7
- * Adds an import to the program if it doesn't already exist.
8
- *
9
- * @param path - The current NodePath in the AST.
10
- * @param specifier - The import specifier.
11
- */
12
- function addImport(path, specifier) {
13
- addImportsToProgram(path.scope.getProgramParent().path, specifier);
14
- }
15
- function isNonNamespacedImport(importDeclPath) {
16
- return importDeclPath.get("specifiers").filter(Boolean).every((specifier) => specifier?.isImportSpecifier()) && importDeclPath.node.importKind !== "type" && importDeclPath.node.importKind !== "typeof";
17
- }
18
- function getExistingImports(program) {
19
- const existingImports = /* @__PURE__ */ new Map();
20
- program.traverse({ ImportDeclaration(path) {
21
- if (isNonNamespacedImport(path)) existingImports.set(path.node.source.value, path);
22
- } });
23
- return existingImports;
24
- }
25
- function addImportsToProgram(path, specifier) {
26
- /**
27
- * If an existing import of this module exists (ie \`import \{ ... \} from
28
- * '<moduleName>'\`), inject new imported specifiers into the list of
29
- * destructured variables.
30
- */
31
- if (!getExistingImports(path).get(specifier.module)) path.unshiftContainer("body", t.importDeclaration([t.importSpecifier(t.identifier(specifier.name || specifier.imported), t.identifier(specifier.imported))], t.stringLiteral(specifier.module)));
32
- }
33
-
34
- //#endregion
35
- export { addImport, addImportsToProgram };
@@ -1,50 +0,0 @@
1
- const require_rolldown_runtime = require('../../../_virtual/rolldown_runtime.cjs');
2
- const require_filters = require('./filters.cjs');
3
- let __storm_software_config_tools_types = require("@storm-software/config-tools/types");
4
- let __stryke_type_checks_is_function = require("@stryke/type-checks/is-function");
5
- let chalk = require("chalk");
6
- chalk = require_rolldown_runtime.__toESM(chalk);
7
-
8
- //#region ../plugin-babel/src/helpers/options.ts
9
- function resolvePluginFunction(context, plugin) {
10
- try {
11
- return Array.isArray(plugin) && plugin.length > 0 && plugin[0] ? (0, __stryke_type_checks_is_function.isFunction)(plugin[0]) ? plugin[0](context) : plugin[0] : (0, __stryke_type_checks_is_function.isFunction)(plugin) ? plugin(context) : plugin;
12
- } catch {
13
- return plugin[0];
14
- }
15
- }
16
- /**
17
- * Resolve the [Babel](https://babeljs.io/) plugin.
18
- *
19
- * @param context - The context for the transformation.
20
- * @param code - The code to be transformed.
21
- * @param id - The ID of the source file.
22
- * @param plugin - The Babel plugin to resolve.
23
- * @returns The resolved Babel plugin options, or undefined if the plugin is filtered out.
24
- */
25
- function resolveBabelPlugin(context, code, id, plugin) {
26
- if (Array.isArray(plugin) && plugin.length > 0 && plugin[0]) {
27
- if (plugin.length > 2 && plugin[2] && (0, __stryke_type_checks_is_function.isFunction)(plugin[2]) && !plugin[2](code, id)) {
28
- context.log(__storm_software_config_tools_types.LogLevelLabel.TRACE, `Skipping filtered Babel plugin ${chalk.default.bold.cyanBright(require_filters.getPluginName(plugin) || "unnamed")} for ${id}`);
29
- return;
30
- }
31
- return plugin.length > 2 ? [
32
- resolvePluginFunction(context, plugin),
33
- plugin[1],
34
- plugin[2]
35
- ] : [
36
- resolvePluginFunction(context, plugin),
37
- plugin[1],
38
- null
39
- ];
40
- }
41
- return [
42
- resolvePluginFunction(context, plugin),
43
- {},
44
- null
45
- ];
46
- }
47
-
48
- //#endregion
49
- exports.resolveBabelPlugin = resolveBabelPlugin;
50
- exports.resolvePluginFunction = resolvePluginFunction;
@@ -1,47 +0,0 @@
1
- import { getPluginName } from "./filters.mjs";
2
- import { LogLevelLabel } from "@storm-software/config-tools/types";
3
- import { isFunction } from "@stryke/type-checks/is-function";
4
- import chalk from "chalk";
5
-
6
- //#region ../plugin-babel/src/helpers/options.ts
7
- function resolvePluginFunction(context, plugin) {
8
- try {
9
- return Array.isArray(plugin) && plugin.length > 0 && plugin[0] ? isFunction(plugin[0]) ? plugin[0](context) : plugin[0] : isFunction(plugin) ? plugin(context) : plugin;
10
- } catch {
11
- return plugin[0];
12
- }
13
- }
14
- /**
15
- * Resolve the [Babel](https://babeljs.io/) plugin.
16
- *
17
- * @param context - The context for the transformation.
18
- * @param code - The code to be transformed.
19
- * @param id - The ID of the source file.
20
- * @param plugin - The Babel plugin to resolve.
21
- * @returns The resolved Babel plugin options, or undefined if the plugin is filtered out.
22
- */
23
- function resolveBabelPlugin(context, code, id, plugin) {
24
- if (Array.isArray(plugin) && plugin.length > 0 && plugin[0]) {
25
- if (plugin.length > 2 && plugin[2] && isFunction(plugin[2]) && !plugin[2](code, id)) {
26
- context.log(LogLevelLabel.TRACE, `Skipping filtered Babel plugin ${chalk.bold.cyanBright(getPluginName(plugin) || "unnamed")} for ${id}`);
27
- return;
28
- }
29
- return plugin.length > 2 ? [
30
- resolvePluginFunction(context, plugin),
31
- plugin[1],
32
- plugin[2]
33
- ] : [
34
- resolvePluginFunction(context, plugin),
35
- plugin[1],
36
- null
37
- ];
38
- }
39
- return [
40
- resolvePluginFunction(context, plugin),
41
- {},
42
- null
43
- ];
44
- }
45
-
46
- //#endregion
47
- export { resolveBabelPlugin, resolvePluginFunction };
@@ -1,91 +0,0 @@
1
- const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.cjs');
2
- const require_filters = require('./helpers/filters.cjs');
3
- const require_options = require('./helpers/options.cjs');
4
- const require_create_plugin = require('./helpers/create-plugin.cjs');
5
- const require_module_helpers = require('./helpers/module-helpers.cjs');
6
- require('./helpers/index.cjs');
7
- let __babel_core = require("@babel/core");
8
- let __storm_software_config_tools_types = require("@storm-software/config-tools/types");
9
- let __stryke_path_file_path_fns = require("@stryke/path/file-path-fns");
10
- let __stryke_path_is_parent_path = require("@stryke/path/is-parent-path");
11
- let __stryke_type_checks_is_set_object = require("@stryke/type-checks/is-set-object");
12
- let defu = require("defu");
13
- defu = require_rolldown_runtime.__toESM(defu);
14
-
15
- //#region ../plugin-babel/src/index.ts
16
- /**
17
- * Babel plugin for Powerlines.
18
- *
19
- * @param options - The Babel plugin user configuration options.
20
- * @returns A Powerlines plugin that integrates Babel transformations.
21
- */
22
- const plugin = (options = {}) => {
23
- return {
24
- name: "babel",
25
- config() {
26
- if (!(0, __stryke_type_checks_is_set_object.isSetObject)(options)) return;
27
- return { transform: { babel: options } };
28
- },
29
- configResolved: {
30
- order: "pre",
31
- handler() {
32
- this.devDependencies["@babel/core"] = "^7.28.4";
33
- this.config.transform.babel = (0, defu.default)(this.config.transform.babel ?? {}, {
34
- plugins: [],
35
- presets: []
36
- });
37
- }
38
- },
39
- async transform(code, id) {
40
- if ((0, __stryke_path_is_parent_path.isParentPath)(id, this.powerlinesPath) || code.includes("/* @storm-ignore */") || code.includes("/* @storm-disable */")) {
41
- this.log(__storm_software_config_tools_types.LogLevelLabel.TRACE, `Skipping Babel transformation for: ${id}`);
42
- return {
43
- code,
44
- id
45
- };
46
- }
47
- this.log(__storm_software_config_tools_types.LogLevelLabel.TRACE, `Babel transforming file: ${id}`);
48
- const plugins = this.config.transform.babel.plugins.map((plugin$1) => require_options.resolveBabelPlugin(this, code, id, plugin$1)).filter((plugin$1, _, arr) => plugin$1 && !require_filters.isDuplicatePlugin(arr, plugin$1));
49
- const presets = this.config.transform.babel.presets.map((preset) => require_options.resolveBabelPlugin(this, code, id, preset)).filter((preset, _, arr) => preset && !require_filters.isDuplicatePlugin(arr, preset));
50
- if (Array.isArray(plugins) && plugins.length === 0 && Array.isArray(presets) && presets.length === 0) return {
51
- code,
52
- id
53
- };
54
- if ([
55
- "ts",
56
- "cts",
57
- "mts",
58
- "tsx"
59
- ].includes((0, __stryke_path_file_path_fns.findFileExtensionSafe)(id)) && !require_filters.isDuplicatePlugin(plugins, "@babel/plugin-syntax-typescript") && !require_filters.isDuplicatePlugin(presets, "@babel/preset-typescript")) plugins.unshift(["@babel/plugin-syntax-typescript", { isTSX: (0, __stryke_path_file_path_fns.findFileExtension)(id) === ".tsx" }]);
60
- const result = await (0, __babel_core.transformAsync)(code, {
61
- highlightCode: true,
62
- code: true,
63
- ast: false,
64
- cloneInputAst: false,
65
- comments: true,
66
- sourceType: "module",
67
- configFile: false,
68
- babelrc: false,
69
- envName: this.config.mode,
70
- caller: { name: this.config.framework },
71
- ...this.config.transform.babel ?? {},
72
- filename: id,
73
- plugins: plugins.map((plugin$1) => {
74
- return Array.isArray(plugin$1) && plugin$1.length >= 2 ? [plugin$1[0], (0, defu.default)(plugin$1.length > 1 && plugin$1[1] ? plugin$1[1] : {}, { options })] : plugin$1;
75
- }).filter(Boolean),
76
- presets: presets.map((preset) => {
77
- return Array.isArray(preset) && preset.length >= 2 ? [preset[0], (0, defu.default)(preset.length > 1 && preset[1] ? preset[1] : {}, { options })] : preset;
78
- }).filter(Boolean)
79
- });
80
- if (!result?.code) throw new Error(`Powerlines - Babel plugin failed to compile ${id}`);
81
- return {
82
- code: result.code,
83
- id
84
- };
85
- }
86
- };
87
- };
88
- var src_default = plugin;
89
-
90
- //#endregion
91
- exports.default = src_default;