@powerlines/plugin-rolldown 0.7.127 → 0.7.129

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 (89) hide show
  1. package/dist/_virtual/rolldown_runtime.cjs +29 -1
  2. package/dist/helpers/index.cjs +3 -1
  3. package/dist/helpers/index.mjs +3 -1
  4. package/dist/helpers/unplugin.cjs +12 -1
  5. package/dist/helpers/unplugin.mjs +11 -1
  6. package/dist/index.cjs +38 -1
  7. package/dist/index.mjs +33 -1
  8. package/dist/powerlines/schemas/fs.cjs +226 -1
  9. package/dist/powerlines/schemas/fs.mjs +224 -1
  10. package/dist/powerlines/src/api.cjs +576 -9
  11. package/dist/powerlines/src/api.mjs +578 -1
  12. package/dist/powerlines/src/internal/babel/module-resolver-plugin.cjs +86 -1
  13. package/dist/powerlines/src/internal/babel/module-resolver-plugin.mjs +84 -1
  14. package/dist/powerlines/src/internal/helpers/environment.cjs +52 -1
  15. package/dist/powerlines/src/internal/helpers/environment.mjs +48 -1
  16. package/dist/powerlines/src/internal/helpers/generate-types.cjs +50 -7
  17. package/dist/powerlines/src/internal/helpers/generate-types.mjs +48 -7
  18. package/dist/powerlines/src/internal/helpers/hooks.cjs +63 -1
  19. package/dist/powerlines/src/internal/helpers/hooks.mjs +61 -1
  20. package/dist/powerlines/src/internal/helpers/install-dependencies.cjs +25 -3
  21. package/dist/powerlines/src/internal/helpers/install-dependencies.mjs +24 -3
  22. package/dist/powerlines/src/internal/helpers/install.cjs +37 -1
  23. package/dist/powerlines/src/internal/helpers/install.mjs +36 -1
  24. package/dist/powerlines/src/internal/helpers/resolve-tsconfig.cjs +97 -7
  25. package/dist/powerlines/src/internal/helpers/resolve-tsconfig.mjs +93 -7
  26. package/dist/powerlines/src/internal/helpers/resolver.cjs +43 -1
  27. package/dist/powerlines/src/internal/helpers/resolver.mjs +41 -1
  28. package/dist/powerlines/src/lib/build/rolldown.cjs +125 -1
  29. package/dist/powerlines/src/lib/build/rolldown.mjs +119 -1
  30. package/dist/powerlines/src/lib/build/rollup.cjs +45 -1
  31. package/dist/powerlines/src/lib/build/rollup.mjs +39 -1
  32. package/dist/powerlines/src/lib/config-file.cjs +79 -1
  33. package/dist/powerlines/src/lib/config-file.mjs +76 -1
  34. package/dist/powerlines/src/lib/contexts/api-context.cjs +184 -1
  35. package/dist/powerlines/src/lib/contexts/api-context.mjs +182 -1
  36. package/dist/powerlines/src/lib/contexts/context.cjs +931 -1
  37. package/dist/powerlines/src/lib/contexts/context.mjs +929 -1
  38. package/dist/powerlines/src/lib/contexts/environment-context.cjs +160 -1
  39. package/dist/powerlines/src/lib/contexts/environment-context.mjs +159 -1
  40. package/dist/powerlines/src/lib/contexts/plugin-context.cjs +75 -1
  41. package/dist/powerlines/src/lib/contexts/plugin-context.mjs +74 -1
  42. package/dist/powerlines/src/lib/entry.cjs +69 -1
  43. package/dist/powerlines/src/lib/entry.mjs +67 -1
  44. package/dist/powerlines/src/lib/fs/helpers.cjs +85 -1
  45. package/dist/powerlines/src/lib/fs/helpers.mjs +81 -1
  46. package/dist/powerlines/src/lib/fs/storage/base.cjs +196 -1
  47. package/dist/powerlines/src/lib/fs/storage/base.mjs +195 -1
  48. package/dist/powerlines/src/lib/fs/storage/file-system.cjs +170 -1
  49. package/dist/powerlines/src/lib/fs/storage/file-system.mjs +169 -1
  50. package/dist/powerlines/src/lib/fs/storage/virtual.cjs +88 -1
  51. package/dist/powerlines/src/lib/fs/storage/virtual.mjs +87 -1
  52. package/dist/powerlines/src/lib/fs/vfs.cjs +830 -1
  53. package/dist/powerlines/src/lib/fs/vfs.mjs +828 -1
  54. package/dist/powerlines/src/lib/logger.cjs +58 -1
  55. package/dist/powerlines/src/lib/logger.mjs +55 -1
  56. package/dist/powerlines/src/lib/typescript/ts-morph.cjs +104 -1
  57. package/dist/powerlines/src/lib/typescript/ts-morph.mjs +102 -1
  58. package/dist/powerlines/src/lib/typescript/tsconfig.cjs +149 -4
  59. package/dist/powerlines/src/lib/typescript/tsconfig.mjs +144 -4
  60. package/dist/powerlines/src/lib/unplugin/factory.cjs +6 -1
  61. package/dist/powerlines/src/lib/unplugin/factory.mjs +8 -1
  62. package/dist/powerlines/src/lib/unplugin/helpers.cjs +17 -1
  63. package/dist/powerlines/src/lib/unplugin/helpers.mjs +16 -1
  64. package/dist/powerlines/src/lib/unplugin/index.cjs +3 -1
  65. package/dist/powerlines/src/lib/unplugin/index.mjs +5 -1
  66. package/dist/powerlines/src/lib/unplugin/plugin.cjs +127 -5
  67. package/dist/powerlines/src/lib/unplugin/plugin.mjs +126 -5
  68. package/dist/powerlines/src/lib/utilities/file-header.cjs +19 -7
  69. package/dist/powerlines/src/lib/utilities/file-header.mjs +18 -7
  70. package/dist/powerlines/src/lib/utilities/meta.cjs +45 -1
  71. package/dist/powerlines/src/lib/utilities/meta.mjs +41 -1
  72. package/dist/powerlines/src/lib/utilities/source-file.cjs +22 -1
  73. package/dist/powerlines/src/lib/utilities/source-file.mjs +21 -1
  74. package/dist/powerlines/src/plugin-utils/helpers.cjs +148 -1
  75. package/dist/powerlines/src/plugin-utils/helpers.mjs +138 -1
  76. package/dist/powerlines/src/plugin-utils/paths.cjs +36 -1
  77. package/dist/powerlines/src/plugin-utils/paths.mjs +35 -1
  78. package/dist/powerlines/src/types/build.cjs +15 -1
  79. package/dist/powerlines/src/types/build.mjs +14 -1
  80. package/dist/powerlines/src/types/commands.cjs +16 -1
  81. package/dist/powerlines/src/types/commands.mjs +15 -1
  82. package/dist/powerlines/src/types/config.d.mts +0 -1
  83. package/dist/powerlines/src/types/context.d.cts +27 -3
  84. package/dist/powerlines/src/types/context.d.mts +27 -3
  85. package/dist/powerlines/src/types/plugin.cjs +32 -1
  86. package/dist/powerlines/src/types/plugin.mjs +31 -1
  87. package/dist/types/index.mjs +1 -1
  88. package/dist/types/plugin.mjs +1 -1
  89. package/package.json +10 -10
