@powerlines/plugin-nodejs 0.1.116 → 0.1.117

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 (144) hide show
  1. package/dist/components/env.cjs +14 -14
  2. package/dist/components/env.mjs +6 -6
  3. package/dist/deepkit/schemas/reflection.cjs +3998 -0
  4. package/dist/deepkit/schemas/reflection.mjs +3996 -0
  5. package/dist/deepkit/schemas/reflection2.cjs +4112 -0
  6. package/dist/deepkit/schemas/reflection2.mjs +4110 -0
  7. package/dist/deepkit/src/capnp.cjs +913 -0
  8. package/dist/deepkit/src/capnp.mjs +911 -0
  9. package/dist/deepkit/src/esbuild-plugin.cjs +47 -0
  10. package/dist/deepkit/src/esbuild-plugin.mjs +46 -0
  11. package/dist/deepkit/src/reflect-type.cjs +22 -0
  12. package/dist/deepkit/src/reflect-type.mjs +20 -0
  13. package/dist/deepkit/src/resolve-reflections.cjs +16 -0
  14. package/dist/deepkit/src/resolve-reflections.mjs +15 -0
  15. package/dist/deepkit/src/transformer.cjs +52 -0
  16. package/dist/deepkit/src/transformer.mjs +49 -0
  17. package/dist/deepkit/src/transpile.cjs +29 -0
  18. package/dist/deepkit/src/transpile.mjs +27 -0
  19. package/dist/deepkit/src/utilities.cjs +67 -0
  20. package/dist/deepkit/src/utilities.mjs +66 -0
  21. package/dist/index.cjs +6 -8
  22. package/dist/index.mjs +5 -5
  23. package/dist/plugin-alloy/src/core/components/output.cjs +43 -0
  24. package/dist/plugin-alloy/src/core/components/output.mjs +42 -0
  25. package/dist/plugin-alloy/src/core/components/single-line-comment.cjs +22 -0
  26. package/dist/plugin-alloy/src/core/components/single-line-comment.mjs +21 -0
  27. package/dist/plugin-alloy/src/core/components/source-file.cjs +64 -0
  28. package/dist/plugin-alloy/src/core/components/source-file.mjs +62 -0
  29. package/dist/plugin-alloy/src/core/contexts/context.cjs +49 -0
  30. package/dist/plugin-alloy/src/core/contexts/context.mjs +44 -0
  31. package/dist/plugin-alloy/src/core/contexts/index.cjs +2 -0
  32. package/dist/plugin-alloy/src/core/contexts/index.mjs +4 -0
  33. package/dist/plugin-alloy/src/core/contexts/reflection.cjs +46 -0
  34. package/dist/plugin-alloy/src/core/contexts/reflection.mjs +42 -0
  35. package/dist/plugin-alloy/src/helpers/refkey.cjs +16 -0
  36. package/dist/plugin-alloy/src/helpers/refkey.mjs +15 -0
  37. package/dist/plugin-alloy/src/index.cjs +105 -0
  38. package/dist/plugin-alloy/src/index.mjs +103 -0
  39. package/dist/plugin-alloy/src/markdown/components/markdown-file.cjs +115 -0
  40. package/dist/plugin-alloy/src/markdown/components/markdown-file.mjs +114 -0
  41. package/dist/plugin-alloy/src/markdown/components/markdown-table.cjs +39 -0
  42. package/dist/plugin-alloy/src/markdown/components/markdown-table.mjs +38 -0
  43. package/dist/plugin-alloy/src/markdown/contexts/markdown-table.cjs +18 -0
  44. package/dist/plugin-alloy/src/markdown/contexts/markdown-table.mjs +17 -0
  45. package/dist/plugin-alloy/src/types/components.d.mts +2 -1
  46. package/dist/plugin-alloy/src/typescript/components/builtin-file.cjs +62 -0
  47. package/dist/plugin-alloy/src/typescript/components/builtin-file.mjs +61 -0
  48. package/dist/plugin-alloy/src/typescript/components/tsdoc-reflection.cjs +131 -0
  49. package/dist/plugin-alloy/src/typescript/components/tsdoc-reflection.mjs +129 -0
  50. package/dist/plugin-alloy/src/typescript/components/tsdoc.cjs +451 -0
  51. package/dist/plugin-alloy/src/typescript/components/tsdoc.d.mts +1 -1
  52. package/dist/plugin-alloy/src/typescript/components/tsdoc.mjs +442 -0
  53. package/dist/plugin-alloy/src/typescript/components/typescript-file.cjs +216 -0
  54. package/dist/plugin-alloy/src/typescript/components/typescript-file.d.mts +1 -1
  55. package/dist/plugin-alloy/src/typescript/components/typescript-file.mjs +213 -0
  56. package/dist/plugin-alloy/src/typescript/components/typescript-interface.cjs +72 -0
  57. package/dist/plugin-alloy/src/typescript/components/typescript-interface.d.mts +2 -2
  58. package/dist/plugin-alloy/src/typescript/components/typescript-interface.mjs +71 -0
  59. package/dist/plugin-alloy/src/typescript/components/typescript-object.cjs +124 -0
  60. package/dist/plugin-alloy/src/typescript/components/typescript-object.mjs +123 -0
  61. package/dist/plugin-automd/src/index.cjs +101 -0
  62. package/dist/plugin-automd/src/index.mjs +98 -0
  63. package/dist/plugin-automd/src/types/plugin.d.mts +3 -1
  64. package/dist/plugin-babel/src/helpers/ast-utils.cjs +10 -0
  65. package/dist/plugin-babel/src/helpers/ast-utils.mjs +9 -0
  66. package/dist/plugin-babel/src/helpers/create-plugin.cjs +41 -0
  67. package/dist/plugin-babel/src/helpers/create-plugin.mjs +39 -0
  68. package/dist/plugin-babel/src/helpers/filters.cjs +23 -0
  69. package/dist/plugin-babel/src/helpers/filters.mjs +21 -0
  70. package/dist/plugin-babel/src/helpers/index.cjs +5 -0
  71. package/dist/plugin-babel/src/helpers/index.mjs +7 -0
  72. package/dist/plugin-babel/src/helpers/module-helpers.cjs +38 -0
  73. package/dist/plugin-babel/src/helpers/module-helpers.mjs +35 -0
  74. package/dist/plugin-babel/src/helpers/options.cjs +49 -0
  75. package/dist/plugin-babel/src/helpers/options.mjs +46 -0
  76. package/dist/plugin-babel/src/index.cjs +85 -0
  77. package/dist/plugin-babel/src/index.mjs +83 -0
  78. package/dist/plugin-babel/src/types/index.d.mts +1 -0
  79. package/dist/plugin-env/src/babel/index.cjs +1 -0
  80. package/dist/plugin-env/src/babel/index.mjs +3 -0
  81. package/dist/plugin-env/src/babel/plugin.cjs +70 -0
  82. package/dist/plugin-env/src/babel/plugin.mjs +69 -0
  83. package/dist/plugin-env/src/components/docs.cjs +70 -0
  84. package/dist/plugin-env/src/components/docs.mjs +69 -0
  85. package/dist/plugin-env/src/components/env.cjs +589 -0
  86. package/dist/plugin-env/src/components/env.mjs +586 -0
  87. package/dist/plugin-env/src/components/index.cjs +2 -0
  88. package/dist/plugin-env/src/components/index.mjs +4 -0
  89. package/dist/plugin-env/src/helpers/automd-generator.cjs +22 -0
  90. package/dist/plugin-env/src/helpers/automd-generator.mjs +21 -0
  91. package/dist/plugin-env/src/helpers/create-reflection-resource.cjs +55 -0
  92. package/dist/plugin-env/src/helpers/create-reflection-resource.mjs +54 -0
  93. package/dist/plugin-env/src/helpers/docs-helper.cjs +16 -0
  94. package/dist/plugin-env/src/helpers/docs-helper.mjs +15 -0
  95. package/dist/plugin-env/src/helpers/index.cjs +6 -0
  96. package/dist/plugin-env/src/helpers/index.mjs +8 -0
  97. package/dist/plugin-env/src/helpers/load.cjs +84 -0
  98. package/dist/plugin-env/src/helpers/load.mjs +81 -0
  99. package/dist/plugin-env/src/helpers/persistence.cjs +201 -0
  100. package/dist/plugin-env/src/helpers/persistence.mjs +190 -0
  101. package/dist/plugin-env/src/helpers/reflect.cjs +125 -0
  102. package/dist/plugin-env/src/helpers/reflect.mjs +117 -0
  103. package/dist/plugin-env/src/helpers/source-file-env.cjs +24 -0
  104. package/dist/plugin-env/src/helpers/source-file-env.mjs +23 -0
  105. package/dist/plugin-env/src/helpers/template-helpers.cjs +2 -0
  106. package/dist/plugin-env/src/helpers/template-helpers.mjs +4 -0
  107. package/dist/plugin-env/src/index.cjs +177 -0
  108. package/dist/plugin-env/src/index.mjs +175 -0
  109. package/dist/plugin-env/src/types/plugin.d.mts +2 -1
  110. package/dist/powerlines/src/internal/helpers/hooks.d.mts +2 -0
  111. package/dist/powerlines/src/lib/build/esbuild.cjs +93 -0
  112. package/dist/powerlines/src/lib/build/esbuild.mjs +91 -0
  113. package/dist/powerlines/src/lib/constants/environments.cjs +6 -0
  114. package/dist/powerlines/src/lib/constants/environments.mjs +5 -0
  115. package/dist/powerlines/src/lib/entry.cjs +11 -0
  116. package/dist/powerlines/src/lib/entry.mjs +13 -0
  117. package/dist/powerlines/src/lib/logger.cjs +41 -0
  118. package/dist/powerlines/src/lib/logger.mjs +39 -0
  119. package/dist/powerlines/src/lib/typescript/tsconfig.cjs +38 -0
  120. package/dist/powerlines/src/lib/typescript/tsconfig.mjs +35 -0
  121. package/dist/powerlines/src/lib/unplugin/helpers.cjs +3 -0
  122. package/dist/powerlines/src/lib/unplugin/helpers.mjs +5 -0
  123. package/dist/powerlines/src/lib/unplugin/module-resolution.cjs +66 -0
  124. package/dist/powerlines/src/lib/unplugin/module-resolution.mjs +65 -0
  125. package/dist/powerlines/src/lib/unplugin/plugin.cjs +46 -0
  126. package/dist/powerlines/src/lib/unplugin/plugin.mjs +45 -0
  127. package/dist/powerlines/src/lib/utilities/bundle.cjs +42 -0
  128. package/dist/powerlines/src/lib/utilities/bundle.mjs +40 -0
  129. package/dist/powerlines/src/lib/utilities/resolve.cjs +50 -0
  130. package/dist/powerlines/src/lib/utilities/resolve.mjs +49 -0
  131. package/dist/powerlines/src/lib/utilities/source-file.cjs +5 -0
  132. package/dist/powerlines/src/lib/utilities/source-file.mjs +5 -0
  133. package/dist/powerlines/src/plugin-utils/paths.cjs +1 -0
  134. package/dist/powerlines/src/plugin-utils/paths.mjs +3 -0
  135. package/dist/powerlines/src/types/build.cjs +21 -0
  136. package/dist/powerlines/src/types/build.d.mts +6 -6
  137. package/dist/powerlines/src/types/build.mjs +21 -0
  138. package/dist/powerlines/src/types/commands.d.mts +1 -0
  139. package/dist/powerlines/src/types/config.d.mts +3 -2
  140. package/dist/powerlines/src/types/context.d.mts +2 -2
  141. package/dist/powerlines/src/types/plugin.d.mts +1 -1
  142. package/dist/powerlines/src/types/tsconfig.d.mts +1 -1
  143. package/dist/powerlines/src/types/unplugin.d.mts +2 -1
  144. package/package.json +6 -6