@@ -1,8 +1,98 @@
1
- const e=require(`../../../../_virtual/rolldown_runtime.cjs`),t=require(`../../lib/typescript/tsconfig.cjs`);let n=require(`@stryke/path/join-paths`),r=require(`@storm-software/config-tools/types`),i=require(`@stryke/fs/package-fns`),a=require(`chalk`);a=e.__toESM(a);let o=require(`@donedeal0/superdiff`),s=require(`@stryke/fs/json`),c=require(`@stryke/json/storm-json`),l=require(`@stryke/path/file-path-fns`),u=require(`@stryke/string-format/title-case`);function d(e){return(0,n.joinPaths)((0,l.relativePath)((0,n.joinPaths)(e.workspaceConfig.workspaceRoot,e.config.projectRoot),(0,l.findFilePath)(e.dtsPath)),(0,l.findFileName)(e.dtsPath))}async function f(e){let n=t.getParsedTypeScriptConfig(e.workspaceConfig.workspaceRoot,e.config.projectRoot,e.config.tsconfig,e.config.tsconfigRaw),r=await(0,s.readJsonFile)(t.getTsconfigFilePath(e.workspaceConfig.workspaceRoot,e.config.projectRoot,e.config.tsconfig));if(r.compilerOptions??={},e.config.output.dts!==!1){let n=d(e);r.include?.some(r=>t.isIncludeMatchFound(r,[e.dtsPath,n]))||(r.include??=[],r.include.push(n.startsWith(`./`)?n.slice(2):n))}return n.options.lib?.some(e=>[`lib.esnext.d.ts`,`lib.es2021.d.ts`,`lib.es2022.d.ts`,`lib.es2023.d.ts`].includes(e.toLowerCase()))||(r.compilerOptions.lib??=[],r.compilerOptions.lib.push(`esnext`)),n.options.esModuleInterop!==!0&&(r.compilerOptions.esModuleInterop=!0),n.options.isolatedModules!==!0&&(r.compilerOptions.isolatedModules=!0),e.config.build.platform===`node`&&(n.options.types?.some(e=>e.toLowerCase()===`node`||e.toLowerCase()===`@types/node`)||(r.compilerOptions.types??=[],r.compilerOptions.types.push(`node`))),r}async function p(e){if(e.log(r.LogLevelLabel.TRACE,`Initializing TypeScript configuration (tsconfig.json) for the Powerlines project.`),!(0,i.isPackageExists)(`typescript`))throw Error(`The TypeScript package is not installed. Please install the package using the command: "npm install typescript --save-dev"`);let n=t.getTsconfigFilePath(e.workspaceConfig.workspaceRoot,e.config.projectRoot,e.config.tsconfig);e.tsconfig.originalTsconfigJson=await(0,s.readJsonFile)(n),e.tsconfig.tsconfigJson=await f(e),e.log(r.LogLevelLabel.TRACE,`Writing updated TypeScript configuration (tsconfig.json) file to disk.`),await e.fs.write(n,c.StormJSON.stringify(e.tsconfig.tsconfigJson)),e.tsconfig=t.getParsedTypeScriptConfig(e.workspaceConfig.workspaceRoot,e.config.projectRoot,e.config.tsconfig,e.config.tsconfigRaw,e.tsconfig.originalTsconfigJson)}async function m(e){let n=await(0,s.readJsonFile)(e.tsconfig.tsconfigFilePath);n?.compilerOptions?.types&&Array.isArray(n.compilerOptions.types)&&!n.compilerOptions.types.length&&delete n.compilerOptions.types;let i=(0,o.getObjectDiff)(e.tsconfig.originalTsconfigJson,n,{ignoreArrayOrder:!0,showOnly:{statuses:[`added`,`deleted`,`updated`],granularity:`deep`}}),l=[],d=(e,t)=>{if(e.status===`added`||e.status===`deleted`||e.status===`updated`)if(e.diff)for(let n of e.diff)d(n,t?`${t}.${e.property}`:e.property);else l.push({field:t?`${t}.${e.property}`:e.property,status:e.status,previous:e.status===`added`?`---`:c.StormJSON.stringify(e.previousValue),current:e.status===`deleted`?`---`:c.StormJSON.stringify(e.currentValue)})};for(let e of i.diff)d(e);if(l.length>0&&e.log(r.LogLevelLabel.WARN,`Updating the following configuration values in "${e.tsconfig.tsconfigFilePath}" file:
1
+ const require_rolldown_runtime = require('../../../../_virtual/rolldown_runtime.cjs');
2
+ const require_tsconfig = require('../../lib/typescript/tsconfig.cjs');
3
+ let __stryke_path_join_paths = require("@stryke/path/join-paths");
4
+ let __storm_software_config_tools_types = require("@storm-software/config-tools/types");
5
+ let __stryke_fs_package_fns = require("@stryke/fs/package-fns");
6
+ let chalk = require("chalk");
7
+ chalk = require_rolldown_runtime.__toESM(chalk);
8
+ let __donedeal0_superdiff = require("@donedeal0/superdiff");
9
+ let __stryke_fs_json = require("@stryke/fs/json");
10
+ let __stryke_json_storm_json = require("@stryke/json/storm-json");
11
+ let __stryke_path_file_path_fns = require("@stryke/path/file-path-fns");
12
+ let __stryke_string_format_title_case = require("@stryke/string-format/title-case");
2
13
 
3
- ${l.map((e,t)=>`${a.default.bold.whiteBright(`${t+1}. ${(0,u.titleCase)(e.status)} the ${e.field} field: `)}
4
- ${a.default.red(` - Previous: ${e.previous} `)}
5
- ${a.default.green(` - Updated: ${e.current} `)}
6
- `).join(`
7
- `)}
8
- `),await e.fs.write(e.tsconfig.tsconfigFilePath,c.StormJSON.stringify(n)),e.tsconfig=t.getParsedTypeScriptConfig(e.workspaceConfig.workspaceRoot,e.config.projectRoot,e.config.tsconfig),!e.tsconfig)throw Error(`Failed to parse the TypeScript configuration file.`)}exports.getTsconfigDtsPath=d,exports.initializeTsconfig=p,exports.resolveTsconfig=m;
14
+ //#region ../powerlines/src/internal/helpers/resolve-tsconfig.ts
15
+ function getTsconfigDtsPath(context) {
16
+ return (0, __stryke_path_join_paths.joinPaths)((0, __stryke_path_file_path_fns.relativePath)((0, __stryke_path_join_paths.joinPaths)(context.workspaceConfig.workspaceRoot, context.config.projectRoot), (0, __stryke_path_file_path_fns.findFilePath)(context.dtsPath)), (0, __stryke_path_file_path_fns.findFileName)(context.dtsPath));
17
+ }
18
+ async function resolveTsconfigChanges(context) {
19
+ const tsconfig = require_tsconfig.getParsedTypeScriptConfig(context.workspaceConfig.workspaceRoot, context.config.projectRoot, context.config.tsconfig, context.config.tsconfigRaw);
20
+ const tsconfigJson = await (0, __stryke_fs_json.readJsonFile)(require_tsconfig.getTsconfigFilePath(context.workspaceConfig.workspaceRoot, context.config.projectRoot, context.config.tsconfig));
21
+ tsconfigJson.compilerOptions ??= {};
22
+ if (context.config.output.dts !== false) {
23
+ const dtsRelativePath = getTsconfigDtsPath(context);
24
+ if (!tsconfigJson.include?.some((filePattern) => require_tsconfig.isIncludeMatchFound(filePattern, [context.dtsPath, dtsRelativePath]))) {
25
+ tsconfigJson.include ??= [];
26
+ tsconfigJson.include.push(dtsRelativePath.startsWith("./") ? dtsRelativePath.slice(2) : dtsRelativePath);
27
+ }
28
+ }
29
+ if (!tsconfig.options.lib?.some((lib) => [
30
+ "lib.esnext.d.ts",
31
+ "lib.es2021.d.ts",
32
+ "lib.es2022.d.ts",
33
+ "lib.es2023.d.ts"
34
+ ].includes(lib.toLowerCase()))) {
35
+ tsconfigJson.compilerOptions.lib ??= [];
36
+ tsconfigJson.compilerOptions.lib.push("esnext");
37
+ }
38
+ if (tsconfig.options.esModuleInterop !== true) tsconfigJson.compilerOptions.esModuleInterop = true;
39
+ if (tsconfig.options.isolatedModules !== true) tsconfigJson.compilerOptions.isolatedModules = true;
40
+ if (context.config.build.platform === "node") {
41
+ if (!tsconfig.options.types?.some((type) => type.toLowerCase() === "node" || type.toLowerCase() === "@types/node")) {
42
+ tsconfigJson.compilerOptions.types ??= [];
43
+ tsconfigJson.compilerOptions.types.push("node");
44
+ }
45
+ }
46
+ return tsconfigJson;
47
+ }
48
+ async function initializeTsconfig(context) {
49
+ context.log(__storm_software_config_tools_types.LogLevelLabel.TRACE, "Initializing TypeScript configuration (tsconfig.json) for the Powerlines project.");
50
+ if (!(0, __stryke_fs_package_fns.isPackageExists)("typescript")) throw new Error("The TypeScript package is not installed. Please install the package using the command: \"npm install typescript --save-dev\"");
51
+ const tsconfigFilePath = require_tsconfig.getTsconfigFilePath(context.workspaceConfig.workspaceRoot, context.config.projectRoot, context.config.tsconfig);
52
+ context.tsconfig.originalTsconfigJson = await (0, __stryke_fs_json.readJsonFile)(tsconfigFilePath);
53
+ context.tsconfig.tsconfigJson = await resolveTsconfigChanges(context);
54
+ context.log(__storm_software_config_tools_types.LogLevelLabel.TRACE, "Writing updated TypeScript configuration (tsconfig.json) file to disk.");
55
+ await context.fs.write(tsconfigFilePath, __stryke_json_storm_json.StormJSON.stringify(context.tsconfig.tsconfigJson));
56
+ context.tsconfig = require_tsconfig.getParsedTypeScriptConfig(context.workspaceConfig.workspaceRoot, context.config.projectRoot, context.config.tsconfig, context.config.tsconfigRaw, context.tsconfig.originalTsconfigJson);
57
+ }
58
+ async function resolveTsconfig(context) {
59
+ const updateTsconfigJson = await (0, __stryke_fs_json.readJsonFile)(context.tsconfig.tsconfigFilePath);
60
+ if (updateTsconfigJson?.compilerOptions?.types && Array.isArray(updateTsconfigJson.compilerOptions.types) && !updateTsconfigJson.compilerOptions.types.length) delete updateTsconfigJson.compilerOptions.types;
61
+ const result = (0, __donedeal0_superdiff.getObjectDiff)(context.tsconfig.originalTsconfigJson, updateTsconfigJson, {
62
+ ignoreArrayOrder: true,
63
+ showOnly: {
64
+ statuses: [
65
+ "added",
66
+ "deleted",
67
+ "updated"
68
+ ],
69
+ granularity: "deep"
70
+ }
71
+ });
72
+ const changes = [];
73
+ const getChanges = (difference, property) => {
74
+ if (difference.status === "added" || difference.status === "deleted" || difference.status === "updated") if (difference.diff) for (const diff of difference.diff) getChanges(diff, property ? `${property}.${difference.property}` : difference.property);
75
+ else changes.push({
76
+ field: property ? `${property}.${difference.property}` : difference.property,
77
+ status: difference.status,
78
+ previous: difference.status === "added" ? "---" : __stryke_json_storm_json.StormJSON.stringify(difference.previousValue),
79
+ current: difference.status === "deleted" ? "---" : __stryke_json_storm_json.StormJSON.stringify(difference.currentValue)
80
+ });
81
+ };
82
+ for (const diff of result.diff) getChanges(diff);
83
+ if (changes.length > 0) context.log(__storm_software_config_tools_types.LogLevelLabel.WARN, `Updating the following configuration values in "${context.tsconfig.tsconfigFilePath}" file:
84
+
85
+ ${changes.map((change, i) => `${chalk.default.bold.whiteBright(`${i + 1}. ${(0, __stryke_string_format_title_case.titleCase)(change.status)} the ${change.field} field: `)}
86
+ ${chalk.default.red(` - Previous: ${change.previous} `)}
87
+ ${chalk.default.green(` - Updated: ${change.current} `)}
88
+ `).join("\n")}
89
+ `);
90
+ await context.fs.write(context.tsconfig.tsconfigFilePath, __stryke_json_storm_json.StormJSON.stringify(updateTsconfigJson));
91
+ context.tsconfig = require_tsconfig.getParsedTypeScriptConfig(context.workspaceConfig.workspaceRoot, context.config.projectRoot, context.config.tsconfig);
92
+ if (!context.tsconfig) throw new Error("Failed to parse the TypeScript configuration file.");
93
+ }
94
+
95
+ //#endregion
96
+ exports.getTsconfigDtsPath = getTsconfigDtsPath;
97
+ exports.initializeTsconfig = initializeTsconfig;
98
+ exports.resolveTsconfig = resolveTsconfig;
@@ -1,8 +1,94 @@
1
- import{getParsedTypeScriptConfig as e,getTsconfigFilePath as t,isIncludeMatchFound as n}from"../../lib/typescript/tsconfig.mjs";import{joinPaths as r}from"@stryke/path/join-paths";import{LogLevelLabel as i}from"@storm-software/config-tools/types";import{isPackageExists as a}from"@stryke/fs/package-fns";import o from"chalk";import{getObjectDiff as s}from"@donedeal0/superdiff";import{readJsonFile as c}from"@stryke/fs/json";import{StormJSON as l}from"@stryke/json/storm-json";import{findFileName as u,findFilePath as d,relativePath as f}from"@stryke/path/file-path-fns";import{titleCase as p}from"@stryke/string-format/title-case";function m(e){return r(f(r(e.workspaceConfig.workspaceRoot,e.config.projectRoot),d(e.dtsPath)),u(e.dtsPath))}async function h(r){let i=e(r.workspaceConfig.workspaceRoot,r.config.projectRoot,r.config.tsconfig,r.config.tsconfigRaw),a=await c(t(r.workspaceConfig.workspaceRoot,r.config.projectRoot,r.config.tsconfig));if(a.compilerOptions??={},r.config.output.dts!==!1){let e=m(r);a.include?.some(t=>n(t,[r.dtsPath,e]))||(a.include??=[],a.include.push(e.startsWith(`./`)?e.slice(2):e))}return i.options.lib?.some(e=>[`lib.esnext.d.ts`,`lib.es2021.d.ts`,`lib.es2022.d.ts`,`lib.es2023.d.ts`].includes(e.toLowerCase()))||(a.compilerOptions.lib??=[],a.compilerOptions.lib.push(`esnext`)),i.options.esModuleInterop!==!0&&(a.compilerOptions.esModuleInterop=!0),i.options.isolatedModules!==!0&&(a.compilerOptions.isolatedModules=!0),r.config.build.platform===`node`&&(i.options.types?.some(e=>e.toLowerCase()===`node`||e.toLowerCase()===`@types/node`)||(a.compilerOptions.types??=[],a.compilerOptions.types.push(`node`))),a}async function g(n){if(n.log(i.TRACE,`Initializing TypeScript configuration (tsconfig.json) for the Powerlines project.`),!a(`typescript`))throw Error(`The TypeScript package is not installed. Please install the package using the command: "npm install typescript --save-dev"`);let r=t(n.workspaceConfig.workspaceRoot,n.config.projectRoot,n.config.tsconfig);n.tsconfig.originalTsconfigJson=await c(r),n.tsconfig.tsconfigJson=await h(n),n.log(i.TRACE,`Writing updated TypeScript configuration (tsconfig.json) file to disk.`),await n.fs.write(r,l.stringify(n.tsconfig.tsconfigJson)),n.tsconfig=e(n.workspaceConfig.workspaceRoot,n.config.projectRoot,n.config.tsconfig,n.config.tsconfigRaw,n.tsconfig.originalTsconfigJson)}async function _(t){let n=await c(t.tsconfig.tsconfigFilePath);n?.compilerOptions?.types&&Array.isArray(n.compilerOptions.types)&&!n.compilerOptions.types.length&&delete n.compilerOptions.types;let r=s(t.tsconfig.originalTsconfigJson,n,{ignoreArrayOrder:!0,showOnly:{statuses:[`added`,`deleted`,`updated`],granularity:`deep`}}),a=[],u=(e,t)=>{if(e.status===`added`||e.status===`deleted`||e.status===`updated`)if(e.diff)for(let n of e.diff)u(n,t?`${t}.${e.property}`:e.property);else a.push({field:t?`${t}.${e.property}`:e.property,status:e.status,previous:e.status===`added`?`---`:l.stringify(e.previousValue),current:e.status===`deleted`?`---`:l.stringify(e.currentValue)})};for(let e of r.diff)u(e);if(a.length>0&&t.log(i.WARN,`Updating the following configuration values in "${t.tsconfig.tsconfigFilePath}" file:
1
+ import { getParsedTypeScriptConfig, getTsconfigFilePath, isIncludeMatchFound } from "../../lib/typescript/tsconfig.mjs";
2
+ import { joinPaths } from "@stryke/path/join-paths";
3
+ import { LogLevelLabel } from "@storm-software/config-tools/types";
4
+ import { isPackageExists } from "@stryke/fs/package-fns";
5
+ import chalk from "chalk";
6
+ import { getObjectDiff } from "@donedeal0/superdiff";
7
+ import { readJsonFile } from "@stryke/fs/json";
8
+ import { StormJSON } from "@stryke/json/storm-json";
9
+ import { findFileName, findFilePath, relativePath } from "@stryke/path/file-path-fns";
10
+ import { titleCase } from "@stryke/string-format/title-case";
2
11
 
3
- ${a.map((e,t)=>`${o.bold.whiteBright(`${t+1}. ${p(e.status)} the ${e.field} field: `)}
4
- ${o.red(` - Previous: ${e.previous} `)}
5
- ${o.green(` - Updated: ${e.current} `)}
6
- `).join(`
7
- `)}
8
- `),await t.fs.write(t.tsconfig.tsconfigFilePath,l.stringify(n)),t.tsconfig=e(t.workspaceConfig.workspaceRoot,t.config.projectRoot,t.config.tsconfig),!t.tsconfig)throw Error(`Failed to parse the TypeScript configuration file.`)}export{m as getTsconfigDtsPath,g as initializeTsconfig,_ as resolveTsconfig};
12
+ //#region ../powerlines/src/internal/helpers/resolve-tsconfig.ts
13
+ function getTsconfigDtsPath(context) {
14
+ return joinPaths(relativePath(joinPaths(context.workspaceConfig.workspaceRoot, context.config.projectRoot), findFilePath(context.dtsPath)), findFileName(context.dtsPath));
15
+ }
16
+ async function resolveTsconfigChanges(context) {
17
+ const tsconfig = getParsedTypeScriptConfig(context.workspaceConfig.workspaceRoot, context.config.projectRoot, context.config.tsconfig, context.config.tsconfigRaw);
18
+ const tsconfigJson = await readJsonFile(getTsconfigFilePath(context.workspaceConfig.workspaceRoot, context.config.projectRoot, context.config.tsconfig));
19
+ tsconfigJson.compilerOptions ??= {};
20
+ if (context.config.output.dts !== false) {
21
+ const dtsRelativePath = getTsconfigDtsPath(context);
22
+ if (!tsconfigJson.include?.some((filePattern) => isIncludeMatchFound(filePattern, [context.dtsPath, dtsRelativePath]))) {
23
+ tsconfigJson.include ??= [];
24
+ tsconfigJson.include.push(dtsRelativePath.startsWith("./") ? dtsRelativePath.slice(2) : dtsRelativePath);
25
+ }
26
+ }
27
+ if (!tsconfig.options.lib?.some((lib) => [
28
+ "lib.esnext.d.ts",
29
+ "lib.es2021.d.ts",
30
+ "lib.es2022.d.ts",
31
+ "lib.es2023.d.ts"
32
+ ].includes(lib.toLowerCase()))) {
33
+ tsconfigJson.compilerOptions.lib ??= [];
34
+ tsconfigJson.compilerOptions.lib.push("esnext");
35
+ }
36
+ if (tsconfig.options.esModuleInterop !== true) tsconfigJson.compilerOptions.esModuleInterop = true;
37
+ if (tsconfig.options.isolatedModules !== true) tsconfigJson.compilerOptions.isolatedModules = true;
38
+ if (context.config.build.platform === "node") {
39
+ if (!tsconfig.options.types?.some((type) => type.toLowerCase() === "node" || type.toLowerCase() === "@types/node")) {
40
+ tsconfigJson.compilerOptions.types ??= [];
41
+ tsconfigJson.compilerOptions.types.push("node");
42
+ }
43
+ }
44
+ return tsconfigJson;
45
+ }
46
+ async function initializeTsconfig(context) {
47
+ context.log(LogLevelLabel.TRACE, "Initializing TypeScript configuration (tsconfig.json) for the Powerlines project.");
48
+ if (!isPackageExists("typescript")) throw new Error("The TypeScript package is not installed. Please install the package using the command: \"npm install typescript --save-dev\"");
49
+ const tsconfigFilePath = getTsconfigFilePath(context.workspaceConfig.workspaceRoot, context.config.projectRoot, context.config.tsconfig);
50
+ context.tsconfig.originalTsconfigJson = await readJsonFile(tsconfigFilePath);
51
+ context.tsconfig.tsconfigJson = await resolveTsconfigChanges(context);
52
+ context.log(LogLevelLabel.TRACE, "Writing updated TypeScript configuration (tsconfig.json) file to disk.");
53
+ await context.fs.write(tsconfigFilePath, StormJSON.stringify(context.tsconfig.tsconfigJson));
54
+ context.tsconfig = getParsedTypeScriptConfig(context.workspaceConfig.workspaceRoot, context.config.projectRoot, context.config.tsconfig, context.config.tsconfigRaw, context.tsconfig.originalTsconfigJson);
55
+ }
56
+ async function resolveTsconfig(context) {
57
+ const updateTsconfigJson = await readJsonFile(context.tsconfig.tsconfigFilePath);
58
+ if (updateTsconfigJson?.compilerOptions?.types && Array.isArray(updateTsconfigJson.compilerOptions.types) && !updateTsconfigJson.compilerOptions.types.length) delete updateTsconfigJson.compilerOptions.types;
59
+ const result = getObjectDiff(context.tsconfig.originalTsconfigJson, updateTsconfigJson, {
60
+ ignoreArrayOrder: true,
61
+ showOnly: {
62
+ statuses: [
63
+ "added",
64
+ "deleted",
65
+ "updated"
66
+ ],
67
+ granularity: "deep"
68
+ }
69
+ });
70
+ const changes = [];
71
+ const getChanges = (difference, property) => {
72
+ if (difference.status === "added" || difference.status === "deleted" || difference.status === "updated") if (difference.diff) for (const diff of difference.diff) getChanges(diff, property ? `${property}.${difference.property}` : difference.property);
73
+ else changes.push({
74
+ field: property ? `${property}.${difference.property}` : difference.property,
75
+ status: difference.status,
76
+ previous: difference.status === "added" ? "---" : StormJSON.stringify(difference.previousValue),
77
+ current: difference.status === "deleted" ? "---" : StormJSON.stringify(difference.currentValue)
78
+ });
79
+ };
80
+ for (const diff of result.diff) getChanges(diff);
81
+ if (changes.length > 0) context.log(LogLevelLabel.WARN, `Updating the following configuration values in "${context.tsconfig.tsconfigFilePath}" file:
82
+
83
+ ${changes.map((change, i) => `${chalk.bold.whiteBright(`${i + 1}. ${titleCase(change.status)} the ${change.field} field: `)}
84
+ ${chalk.red(` - Previous: ${change.previous} `)}
85
+ ${chalk.green(` - Updated: ${change.current} `)}
86
+ `).join("\n")}
87
+ `);
88
+ await context.fs.write(context.tsconfig.tsconfigFilePath, StormJSON.stringify(updateTsconfigJson));
89
+ context.tsconfig = getParsedTypeScriptConfig(context.workspaceConfig.workspaceRoot, context.config.projectRoot, context.config.tsconfig);
90
+ if (!context.tsconfig) throw new Error("Failed to parse the TypeScript configuration file.");
91
+ }
92
+
93
+ //#endregion
94
+ export { getTsconfigDtsPath, initializeTsconfig, resolveTsconfig };
@@ -1 +1,43 @@
1
- const e=require(`../../../../_virtual/rolldown_runtime.cjs`);let t=require(`defu`);t=e.__toESM(t);let n=require(`@stryke/path/join-paths`),r=require(`jiti`);function i(e){return(0,t.default)(e,{interopDefault:!0,fsCache:e.mode===`development`?!1:(0,n.joinPaths)(e.cacheDir,`jiti`),moduleCache:e.mode!==`development`})}function a(e){return(0,r.createJiti)((0,n.joinPaths)(e.workspaceRoot,e.projectRoot),i({...e}))}function o(e){let t=(0,r.createJiti)((0,n.joinPaths)(e.workspaceRoot,e.projectRoot),i(e));return t.plugin=a(e),t}exports.createResolver=o;
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_join_paths = require("@stryke/path/join-paths");
5
+ let jiti = require("jiti");
6
+
7
+ //#region ../powerlines/src/internal/helpers/resolver.ts
8
+ /**
9
+ * Create a Jiti resolver for the given workspace and project root.
10
+ *
11
+ * @param options - The options for creating the resolver.
12
+ * @returns A Jiti instance configured for the specified workspace and project root.
13
+ */
14
+ function resolveOptions(options) {
15
+ return (0, defu.default)(options, {
16
+ interopDefault: true,
17
+ fsCache: options.mode !== "development" ? (0, __stryke_path_join_paths.joinPaths)(options.cacheDir, "jiti") : false,
18
+ moduleCache: options.mode !== "development"
19
+ });
20
+ }
21
+ /**
22
+ * Create a Jiti resolver for the given workspace and project root.
23
+ *
24
+ * @param options - The options for creating the resolver.
25
+ * @returns A Jiti instance configured for the specified workspace and project root.
26
+ */
27
+ function createPluginResolver(options) {
28
+ return (0, jiti.createJiti)((0, __stryke_path_join_paths.joinPaths)(options.workspaceRoot, options.projectRoot), resolveOptions({ ...options }));
29
+ }
30
+ /**
31
+ * Create a Jiti resolver for the given workspace and project root.
32
+ *
33
+ * @param options - The options for creating the resolver.
34
+ * @returns A Jiti instance configured for the specified workspace and project root.
35
+ */
36
+ function createResolver(options) {
37
+ const baseResolver = (0, jiti.createJiti)((0, __stryke_path_join_paths.joinPaths)(options.workspaceRoot, options.projectRoot), resolveOptions(options));
38
+ baseResolver.plugin = createPluginResolver(options);
39
+ return baseResolver;
40
+ }
41
+
42
+ //#endregion
43
+ exports.createResolver = createResolver;
@@ -1 +1,41 @@
1
- import e from"defu";import{joinPaths as t}from"@stryke/path/join-paths";import{createJiti as n}from"jiti";function r(n){return e(n,{interopDefault:!0,fsCache:n.mode===`development`?!1:t(n.cacheDir,`jiti`),moduleCache:n.mode!==`development`})}function i(e){return n(t(e.workspaceRoot,e.projectRoot),r({...e}))}function a(e){let a=n(t(e.workspaceRoot,e.projectRoot),r(e));return a.plugin=i(e),a}export{a as createResolver};
1
+ import defu$1 from "defu";
2
+ import { joinPaths } from "@stryke/path/join-paths";
3
+ import { createJiti } from "jiti";
4
+
5
+ //#region ../powerlines/src/internal/helpers/resolver.ts
6
+ /**
7
+ * Create a Jiti resolver for the given workspace and project root.
8
+ *
9
+ * @param options - The options for creating the resolver.
10
+ * @returns A Jiti instance configured for the specified workspace and project root.
11
+ */
12
+ function resolveOptions(options) {
13
+ return defu$1(options, {
14
+ interopDefault: true,
15
+ fsCache: options.mode !== "development" ? joinPaths(options.cacheDir, "jiti") : false,
16
+ moduleCache: options.mode !== "development"
17
+ });
18
+ }
19
+ /**
20
+ * Create a Jiti resolver for the given workspace and project root.
21
+ *
22
+ * @param options - The options for creating the resolver.
23
+ * @returns A Jiti instance configured for the specified workspace and project root.
24
+ */
25
+ function createPluginResolver(options) {
26
+ return createJiti(joinPaths(options.workspaceRoot, options.projectRoot), resolveOptions({ ...options }));
27
+ }
28
+ /**
29
+ * Create a Jiti resolver for the given workspace and project root.
30
+ *
31
+ * @param options - The options for creating the resolver.
32
+ * @returns A Jiti instance configured for the specified workspace and project root.
33
+ */
34
+ function createResolver(options) {
35
+ const baseResolver = createJiti(joinPaths(options.workspaceRoot, options.projectRoot), resolveOptions(options));
36
+ baseResolver.plugin = createPluginResolver(options);
37
+ return baseResolver;
38
+ }
39
+
40
+ //#endregion
41
+ export { createResolver };
@@ -1 +1,125 @@
1
- const e=require(`../../../../_virtual/rolldown_runtime.cjs`),t=require(`./rollup.cjs`);let n=require(`@stryke/convert/to-array`),r=require(`defu`);r=e.__toESM(r);let i=require(`@rollup/plugin-babel`),a=require(`@rollup/plugin-inject`);a=e.__toESM(a);let o=require(`@rollup/plugin-node-resolve`);o=e.__toESM(o);let s=require(`@rollup/plugin-replace`);s=e.__toESM(s);let c=require(`@stryke/helpers/omit`),l=require(`@stryke/path/join-paths`),u=require(`@stryke/type-checks/is-function`),d=require(`@stryke/type-checks/is-string`),f=require(`node:fs`),p=require(`rolldown/experimental`),m=require(`rollup-plugin-typescript2`);m=e.__toESM(m);function h(e){return(0,r.default)({input:(0,f.globSync)((0,n.toArray)(e.entry).map(e=>(0,d.isString)(e)?e:e.file)).flat(),external:(t,r,i)=>{let a=e.config.build.variant===`rollup`&&e.config.build.override.external?(0,u.isFunction)(e.config.build.override.external)?e.config.build.override.external:t=>(0,n.toArray)(e.config.build.override.external).includes(t):e.config.build.variant===`vite`&&e.config.build.override?.build?.rollupOptions?.external?(0,u.isFunction)(e.config.build.override?.build?.rollupOptions?.external)?e.config.build.override?.build?.rollupOptions?.external:t=>(0,n.toArray)(e.config.build?.build?.rollupOptions?.external).includes(t):e.config.build.variant===`rollup`&&e.config.build.external?(0,u.isFunction)(e.config.build.external)?e.config.build.external:t=>(0,n.toArray)(e.config.build.external).includes(t):e.config.build.variant===`vite`&&e.config.build.build?.rollupOptions?.external?(0,u.isFunction)(e.config.build.build?.rollupOptions?.external)?e.config.build.build?.rollupOptions?.external:t=>(0,n.toArray)(e.config.build?.build?.rollupOptions?.external).includes(t):void 0;return(0,u.isFunction)(a)&&a(t,r,i)||e.config.build.external&&(0,n.toArray)(e.config.build.external).includes(t)?!0:e.config.build.noExternal&&(0,n.toArray)(e.config.build.noExternal).includes(t)?!1:e.builtins.includes(t)?e.config.projectType!==`application`:!e.config.build.skipNodeModulesBundle},plugins:[(0,m.default)({check:!1,tsconfig:e.tsconfig.tsconfigFilePath}),e.config.build.define&&Object.keys(e.config.build.define).length>0&&(0,s.default)({sourceMap:e.config.mode===`development`,preventAssignment:!0,...e.config.build.define??{}}),e.config.build.inject&&Object.keys(e.config.build.inject).length>0&&(0,a.default)({sourceMap:e.config.mode===`development`,...e.config.build.inject}),(0,p.viteAliasPlugin)({entries:e.builtins.reduce((t,n)=>{if(!t.find(e=>e.find===n)){let r=e.fs.ids[n];r&&t.push({find:n,replacement:r})}return t},e.config.build.alias?Array.isArray(e.config.build.alias)?e.config.build.alias:Object.entries(e.config.build.alias).reduce((e,[t,n])=>(e.find(e=>e.find===t)||e.push({find:t,replacement:n}),e),[]):[])}),(0,i.getBabelInputPlugin)((0,r.default)(e.config.transform.babel,{caller:{name:`powerlines`,supportsStaticESM:!0},cwd:e.config.projectRoot,babelrc:!1,extensions:[`.js`,`.jsx`,`.ts`,`.tsx`],babelHelpers:`bundled`,skipPreflightCheck:!0,exclude:/node_modules/})),(0,o.default)({moduleDirectories:[`node_modules`],preferBuiltins:!0}),t.dtsBundlePlugin]},e.config.build.variant===`rolldown`||e.config.build.variant===`rollup`?e.config.build.override:{},e.config.build.variant===`vite`?e.config.build.override.build?.rollupOptions:{},e.config.build.variant===`rolldown`||e.config.build.variant===`rollup`?(0,c.omit)(e.config.build,[`override`,`variant`]):{},e.config.build.variant===`vite`?e.config.build.build:{},{experimental:{viteMode:e.config.build.variant===`vite`},resolve:{mainFields:e.config.build.mainFields,conditions:e.config.build.conditions,define:e.config.build.define,extensions:e.config.build.extensions},platform:e.config.build.platform,tsconfig:e.tsconfig.tsconfigFilePath,cache:e.config.skipCache?!1:(0,l.joinPaths)(e.cachePath,`rolldown`),logLevel:e.config.logLevel,onLog:e.log,jsx:`automatic`,keepNames:!0,treeshake:!0,minify:e.config.mode===`production`,output:[{dir:e.config.output.buildPath,format:`es`,preserveModules:!0,sourcemap:e.config.mode===`development`},{dir:e.config.output.buildPath,format:`cjs`,preserveModules:!0,sourcemap:e.config.mode===`development`}]})}exports.extractRolldownConfig=h;
1
+ const require_rolldown_runtime = require('../../../../_virtual/rolldown_runtime.cjs');
2
+ const require_rollup = require('./rollup.cjs');
3
+ let __stryke_convert_to_array = require("@stryke/convert/to-array");
4
+ let defu = require("defu");
5
+ defu = require_rolldown_runtime.__toESM(defu);
6
+ let __rollup_plugin_babel = require("@rollup/plugin-babel");
7
+ let __rollup_plugin_inject = require("@rollup/plugin-inject");
8
+ __rollup_plugin_inject = require_rolldown_runtime.__toESM(__rollup_plugin_inject);
9
+ let __rollup_plugin_node_resolve = require("@rollup/plugin-node-resolve");
10
+ __rollup_plugin_node_resolve = require_rolldown_runtime.__toESM(__rollup_plugin_node_resolve);
11
+ let __rollup_plugin_replace = require("@rollup/plugin-replace");
12
+ __rollup_plugin_replace = require_rolldown_runtime.__toESM(__rollup_plugin_replace);
13
+ let __stryke_helpers_omit = require("@stryke/helpers/omit");
14
+ let __stryke_path_join_paths = require("@stryke/path/join-paths");
15
+ let __stryke_type_checks_is_function = require("@stryke/type-checks/is-function");
16
+ let __stryke_type_checks_is_string = require("@stryke/type-checks/is-string");
17
+ let node_fs = require("node:fs");
18
+ let rolldown_experimental = require("rolldown/experimental");
19
+ let rollup_plugin_typescript2 = require("rollup-plugin-typescript2");
20
+ rollup_plugin_typescript2 = require_rolldown_runtime.__toESM(rollup_plugin_typescript2);
21
+
22
+ //#region ../powerlines/src/lib/build/rolldown.ts
23
+ /**
24
+ * Resolves the options for [rolldown](https://rolldown.rs).
25
+ *
26
+ * @param context - The build context.
27
+ * @returns The resolved options.
28
+ */
29
+ function extractRolldownConfig(context) {
30
+ return (0, defu.default)({
31
+ input: (0, node_fs.globSync)((0, __stryke_convert_to_array.toArray)(context.entry).map((entry) => (0, __stryke_type_checks_is_string.isString)(entry) ? entry : entry.file)).flat(),
32
+ external: (source, importer, isResolved) => {
33
+ const externalFn = context.config.build.variant === "rollup" && context.config.build.override.external ? (0, __stryke_type_checks_is_function.isFunction)(context.config.build.override.external) ? context.config.build.override.external : (id) => (0, __stryke_convert_to_array.toArray)(context.config.build.override.external).includes(id) : context.config.build.variant === "vite" && context.config.build.override?.build?.rollupOptions?.external ? (0, __stryke_type_checks_is_function.isFunction)(context.config.build.override?.build?.rollupOptions?.external) ? context.config.build.override?.build?.rollupOptions?.external : (id) => (0, __stryke_convert_to_array.toArray)(context.config.build?.build?.rollupOptions?.external).includes(id) : context.config.build.variant === "rollup" && context.config.build.external ? (0, __stryke_type_checks_is_function.isFunction)(context.config.build.external) ? context.config.build.external : (id) => (0, __stryke_convert_to_array.toArray)(context.config.build.external).includes(id) : context.config.build.variant === "vite" && context.config.build.build?.rollupOptions?.external ? (0, __stryke_type_checks_is_function.isFunction)(context.config.build.build?.rollupOptions?.external) ? context.config.build.build?.rollupOptions?.external : (id) => (0, __stryke_convert_to_array.toArray)(context.config.build?.build?.rollupOptions?.external).includes(id) : void 0;
34
+ if ((0, __stryke_type_checks_is_function.isFunction)(externalFn) && externalFn(source, importer, isResolved)) return true;
35
+ if (context.config.build.external && (0, __stryke_convert_to_array.toArray)(context.config.build.external).includes(source)) return true;
36
+ if (context.config.build.noExternal && (0, __stryke_convert_to_array.toArray)(context.config.build.noExternal).includes(source)) return false;
37
+ if (context.builtins.includes(source)) return context.config.projectType !== "application";
38
+ return !context.config.build.skipNodeModulesBundle;
39
+ },
40
+ plugins: [
41
+ (0, rollup_plugin_typescript2.default)({
42
+ check: false,
43
+ tsconfig: context.tsconfig.tsconfigFilePath
44
+ }),
45
+ context.config.build.define && Object.keys(context.config.build.define).length > 0 && (0, __rollup_plugin_replace.default)({
46
+ sourceMap: context.config.mode === "development",
47
+ preventAssignment: true,
48
+ ...context.config.build.define ?? {}
49
+ }),
50
+ context.config.build.inject && Object.keys(context.config.build.inject).length > 0 && (0, __rollup_plugin_inject.default)({
51
+ sourceMap: context.config.mode === "development",
52
+ ...context.config.build.inject
53
+ }),
54
+ (0, rolldown_experimental.viteAliasPlugin)({ entries: context.builtins.reduce((ret, id) => {
55
+ if (!ret.find((e) => e.find === id)) {
56
+ const path = context.fs.ids[id];
57
+ if (path) ret.push({
58
+ find: id,
59
+ replacement: path
60
+ });
61
+ }
62
+ return ret;
63
+ }, context.config.build.alias ? Array.isArray(context.config.build.alias) ? context.config.build.alias : Object.entries(context.config.build.alias).reduce((ret, [id, path]) => {
64
+ if (!ret.find((e) => e.find === id)) ret.push({
65
+ find: id,
66
+ replacement: path
67
+ });
68
+ return ret;
69
+ }, []) : []) }),
70
+ (0, __rollup_plugin_babel.getBabelInputPlugin)((0, defu.default)(context.config.transform.babel, {
71
+ caller: {
72
+ name: "powerlines",
73
+ supportsStaticESM: true
74
+ },
75
+ cwd: context.config.projectRoot,
76
+ babelrc: false,
77
+ extensions: [
78
+ ".js",
79
+ ".jsx",
80
+ ".ts",
81
+ ".tsx"
82
+ ],
83
+ babelHelpers: "bundled",
84
+ skipPreflightCheck: true,
85
+ exclude: /node_modules/
86
+ })),
87
+ (0, __rollup_plugin_node_resolve.default)({
88
+ moduleDirectories: ["node_modules"],
89
+ preferBuiltins: true
90
+ }),
91
+ require_rollup.dtsBundlePlugin
92
+ ]
93
+ }, context.config.build.variant === "rolldown" || context.config.build.variant === "rollup" ? context.config.build.override : {}, context.config.build.variant === "vite" ? context.config.build.override.build?.rollupOptions : {}, context.config.build.variant === "rolldown" || context.config.build.variant === "rollup" ? (0, __stryke_helpers_omit.omit)(context.config.build, ["override", "variant"]) : {}, context.config.build.variant === "vite" ? context.config.build.build : {}, {
94
+ experimental: { viteMode: context.config.build.variant === "vite" },
95
+ resolve: {
96
+ mainFields: context.config.build.mainFields,
97
+ conditions: context.config.build.conditions,
98
+ define: context.config.build.define,
99
+ extensions: context.config.build.extensions
100
+ },
101
+ platform: context.config.build.platform,
102
+ tsconfig: context.tsconfig.tsconfigFilePath,
103
+ cache: !context.config.skipCache ? (0, __stryke_path_join_paths.joinPaths)(context.cachePath, "rolldown") : false,
104
+ logLevel: context.config.logLevel,
105
+ onLog: context.log,
106
+ jsx: "automatic",
107
+ keepNames: true,
108
+ treeshake: true,
109
+ minify: context.config.mode === "production",
110
+ output: [{
111
+ dir: context.config.output.buildPath,
112
+ format: "es",
113
+ preserveModules: true,
114
+ sourcemap: context.config.mode === "development"
115
+ }, {
116
+ dir: context.config.output.buildPath,
117
+ format: "cjs",
118
+ preserveModules: true,
119
+ sourcemap: context.config.mode === "development"
120
+ }]
121
+ });
122
+ }
123
+
124
+ //#endregion
125
+ exports.extractRolldownConfig = extractRolldownConfig;
@@ -1 +1,119 @@
1
- import{dtsBundlePlugin as e}from"./rollup.mjs";import{toArray as t}from"@stryke/convert/to-array";import n from"defu";import{getBabelInputPlugin as r}from"@rollup/plugin-babel";import i from"@rollup/plugin-inject";import a from"@rollup/plugin-node-resolve";import o from"@rollup/plugin-replace";import{omit as s}from"@stryke/helpers/omit";import{joinPaths as c}from"@stryke/path/join-paths";import{isFunction as l}from"@stryke/type-checks/is-function";import{isString as u}from"@stryke/type-checks/is-string";import{globSync as d}from"node:fs";import{viteAliasPlugin as f}from"rolldown/experimental";import p from"rollup-plugin-typescript2";function m(m){return n({input:d(t(m.entry).map(e=>u(e)?e:e.file)).flat(),external:(e,n,r)=>{let i=m.config.build.variant===`rollup`&&m.config.build.override.external?l(m.config.build.override.external)?m.config.build.override.external:e=>t(m.config.build.override.external).includes(e):m.config.build.variant===`vite`&&m.config.build.override?.build?.rollupOptions?.external?l(m.config.build.override?.build?.rollupOptions?.external)?m.config.build.override?.build?.rollupOptions?.external:e=>t(m.config.build?.build?.rollupOptions?.external).includes(e):m.config.build.variant===`rollup`&&m.config.build.external?l(m.config.build.external)?m.config.build.external:e=>t(m.config.build.external).includes(e):m.config.build.variant===`vite`&&m.config.build.build?.rollupOptions?.external?l(m.config.build.build?.rollupOptions?.external)?m.config.build.build?.rollupOptions?.external:e=>t(m.config.build?.build?.rollupOptions?.external).includes(e):void 0;return l(i)&&i(e,n,r)||m.config.build.external&&t(m.config.build.external).includes(e)?!0:m.config.build.noExternal&&t(m.config.build.noExternal).includes(e)?!1:m.builtins.includes(e)?m.config.projectType!==`application`:!m.config.build.skipNodeModulesBundle},plugins:[p({check:!1,tsconfig:m.tsconfig.tsconfigFilePath}),m.config.build.define&&Object.keys(m.config.build.define).length>0&&o({sourceMap:m.config.mode===`development`,preventAssignment:!0,...m.config.build.define??{}}),m.config.build.inject&&Object.keys(m.config.build.inject).length>0&&i({sourceMap:m.config.mode===`development`,...m.config.build.inject}),f({entries:m.builtins.reduce((e,t)=>{if(!e.find(e=>e.find===t)){let n=m.fs.ids[t];n&&e.push({find:t,replacement:n})}return e},m.config.build.alias?Array.isArray(m.config.build.alias)?m.config.build.alias:Object.entries(m.config.build.alias).reduce((e,[t,n])=>(e.find(e=>e.find===t)||e.push({find:t,replacement:n}),e),[]):[])}),r(n(m.config.transform.babel,{caller:{name:`powerlines`,supportsStaticESM:!0},cwd:m.config.projectRoot,babelrc:!1,extensions:[`.js`,`.jsx`,`.ts`,`.tsx`],babelHelpers:`bundled`,skipPreflightCheck:!0,exclude:/node_modules/})),a({moduleDirectories:[`node_modules`],preferBuiltins:!0}),e]},m.config.build.variant===`rolldown`||m.config.build.variant===`rollup`?m.config.build.override:{},m.config.build.variant===`vite`?m.config.build.override.build?.rollupOptions:{},m.config.build.variant===`rolldown`||m.config.build.variant===`rollup`?s(m.config.build,[`override`,`variant`]):{},m.config.build.variant===`vite`?m.config.build.build:{},{experimental:{viteMode:m.config.build.variant===`vite`},resolve:{mainFields:m.config.build.mainFields,conditions:m.config.build.conditions,define:m.config.build.define,extensions:m.config.build.extensions},platform:m.config.build.platform,tsconfig:m.tsconfig.tsconfigFilePath,cache:m.config.skipCache?!1:c(m.cachePath,`rolldown`),logLevel:m.config.logLevel,onLog:m.log,jsx:`automatic`,keepNames:!0,treeshake:!0,minify:m.config.mode===`production`,output:[{dir:m.config.output.buildPath,format:`es`,preserveModules:!0,sourcemap:m.config.mode===`development`},{dir:m.config.output.buildPath,format:`cjs`,preserveModules:!0,sourcemap:m.config.mode===`development`}]})}export{m as extractRolldownConfig};
1
+ import { dtsBundlePlugin } from "./rollup.mjs";
2
+ import { toArray } from "@stryke/convert/to-array";
3
+ import defu$1 from "defu";
4
+ import { getBabelInputPlugin } from "@rollup/plugin-babel";
5
+ import inject from "@rollup/plugin-inject";
6
+ import resolve from "@rollup/plugin-node-resolve";
7
+ import replace from "@rollup/plugin-replace";
8
+ import { omit } from "@stryke/helpers/omit";
9
+ import { joinPaths } from "@stryke/path/join-paths";
10
+ import { isFunction } from "@stryke/type-checks/is-function";
11
+ import { isString } from "@stryke/type-checks/is-string";
12
+ import { globSync } from "node:fs";
13
+ import { viteAliasPlugin } from "rolldown/experimental";
14
+ import typescriptPlugin from "rollup-plugin-typescript2";
15
+
16
+ //#region ../powerlines/src/lib/build/rolldown.ts
17
+ /**
18
+ * Resolves the options for [rolldown](https://rolldown.rs).
19
+ *
20
+ * @param context - The build context.
21
+ * @returns The resolved options.
22
+ */
23
+ function extractRolldownConfig(context) {
24
+ return defu$1({
25
+ input: globSync(toArray(context.entry).map((entry) => isString(entry) ? entry : entry.file)).flat(),
26
+ external: (source, importer, isResolved) => {
27
+ const externalFn = context.config.build.variant === "rollup" && context.config.build.override.external ? isFunction(context.config.build.override.external) ? context.config.build.override.external : (id) => toArray(context.config.build.override.external).includes(id) : context.config.build.variant === "vite" && context.config.build.override?.build?.rollupOptions?.external ? isFunction(context.config.build.override?.build?.rollupOptions?.external) ? context.config.build.override?.build?.rollupOptions?.external : (id) => toArray(context.config.build?.build?.rollupOptions?.external).includes(id) : context.config.build.variant === "rollup" && context.config.build.external ? isFunction(context.config.build.external) ? context.config.build.external : (id) => toArray(context.config.build.external).includes(id) : context.config.build.variant === "vite" && context.config.build.build?.rollupOptions?.external ? isFunction(context.config.build.build?.rollupOptions?.external) ? context.config.build.build?.rollupOptions?.external : (id) => toArray(context.config.build?.build?.rollupOptions?.external).includes(id) : void 0;
28
+ if (isFunction(externalFn) && externalFn(source, importer, isResolved)) return true;
29
+ if (context.config.build.external && toArray(context.config.build.external).includes(source)) return true;
30
+ if (context.config.build.noExternal && toArray(context.config.build.noExternal).includes(source)) return false;
31
+ if (context.builtins.includes(source)) return context.config.projectType !== "application";
32
+ return !context.config.build.skipNodeModulesBundle;
33
+ },
34
+ plugins: [
35
+ typescriptPlugin({
36
+ check: false,
37
+ tsconfig: context.tsconfig.tsconfigFilePath
38
+ }),
39
+ context.config.build.define && Object.keys(context.config.build.define).length > 0 && replace({
40
+ sourceMap: context.config.mode === "development",
41
+ preventAssignment: true,
42
+ ...context.config.build.define ?? {}
43
+ }),
44
+ context.config.build.inject && Object.keys(context.config.build.inject).length > 0 && inject({
45
+ sourceMap: context.config.mode === "development",
46
+ ...context.config.build.inject
47
+ }),
48
+ viteAliasPlugin({ entries: context.builtins.reduce((ret, id) => {
49
+ if (!ret.find((e) => e.find === id)) {
50
+ const path = context.fs.ids[id];
51
+ if (path) ret.push({
52
+ find: id,
53
+ replacement: path
54
+ });
55
+ }
56
+ return ret;
57
+ }, context.config.build.alias ? Array.isArray(context.config.build.alias) ? context.config.build.alias : Object.entries(context.config.build.alias).reduce((ret, [id, path]) => {
58
+ if (!ret.find((e) => e.find === id)) ret.push({
59
+ find: id,
60
+ replacement: path
61
+ });
62
+ return ret;
63
+ }, []) : []) }),
64
+ getBabelInputPlugin(defu$1(context.config.transform.babel, {
65
+ caller: {
66
+ name: "powerlines",
67
+ supportsStaticESM: true
68
+ },
69
+ cwd: context.config.projectRoot,
70
+ babelrc: false,
71
+ extensions: [
72
+ ".js",
73
+ ".jsx",
74
+ ".ts",
75
+ ".tsx"
76
+ ],
77
+ babelHelpers: "bundled",
78
+ skipPreflightCheck: true,
79
+ exclude: /node_modules/
80
+ })),
81
+ resolve({
82
+ moduleDirectories: ["node_modules"],
83
+ preferBuiltins: true
84
+ }),
85
+ dtsBundlePlugin
86
+ ]
87
+ }, context.config.build.variant === "rolldown" || context.config.build.variant === "rollup" ? context.config.build.override : {}, context.config.build.variant === "vite" ? context.config.build.override.build?.rollupOptions : {}, context.config.build.variant === "rolldown" || context.config.build.variant === "rollup" ? omit(context.config.build, ["override", "variant"]) : {}, context.config.build.variant === "vite" ? context.config.build.build : {}, {
88
+ experimental: { viteMode: context.config.build.variant === "vite" },
89
+ resolve: {
90
+ mainFields: context.config.build.mainFields,
91
+ conditions: context.config.build.conditions,
92
+ define: context.config.build.define,
93
+ extensions: context.config.build.extensions
94
+ },
95
+ platform: context.config.build.platform,
96
+ tsconfig: context.tsconfig.tsconfigFilePath,
97
+ cache: !context.config.skipCache ? joinPaths(context.cachePath, "rolldown") : false,
98
+ logLevel: context.config.logLevel,
99
+ onLog: context.log,
100
+ jsx: "automatic",
101
+ keepNames: true,
102
+ treeshake: true,
103
+ minify: context.config.mode === "production",
104
+ output: [{
105
+ dir: context.config.output.buildPath,
106
+ format: "es",
107
+ preserveModules: true,
108
+ sourcemap: context.config.mode === "development"
109
+ }, {
110
+ dir: context.config.output.buildPath,
111
+ format: "cjs",
112
+ preserveModules: true,
113
+ sourcemap: context.config.mode === "development"
114
+ }]
115
+ });
116
+ }
117
+
118
+ //#endregion
119
+ export { extractRolldownConfig };
@@ -1 +1,45 @@
1
- const e=require(`../../../../_virtual/rolldown_runtime.cjs`);let t=require(`@stryke/convert/to-array`),n=require(`defu`);n=e.__toESM(n);let r=require(`@rollup/plugin-babel`),i=require(`@rollup/plugin-inject`);i=e.__toESM(i);let a=require(`@rollup/plugin-node-resolve`);a=e.__toESM(a);let o=require(`@rollup/plugin-replace`);o=e.__toESM(o);let s=require(`@stryke/helpers/omit`),c=require(`@stryke/path/join-paths`),l=require(`@stryke/type-checks/is-function`),u=require(`@stryke/type-checks/is-string`),d=require(`node:fs`),f=require(`rollup-plugin-typescript2`);f=e.__toESM(f),require(`@rollup/plugin-alias`);const p={name:`powerlines:dts-bundle`,async generateBundle(e,t){for(let[,e]of Object.entries(t)){if(e.type===`asset`||!e.isEntry||e.facadeModuleId==null)continue;let t=e.fileName.replace(/(?:\.cjs|\.mjs|\.esm\.js|\.cjs\.js|\.mjs\.js|\.js)$/,`.d.ts`),n=JSON.stringify(`./${e.facadeModuleId.replace(/\.[cm]?[jt]sx?$/,``)}`);this.emitFile({type:`asset`,fileName:t,source:e.exports.includes(`default`)?`export * from ${n};\nexport { default } from ${n};\n`:`export * from ${n};\n`})}}};exports.dtsBundlePlugin=p;
1
+ const require_rolldown_runtime = require('../../../../_virtual/rolldown_runtime.cjs');
2
+ let __stryke_convert_to_array = require("@stryke/convert/to-array");
3
+ let defu = require("defu");
4
+ defu = require_rolldown_runtime.__toESM(defu);
5
+ let __rollup_plugin_babel = require("@rollup/plugin-babel");
6
+ let __rollup_plugin_inject = require("@rollup/plugin-inject");
7
+ __rollup_plugin_inject = require_rolldown_runtime.__toESM(__rollup_plugin_inject);
8
+ let __rollup_plugin_node_resolve = require("@rollup/plugin-node-resolve");
9
+ __rollup_plugin_node_resolve = require_rolldown_runtime.__toESM(__rollup_plugin_node_resolve);
10
+ let __rollup_plugin_replace = require("@rollup/plugin-replace");
11
+ __rollup_plugin_replace = require_rolldown_runtime.__toESM(__rollup_plugin_replace);
12
+ let __stryke_helpers_omit = require("@stryke/helpers/omit");
13
+ let __stryke_path_join_paths = require("@stryke/path/join-paths");
14
+ let __stryke_type_checks_is_function = require("@stryke/type-checks/is-function");
15
+ let __stryke_type_checks_is_string = require("@stryke/type-checks/is-string");
16
+ let node_fs = require("node:fs");
17
+ let rollup_plugin_typescript2 = require("rollup-plugin-typescript2");
18
+ rollup_plugin_typescript2 = require_rolldown_runtime.__toESM(rollup_plugin_typescript2);
19
+ require("@rollup/plugin-alias");
20
+
21
+ //#region ../powerlines/src/lib/build/rollup.ts
22
+ /**
23
+ * A Rollup plugin to bundle TypeScript declaration files (.d.ts) alongside the JavaScript output files.
24
+ *
25
+ * @remarks
26
+ * This plugin generates .d.ts files for each entry point in the bundle, ensuring that type definitions are available for consumers of the library.
27
+ */
28
+ const dtsBundlePlugin = {
29
+ name: "powerlines:dts-bundle",
30
+ async generateBundle(_opts, bundle) {
31
+ for (const [, file] of Object.entries(bundle)) {
32
+ if (file.type === "asset" || !file.isEntry || file.facadeModuleId == null) continue;
33
+ const dtsFileName = file.fileName.replace(/(?:\.cjs|\.mjs|\.esm\.js|\.cjs\.js|\.mjs\.js|\.js)$/, ".d.ts");
34
+ const relativeSourceDtsName = JSON.stringify(`./${file.facadeModuleId.replace(/\.[cm]?[jt]sx?$/, "")}`);
35
+ this.emitFile({
36
+ type: "asset",
37
+ fileName: dtsFileName,
38
+ source: file.exports.includes("default") ? `export * from ${relativeSourceDtsName};\nexport { default } from ${relativeSourceDtsName};\n` : `export * from ${relativeSourceDtsName};\n`
39
+ });
40
+ }
41
+ }
42
+ };
43
+
44
+ //#endregion
45
+ exports.dtsBundlePlugin = dtsBundlePlugin;