@@ -0,0 +1,101 @@
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;
@@ -0,0 +1,98 @@
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,8 +1,10 @@
1
+ import "../../../powerlines/src/types/context.mjs";
2
+ import "../../../powerlines/src/types/config.mjs";
3
+ import "../../../powerlines/src/types/resolved.mjs";
1
4
  import { TOCOptions } from "./toc.mjs";
2
5
  import { Config } from "automd";
3
6
 
4
7
  //#region ../plugin-automd/src/types/plugin.d.ts
5
-
6
8
  type AutoMDPluginOptions = Omit<Config, "dir" | "watch" | "onWatch" | "prefix"> & {
7
9
  /**
8
10
  * Path to the AutoMD configuration file.
@@ -0,0 +1,10 @@
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
@@ -0,0 +1,9 @@
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 { };
@@ -0,0 +1,41 @@
1
+ const require_rolldown_runtime = require('../../../_virtual/rolldown_runtime.cjs');
2
+ const require_logger = require('../../../powerlines/src/lib/logger.cjs');
3
+ let chalk = require("chalk");
4
+ chalk = require_rolldown_runtime.__toESM(chalk);
5
+ let __babel_helper_plugin_utils = require("@babel/helper-plugin-utils");
6
+ let __storm_software_config_tools_types = require("@storm-software/config-tools/types");
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;
@@ -0,0 +1,39 @@
1
+ import { extendLog } from "../../../powerlines/src/lib/logger.mjs";
2
+ import chalk from "chalk";
3
+ import { declare } from "@babel/helper-plugin-utils";
4
+ import { LogLevelLabel } from "@storm-software/config-tools/types";
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 };
@@ -0,0 +1,23 @@
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;
@@ -0,0 +1,21 @@
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 };
@@ -0,0 +1,5 @@
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');
@@ -0,0 +1,7 @@
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 { };
@@ -0,0 +1,38 @@
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;
@@ -0,0 +1,35 @@
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 };
@@ -0,0 +1,49 @@
1
+ const require_rolldown_runtime = require('../../../_virtual/rolldown_runtime.cjs');
2
+ const require_filters = require('./filters.cjs');
3
+ let __stryke_type_checks_is_function = require("@stryke/type-checks/is-function");
4
+ let chalk = require("chalk");
5
+ chalk = require_rolldown_runtime.__toESM(chalk);
6
+
7
+ //#region ../plugin-babel/src/helpers/options.ts
8
+ function resolvePluginFunction(context, plugin) {
9
+ try {
10
+ 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;
11
+ } catch {
12
+ return plugin[0];
13
+ }
14
+ }
15
+ /**
16
+ * Resolve the [Babel](https://babeljs.io/) plugin.
17
+ *
18
+ * @param context - The context for the transformation.
19
+ * @param code - The code to be transformed.
20
+ * @param id - The ID of the source file.
21
+ * @param plugin - The Babel plugin to resolve.
22
+ * @returns The resolved Babel plugin options, or undefined if the plugin is filtered out.
23
+ */
24
+ function resolveBabelPlugin(context, code, id, plugin) {
25
+ if (Array.isArray(plugin) && plugin.length > 0 && plugin[0]) {
26
+ if (plugin.length > 2 && plugin[2] && (0, __stryke_type_checks_is_function.isFunction)(plugin[2]) && !plugin[2](code, id)) {
27
+ context.trace(`Skipping filtered Babel plugin ${chalk.default.bold.cyanBright(require_filters.getPluginName(plugin) || "unnamed")} for ${id}`);
28
+ return;
29
+ }
30
+ return plugin.length > 2 ? [
31
+ resolvePluginFunction(context, plugin),
32
+ plugin[1],
33
+ plugin[2]
34
+ ] : [
35
+ resolvePluginFunction(context, plugin),
36
+ plugin[1],
37
+ null
38
+ ];
39
+ }
40
+ return [
41
+ resolvePluginFunction(context, plugin),
42
+ {},
43
+ null
44
+ ];
45
+ }
46
+
47
+ //#endregion
48
+ exports.resolveBabelPlugin = resolveBabelPlugin;
49
+ exports.resolvePluginFunction = resolvePluginFunction;
@@ -0,0 +1,46 @@
1
+ import { getPluginName } from "./filters.mjs";
2
+ import { isFunction } from "@stryke/type-checks/is-function";
3
+ import chalk from "chalk";
4
+
5
+ //#region ../plugin-babel/src/helpers/options.ts
6
+ function resolvePluginFunction(context, plugin) {
7
+ try {
8
+ return Array.isArray(plugin) && plugin.length > 0 && plugin[0] ? isFunction(plugin[0]) ? plugin[0](context) : plugin[0] : isFunction(plugin) ? plugin(context) : plugin;
9
+ } catch {
10
+ return plugin[0];
11
+ }
12
+ }
13
+ /**
14
+ * Resolve the [Babel](https://babeljs.io/) plugin.
15
+ *
16
+ * @param context - The context for the transformation.
17
+ * @param code - The code to be transformed.
18
+ * @param id - The ID of the source file.
19
+ * @param plugin - The Babel plugin to resolve.
20
+ * @returns The resolved Babel plugin options, or undefined if the plugin is filtered out.
21
+ */
22
+ function resolveBabelPlugin(context, code, id, plugin) {
23
+ if (Array.isArray(plugin) && plugin.length > 0 && plugin[0]) {
24
+ if (plugin.length > 2 && plugin[2] && isFunction(plugin[2]) && !plugin[2](code, id)) {
25
+ context.trace(`Skipping filtered Babel plugin ${chalk.bold.cyanBright(getPluginName(plugin) || "unnamed")} for ${id}`);
26
+ return;
27
+ }
28
+ return plugin.length > 2 ? [
29
+ resolvePluginFunction(context, plugin),
30
+ plugin[1],
31
+ plugin[2]
32
+ ] : [
33
+ resolvePluginFunction(context, plugin),
34
+ plugin[1],
35
+ null
36
+ ];
37
+ }
38
+ return [
39
+ resolvePluginFunction(context, plugin),
40
+ {},
41
+ null
42
+ ];
43
+ }
44
+
45
+ //#endregion
46
+ export { resolveBabelPlugin, resolvePluginFunction };
@@ -0,0 +1,85 @@
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 __stryke_path_file_path_fns = require("@stryke/path/file-path-fns");
9
+ let __stryke_path_is_parent_path = require("@stryke/path/is-parent-path");
10
+ let __stryke_type_checks_is_set_object = require("@stryke/type-checks/is-set-object");
11
+ let defu = require("defu");
12
+ defu = require_rolldown_runtime.__toESM(defu);
13
+
14
+ //#region ../plugin-babel/src/index.ts
15
+ /**
16
+ * Babel plugin for Powerlines.
17
+ *
18
+ * @param options - The Babel plugin user configuration options.
19
+ * @returns A Powerlines plugin that integrates Babel transformations.
20
+ */
21
+ const plugin = (options = {}) => {
22
+ return {
23
+ name: "babel",
24
+ config() {
25
+ if (!(0, __stryke_type_checks_is_set_object.isSetObject)(options)) return;
26
+ return { transform: { babel: options } };
27
+ },
28
+ configResolved: {
29
+ order: "pre",
30
+ handler() {
31
+ this.config.transform.babel = (0, defu.default)(this.config.transform.babel ?? {}, {
32
+ plugins: [],
33
+ presets: []
34
+ });
35
+ }
36
+ },
37
+ async transform(code, id) {
38
+ if ((0, __stryke_path_is_parent_path.isParentPath)(id, this.powerlinesPath) || code.includes("/* @powerlines-ignore */") || code.includes("/* @powerlines-disable */")) {
39
+ this.trace(`Skipping Babel transformation for: ${id}`);
40
+ return {
41
+ code,
42
+ id
43
+ };
44
+ }
45
+ 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));
46
+ 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));
47
+ if (Array.isArray(plugins) && plugins.length === 0 && Array.isArray(presets) && presets.length === 0) return {
48
+ code,
49
+ id
50
+ };
51
+ if (/^(?:m|c)?tsx?$/.test((0, __stryke_path_file_path_fns.findFileExtensionSafe)(id, { fullExtension: true })) && !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" }]);
52
+ this.trace(`Running babel transformations with ${plugins.length} plugins and ${presets.length} presets for file: ${id}`);
53
+ const result = await (0, __babel_core.transformAsync)(code, {
54
+ highlightCode: true,
55
+ code: true,
56
+ ast: false,
57
+ cloneInputAst: false,
58
+ comments: true,
59
+ sourceType: "module",
60
+ configFile: false,
61
+ babelrc: false,
62
+ envName: this.config.mode,
63
+ caller: { name: this.config.framework },
64
+ ...this.config.transform.babel ?? {},
65
+ filename: id,
66
+ plugins: plugins.map((plugin$1) => {
67
+ 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;
68
+ }).filter(Boolean),
69
+ presets: presets.map((preset) => {
70
+ return Array.isArray(preset) && preset.length >= 2 ? [preset[0], (0, defu.default)(preset.length > 1 && preset[1] ? preset[1] : {}, { options })] : preset;
71
+ }).filter(Boolean)
72
+ });
73
+ if (!result?.code) throw new Error(`Powerlines - Babel plugin failed to compile ${id}`);
74
+ this.trace(`Completed babel transformations for file: ${id}`);
75
+ return {
76
+ code: result.code,
77
+ id
78
+ };
79
+ }
80
+ };
81
+ };
82
+ var src_default = plugin;
83
+
84
+ //#endregion
85
+ exports.default = src_default;