smartbundle 0.11.1 → 0.12.0
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.
- package/README.md +1 -1
- package/__compiled__/cjs/src/args.d.ts +11 -1
- package/__compiled__/cjs/src/args.js +7 -2
- package/__compiled__/cjs/src/args.js.map +1 -1
- package/__compiled__/cjs/src/createViteConfig.js +1 -0
- package/__compiled__/cjs/src/createViteConfig.js.map +1 -1
- package/__compiled__/cjs/src/detectModules.d.ts +4 -0
- package/__compiled__/cjs/src/detectModules.js +1 -0
- package/__compiled__/cjs/src/detectModules.js.map +1 -1
- package/__compiled__/cjs/src/error.js.map +1 -1
- package/__compiled__/cjs/src/index.d.ts +1 -1
- package/__compiled__/cjs/src/index.js +31 -30
- package/__compiled__/cjs/src/index.js.map +1 -1
- package/__compiled__/cjs/src/log.js.map +1 -1
- package/__compiled__/cjs/src/packageJson.d.ts +20 -5
- package/__compiled__/cjs/src/packageJson.js.map +1 -1
- package/__compiled__/cjs/src/pipeline.d.ts +6 -0
- package/__compiled__/cjs/src/pipeline.js +20 -0
- package/__compiled__/cjs/src/pipeline.js.map +1 -0
- package/__compiled__/cjs/src/plugins/babel/findBabelConfig.js.map +1 -1
- package/__compiled__/cjs/src/plugins/babel/index.js +1 -0
- package/__compiled__/cjs/src/plugins/babel/index.js.map +1 -1
- package/__compiled__/cjs/src/plugins/react/index.js.map +1 -1
- package/__compiled__/cjs/src/promiseSettledResultErrors.d.ts +3 -0
- package/__compiled__/cjs/src/promiseSettledResultErrors.js +15 -0
- package/__compiled__/cjs/src/promiseSettledResultErrors.js.map +1 -0
- package/__compiled__/cjs/src/resolveDirs.d.ts +1 -5
- package/__compiled__/cjs/src/resolveDirs.js +1 -0
- package/__compiled__/cjs/src/resolveDirs.js.map +1 -1
- package/__compiled__/cjs/src/run.js +1 -1
- package/__compiled__/cjs/src/run.js.map +1 -1
- package/__compiled__/cjs/src/tasks/binsTask.js.map +1 -1
- package/__compiled__/cjs/src/tasks/buildTypesTask/buildTypesTask.d.ts +3 -3
- package/__compiled__/cjs/src/tasks/buildTypesTask/buildTypesTask.js +6 -4
- package/__compiled__/cjs/src/tasks/buildTypesTask/buildTypesTask.js.map +1 -1
- package/__compiled__/cjs/src/tasks/buildTypesTask/callTypescript.d.ts +3 -1
- package/__compiled__/cjs/src/tasks/buildTypesTask/callTypescript.js +53 -11
- package/__compiled__/cjs/src/tasks/buildTypesTask/callTypescript.js.map +1 -1
- package/__compiled__/cjs/src/tasks/buildTypesTask/inlineExtensions.d.ts +8 -2
- package/__compiled__/cjs/src/tasks/buildTypesTask/inlineExtensions.js +101 -22
- package/__compiled__/cjs/src/tasks/buildTypesTask/inlineExtensions.js.map +1 -1
- package/__compiled__/cjs/src/tasks/copyStaticFilesTask.js.map +1 -1
- package/__compiled__/cjs/src/tasks/jsFilesTask.js.map +1 -1
- package/__compiled__/cjs/src/tasks/utils.js.map +1 -1
- package/__compiled__/cjs/src/tasks/viteTask.d.ts +16 -0
- package/__compiled__/cjs/src/{buildVite.js → tasks/viteTask.js} +13 -2
- package/__compiled__/cjs/src/tasks/viteTask.js.map +1 -0
- package/__compiled__/cjs/src/writePackageJson.js.map +1 -1
- package/__compiled__/esm/src/args.d.mts +11 -1
- package/__compiled__/esm/src/args.mjs +7 -2
- package/__compiled__/esm/src/args.mjs.map +1 -1
- package/__compiled__/esm/src/createViteConfig.mjs +1 -0
- package/__compiled__/esm/src/createViteConfig.mjs.map +1 -1
- package/__compiled__/esm/src/detectModules.d.mts +4 -0
- package/__compiled__/esm/src/detectModules.mjs +2 -1
- package/__compiled__/esm/src/detectModules.mjs.map +1 -1
- package/__compiled__/esm/src/error.mjs.map +1 -1
- package/__compiled__/esm/src/index.d.mts +1 -1
- package/__compiled__/esm/src/index.mjs +32 -31
- package/__compiled__/esm/src/index.mjs.map +1 -1
- package/__compiled__/esm/src/log.mjs.map +1 -1
- package/__compiled__/esm/src/packageJson.d.mts +20 -5
- package/__compiled__/esm/src/packageJson.mjs.map +1 -1
- package/__compiled__/esm/src/pipeline.d.mts +6 -0
- package/__compiled__/esm/src/pipeline.mjs +20 -0
- package/__compiled__/esm/src/pipeline.mjs.map +1 -0
- package/__compiled__/esm/src/plugins/babel/findBabelConfig.mjs.map +1 -1
- package/__compiled__/esm/src/plugins/babel/index.mjs +1 -0
- package/__compiled__/esm/src/plugins/babel/index.mjs.map +1 -1
- package/__compiled__/esm/src/plugins/react/index.mjs.map +1 -1
- package/__compiled__/esm/src/promiseSettledResultErrors.d.mts +3 -0
- package/__compiled__/esm/src/promiseSettledResultErrors.mjs +15 -0
- package/__compiled__/esm/src/promiseSettledResultErrors.mjs.map +1 -0
- package/__compiled__/esm/src/resolveDirs.d.mts +1 -5
- package/__compiled__/esm/src/resolveDirs.mjs +1 -0
- package/__compiled__/esm/src/resolveDirs.mjs.map +1 -1
- package/__compiled__/esm/src/run.mjs +1 -1
- package/__compiled__/esm/src/run.mjs.map +1 -1
- package/__compiled__/esm/src/tasks/binsTask.mjs.map +1 -1
- package/__compiled__/esm/src/tasks/buildTypesTask/buildTypesTask.d.mts +3 -3
- package/__compiled__/esm/src/tasks/buildTypesTask/buildTypesTask.mjs +6 -4
- package/__compiled__/esm/src/tasks/buildTypesTask/buildTypesTask.mjs.map +1 -1
- package/__compiled__/esm/src/tasks/buildTypesTask/callTypescript.d.mts +3 -1
- package/__compiled__/esm/src/tasks/buildTypesTask/callTypescript.mjs +54 -12
- package/__compiled__/esm/src/tasks/buildTypesTask/callTypescript.mjs.map +1 -1
- package/__compiled__/esm/src/tasks/buildTypesTask/inlineExtensions.d.mts +8 -2
- package/__compiled__/esm/src/tasks/buildTypesTask/inlineExtensions.mjs +101 -22
- package/__compiled__/esm/src/tasks/buildTypesTask/inlineExtensions.mjs.map +1 -1
- package/__compiled__/esm/src/tasks/copyStaticFilesTask.mjs.map +1 -1
- package/__compiled__/esm/src/tasks/jsFilesTask.mjs.map +1 -1
- package/__compiled__/esm/src/tasks/utils.mjs.map +1 -1
- package/__compiled__/esm/src/tasks/viteTask.d.mts +16 -0
- package/__compiled__/esm/src/{buildVite.mjs → tasks/viteTask.mjs} +14 -3
- package/__compiled__/esm/src/tasks/viteTask.mjs.map +1 -0
- package/__compiled__/esm/src/writePackageJson.mjs.map +1 -1
- package/package.json +13 -9
- package/__compiled__/cjs/src/buildVite.d.ts +0 -15
- package/__compiled__/cjs/src/buildVite.js.map +0 -1
- package/__compiled__/cjs/src/run.d.ts +0 -1
- package/__compiled__/esm/src/buildVite.d.mts +0 -15
- package/__compiled__/esm/src/buildVite.mjs.map +0 -1
- package/__compiled__/esm/src/run.d.mts +0 -1
@@ -1,8 +1,10 @@
|
|
1
|
+
import { type PackageJson } from "../../packageJson.js";
|
1
2
|
type BuildTypesOptions = {
|
2
3
|
ts: typeof import("typescript");
|
3
4
|
sourceDir: string;
|
5
|
+
packageJson: PackageJson;
|
4
6
|
files: string[];
|
5
7
|
outDir: string;
|
6
8
|
};
|
7
|
-
export declare function callTypescript({ ts, sourceDir, files, outDir, }: BuildTypesOptions): Promise<Map<string, string>>;
|
9
|
+
export declare function callTypescript({ ts, sourceDir, files, packageJson, outDir, }: BuildTypesOptions): Promise<Map<string, string>>;
|
8
10
|
export {};
|
@@ -1,9 +1,13 @@
|
|
1
1
|
import * as path from "node:path";
|
2
2
|
import * as fs from "node:fs";
|
3
|
-
import {
|
4
|
-
|
3
|
+
import { inlineExtensionsCjs, inlineExtensionsMjs } from "./inlineExtensions.mjs";
|
4
|
+
import "node:fs/promises";
|
5
|
+
import "zod";
|
6
|
+
import { getMinVersion } from "../../detectModules.mjs";
|
7
|
+
import { BuildError } from "../../error.mjs";
|
8
|
+
function makeFileExists(outDir, filePath) {
|
5
9
|
return (p) => {
|
6
|
-
const dir = path.join(outDir,
|
10
|
+
const dir = path.join(outDir, path.dirname(filePath));
|
7
11
|
return fs.existsSync(path.join(dir, p));
|
8
12
|
};
|
9
13
|
}
|
@@ -11,6 +15,7 @@ async function callTypescript({
|
|
11
15
|
ts,
|
12
16
|
sourceDir,
|
13
17
|
files,
|
18
|
+
packageJson,
|
14
19
|
outDir
|
15
20
|
}) {
|
16
21
|
const configPath = path.join(sourceDir, "tsconfig.json");
|
@@ -50,18 +55,55 @@ async function callTypescript({
|
|
50
55
|
const esmFinalPath = finalEsmPath.replace(/\.d\.ts$/, ".d.mts");
|
51
56
|
sourceToDtsMap.set(esmFinalPath, sourceFileName);
|
52
57
|
fs.mkdirSync(path.dirname(esmFinalPath), { recursive: true });
|
53
|
-
fs.writeFileSync(
|
54
|
-
esmFinalPath,
|
55
|
-
inlineExtensionsMjs(data, makeFileExists(outDir, "esm", relativePath))
|
56
|
-
);
|
58
|
+
fs.writeFileSync(esmFinalPath, data);
|
57
59
|
const finalCjsPath = path.join(outDir, "__compiled__", "cjs", relativePath);
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
inlineExtensionsCjs(data, makeFileExists(outDir, "cjs", relativePath))
|
62
|
-
);
|
60
|
+
fs.mkdirSync(path.dirname(finalCjsPath), { recursive: true });
|
61
|
+
const cjsFinalPath = finalCjsPath;
|
62
|
+
fs.writeFileSync(cjsFinalPath, data);
|
63
63
|
sourceToDtsMap.set(cjsFinalPath, sourceFileName);
|
64
64
|
});
|
65
|
+
const allImportedLibraries = /* @__PURE__ */ new Set();
|
66
|
+
for (const file of sourceToDtsMap.keys()) {
|
67
|
+
const content = fs.readFileSync(file, "utf-8");
|
68
|
+
const relativePath = path.relative(outDir, file);
|
69
|
+
if (file.endsWith(".d.ts")) {
|
70
|
+
const transformedCode = inlineExtensionsCjs(
|
71
|
+
ts,
|
72
|
+
content,
|
73
|
+
makeFileExists(outDir, relativePath)
|
74
|
+
);
|
75
|
+
for (const lib of transformedCode.usedLibraries.values()) {
|
76
|
+
allImportedLibraries.add(lib);
|
77
|
+
}
|
78
|
+
fs.writeFileSync(file, transformedCode.output);
|
79
|
+
}
|
80
|
+
if (file.endsWith(".d.mts")) {
|
81
|
+
const transformedCode = inlineExtensionsMjs(
|
82
|
+
ts,
|
83
|
+
content,
|
84
|
+
makeFileExists(outDir, relativePath)
|
85
|
+
);
|
86
|
+
for (const lib of transformedCode.usedLibraries.values()) {
|
87
|
+
allImportedLibraries.add(lib);
|
88
|
+
}
|
89
|
+
fs.writeFileSync(file, transformedCode.output);
|
90
|
+
}
|
91
|
+
}
|
92
|
+
const notInstalledLibraries = /* @__PURE__ */ new Set();
|
93
|
+
for (const lib of allImportedLibraries) {
|
94
|
+
if (getMinVersion(packageJson, lib, [
|
95
|
+
"optionalDependencies",
|
96
|
+
"devDependencies"
|
97
|
+
]) == null) {
|
98
|
+
notInstalledLibraries.add(lib);
|
99
|
+
}
|
100
|
+
}
|
101
|
+
if (notInstalledLibraries.size > 0) {
|
102
|
+
const libsList = [...notInstalledLibraries].map((x) => `"${x}"`).join(", ");
|
103
|
+
throw new BuildError(
|
104
|
+
`You use types from dependencies that are not installed: ${libsList}. Please install them into dependencies or peerDependencies.`
|
105
|
+
);
|
106
|
+
}
|
65
107
|
return sourceToDtsMap;
|
66
108
|
}
|
67
109
|
export {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"callTypescript.mjs","sources":["../../../../../../src/tasks/buildTypesTask/callTypescript.ts"],"sourcesContent":["import * as path from \"node:path\";\nimport * as fs from \"node:fs\";\nimport {\n inlineExtensionsMjs,\n inlineExtensionsCjs,\n} from \"./inlineExtensions.js\";\n\ntype BuildTypesOptions = {\n ts: typeof import(\"typescript\");\n sourceDir: string;\n files: string[];\n outDir: string;\n};\n\nfunction makeFileExists(outDir: string,
|
1
|
+
{"version":3,"file":"callTypescript.mjs","sources":["../../../../../../src/tasks/buildTypesTask/callTypescript.ts"],"sourcesContent":["import * as path from \"node:path\";\nimport * as fs from \"node:fs\";\nimport {\n inlineExtensionsMjs,\n inlineExtensionsCjs,\n} from \"./inlineExtensions.js\";\nimport { type PackageJson } from \"../../packageJson.js\";\nimport { getMinVersion } from \"../../detectModules.js\";\nimport { BuildError } from \"../../error.js\";\n\ntype BuildTypesOptions = {\n ts: typeof import(\"typescript\");\n sourceDir: string;\n packageJson: PackageJson;\n files: string[];\n outDir: string;\n};\n\nfunction makeFileExists(outDir: string, filePath: string) {\n return (p: string) => {\n const dir = path.join(outDir, path.dirname(filePath));\n return fs.existsSync(path.join(dir, p));\n };\n}\n\nexport async function callTypescript({\n ts,\n sourceDir,\n files,\n packageJson,\n outDir,\n}: BuildTypesOptions) {\n // <build d.ts>\n const configPath = path.join(sourceDir, \"tsconfig.json\");\n const configFile = ts.readConfigFile(configPath, (path) =>\n // https://github.com/XaveScor/bobrik/issues/22\n fs.readFileSync(path, \"utf-8\"),\n );\n\n const parsedCommandLine = ts.parseJsonConfigFileContent(\n configFile.config,\n ts.sys,\n sourceDir,\n {\n declaration: true,\n emitDeclarationOnly: true,\n strict: false,\n strictNullChecks: false,\n strictFunctionTypes: false,\n strictPropertyInitialization: false,\n skipLibCheck: true,\n skipDefaultLibCheck: true,\n outDir: \"\",\n // https://github.com/XaveScor/bobrik/issues/22#issuecomment-2308552352\n noEmit: false,\n },\n configPath,\n );\n\n const host = ts.createCompilerHost(parsedCommandLine.options);\n\n const sourceToDtsMap = new Map<string, string>();\n const program = ts.createProgram(files, parsedCommandLine.options, host);\n program.emit(undefined, (fileName, data) => {\n // .d.ts for cjs because \"type\": \"commonjs\" in package.json\n // .d.mts for esm\n const relativePath = path.relative(sourceDir, fileName);\n const sourceFileName = fileName.replace(/\\.d\\.ts$/, \".ts\"); // Assuming source files have .ts extension\n\n const finalEsmPath = path.join(outDir, \"__compiled__\", \"esm\", relativePath);\n const esmFinalPath = finalEsmPath.replace(/\\.d\\.ts$/, \".d.mts\");\n sourceToDtsMap.set(esmFinalPath, sourceFileName);\n fs.mkdirSync(path.dirname(esmFinalPath), { recursive: true });\n fs.writeFileSync(esmFinalPath, data);\n\n const finalCjsPath = path.join(outDir, \"__compiled__\", \"cjs\", relativePath);\n fs.mkdirSync(path.dirname(finalCjsPath), { recursive: true });\n const cjsFinalPath = finalCjsPath;\n fs.writeFileSync(cjsFinalPath, data);\n sourceToDtsMap.set(cjsFinalPath, sourceFileName);\n });\n\n // </build d.ts>\n\n const allImportedLibraries = new Set<string>();\n // <fix vscode typings>\n for (const file of sourceToDtsMap.keys()) {\n const content = fs.readFileSync(file, \"utf-8\");\n const relativePath = path.relative(outDir, file);\n if (file.endsWith(\".d.ts\")) {\n const transformedCode = inlineExtensionsCjs(\n ts,\n content,\n makeFileExists(outDir, relativePath),\n );\n for (const lib of transformedCode.usedLibraries.values()) {\n allImportedLibraries.add(lib);\n }\n fs.writeFileSync(file, transformedCode.output);\n }\n if (file.endsWith(\".d.mts\")) {\n const transformedCode = inlineExtensionsMjs(\n ts,\n content,\n makeFileExists(outDir, relativePath),\n );\n for (const lib of transformedCode.usedLibraries.values()) {\n allImportedLibraries.add(lib);\n }\n fs.writeFileSync(file, transformedCode.output);\n }\n }\n // </fix vscode typings>\n\n // <check not installed typings libraries>\n const notInstalledLibraries = new Set<string>();\n for (const lib of allImportedLibraries) {\n if (\n getMinVersion(packageJson, lib, [\n \"optionalDependencies\",\n \"devDependencies\",\n ]) == null\n ) {\n notInstalledLibraries.add(lib);\n }\n }\n if (notInstalledLibraries.size > 0) {\n const libsList = [...notInstalledLibraries].map((x) => `\"${x}\"`).join(\", \");\n throw new BuildError(\n `You use types from dependencies that are not installed: ${libsList}. Please install them into dependencies or peerDependencies.`,\n );\n }\n // </check not installed typings libraries>\n\n return sourceToDtsMap;\n}\n"],"names":["path"],"mappings":"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"}
|
@@ -1,3 +1,9 @@
|
|
1
1
|
export type FileExists = (path: string) => boolean;
|
2
|
-
export declare function inlineExtensionsMjs(content: string, fileExists: FileExists):
|
3
|
-
|
2
|
+
export declare function inlineExtensionsMjs(ts: typeof import("typescript"), content: string, fileExists: FileExists): {
|
3
|
+
output: string;
|
4
|
+
usedLibraries: Set<string>;
|
5
|
+
};
|
6
|
+
export declare function inlineExtensionsCjs(ts: typeof import("typescript"), content: string, fileExists: FileExists): {
|
7
|
+
output: string;
|
8
|
+
usedLibraries: Set<string>;
|
9
|
+
};
|
@@ -1,30 +1,109 @@
|
|
1
1
|
import { join } from "node:path";
|
2
|
-
|
3
|
-
const
|
4
|
-
function addExtension(
|
5
|
-
|
6
|
-
if (!
|
7
|
-
|
2
|
+
function transformAndExtractImports(ts, content, ext, dtsExt, fileExists) {
|
3
|
+
const usedLibraries = /* @__PURE__ */ new Set();
|
4
|
+
function addExtension(ts2, node, ext2, dtsExt2, fileExists2) {
|
5
|
+
const importPath = node.text;
|
6
|
+
if (!importPath.startsWith(".")) {
|
7
|
+
usedLibraries.add(importPath);
|
8
|
+
return node;
|
8
9
|
}
|
9
|
-
if (
|
10
|
-
|
11
|
-
if (fileExists(file)) return match.replace(p1, file);
|
12
|
-
const indexFile = "./" + join(p1, `index${ext}`);
|
13
|
-
if (fileExists(indexFile)) return match.replace(p1, indexFile);
|
14
|
-
return match;
|
10
|
+
if (importPath.endsWith(".cjs") || importPath.endsWith(".mjs") || importPath.endsWith(".js")) {
|
11
|
+
return node;
|
15
12
|
}
|
16
|
-
|
17
|
-
|
13
|
+
if (fileExists2(`${importPath}${dtsExt2}`)) {
|
14
|
+
return ts2.factory.createStringLiteral(`${importPath}${ext2}`);
|
15
|
+
}
|
16
|
+
if (fileExists2("./" + join(importPath, `index${dtsExt2}`))) {
|
17
|
+
return ts2.factory.createStringLiteral(
|
18
|
+
"./" + join(importPath, `index${ext2}`)
|
19
|
+
);
|
20
|
+
}
|
21
|
+
return node;
|
22
|
+
}
|
23
|
+
const sourceFile = ts.createSourceFile(
|
24
|
+
"temp.ts",
|
25
|
+
content,
|
26
|
+
ts.ScriptTarget.ESNext,
|
27
|
+
true
|
28
|
+
);
|
29
|
+
const transformer = (context) => (rootNode) => {
|
30
|
+
function visit(node) {
|
31
|
+
if (ts.isExportDeclaration(node)) {
|
32
|
+
const moduleSpecifier = node.moduleSpecifier;
|
33
|
+
if (moduleSpecifier && ts.isStringLiteral(moduleSpecifier)) {
|
34
|
+
const updatedSpecifier = addExtension(
|
35
|
+
ts,
|
36
|
+
moduleSpecifier,
|
37
|
+
ext,
|
38
|
+
dtsExt,
|
39
|
+
fileExists
|
40
|
+
);
|
41
|
+
return ts.factory.updateExportDeclaration(
|
42
|
+
node,
|
43
|
+
node.modifiers,
|
44
|
+
node.isTypeOnly,
|
45
|
+
node.exportClause,
|
46
|
+
updatedSpecifier,
|
47
|
+
node.attributes
|
48
|
+
);
|
49
|
+
}
|
50
|
+
}
|
51
|
+
if (ts.isImportDeclaration(node)) {
|
52
|
+
const moduleSpecifier = node.moduleSpecifier;
|
53
|
+
if (moduleSpecifier && ts.isStringLiteral(moduleSpecifier)) {
|
54
|
+
const updatedSpecifier = addExtension(
|
55
|
+
ts,
|
56
|
+
moduleSpecifier,
|
57
|
+
ext,
|
58
|
+
dtsExt,
|
59
|
+
fileExists
|
60
|
+
);
|
61
|
+
return ts.factory.updateImportDeclaration(
|
62
|
+
node,
|
63
|
+
node.modifiers,
|
64
|
+
node.importClause,
|
65
|
+
updatedSpecifier,
|
66
|
+
node.attributes
|
67
|
+
);
|
68
|
+
}
|
69
|
+
}
|
70
|
+
if (ts.isCallExpression(node) && node.expression.kind === ts.SyntaxKind.ImportKeyword) {
|
71
|
+
const [argument] = node.arguments;
|
72
|
+
if (argument && ts.isStringLiteral(argument)) {
|
73
|
+
const updatedArgument = addExtension(
|
74
|
+
ts,
|
75
|
+
argument,
|
76
|
+
ext,
|
77
|
+
dtsExt,
|
78
|
+
fileExists
|
79
|
+
);
|
80
|
+
return ts.factory.updateCallExpression(
|
81
|
+
node,
|
82
|
+
node.expression,
|
83
|
+
node.typeArguments,
|
84
|
+
[updatedArgument]
|
85
|
+
);
|
86
|
+
}
|
87
|
+
}
|
88
|
+
if (ts.isStringLiteral(node) && ts.isLiteralTypeNode(node.parent) && node.parent.parent.kind === ts.SyntaxKind.ImportType) {
|
89
|
+
return addExtension(ts, node, ext, dtsExt, fileExists);
|
90
|
+
}
|
91
|
+
return ts.visitEachChild(node, visit, context);
|
92
|
+
}
|
93
|
+
return ts.visitNode(rootNode, visit);
|
94
|
+
};
|
95
|
+
const result = ts.transform(sourceFile, [transformer]);
|
96
|
+
const printer = ts.createPrinter();
|
97
|
+
const transformedSourceFile = result.transformed[0];
|
98
|
+
const output = printer.printFile(transformedSourceFile);
|
99
|
+
result.dispose();
|
100
|
+
return { output, usedLibraries };
|
18
101
|
}
|
19
|
-
function inlineExtensionsMjs(content, fileExists) {
|
20
|
-
|
21
|
-
content = addExtension(content, dynamicImportRegex, ".mjs", fileExists);
|
22
|
-
return content;
|
102
|
+
function inlineExtensionsMjs(ts, content, fileExists) {
|
103
|
+
return transformAndExtractImports(ts, content, ".mjs", ".d.mts", fileExists);
|
23
104
|
}
|
24
|
-
function inlineExtensionsCjs(content, fileExists) {
|
25
|
-
|
26
|
-
content = addExtension(content, dynamicImportRegex, ".js", fileExists);
|
27
|
-
return content;
|
105
|
+
function inlineExtensionsCjs(ts, content, fileExists) {
|
106
|
+
return transformAndExtractImports(ts, content, ".js", ".d.ts", fileExists);
|
28
107
|
}
|
29
108
|
export {
|
30
109
|
inlineExtensionsCjs,
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"inlineExtensions.mjs","sources":["../../../../../../src/tasks/buildTypesTask/inlineExtensions.ts"],"sourcesContent":["import { join } from \"node:path\";\n\n// It needs for VSCode. It cannot resolve the import/export if it has no extension\n\
|
1
|
+
{"version":3,"file":"inlineExtensions.mjs","sources":["../../../../../../src/tasks/buildTypesTask/inlineExtensions.ts"],"sourcesContent":["import type * as TS from \"typescript\";\nimport { join } from \"node:path\";\n\n// It needs for VSCode. It cannot resolve the import/export if it has no extension\n\nexport type FileExists = (path: string) => boolean;\n\nfunction transformAndExtractImports(\n ts: typeof import(\"typescript\"),\n content: string,\n ext: string,\n dtsExt: string,\n fileExists: FileExists,\n) {\n const usedLibraries = new Set<string>();\n function addExtension(\n ts: typeof import(\"typescript\"),\n node: TS.StringLiteral,\n ext: string,\n dtsExt: string,\n fileExists: FileExists,\n ): TS.StringLiteral {\n const importPath = node.text;\n\n if (!importPath.startsWith(\".\")) {\n usedLibraries.add(importPath);\n return node; // Leave external imports untouched\n }\n\n if (\n importPath.endsWith(\".cjs\") ||\n importPath.endsWith(\".mjs\") ||\n importPath.endsWith(\".js\")\n ) {\n return node;\n }\n\n if (fileExists(`${importPath}${dtsExt}`)) {\n return ts.factory.createStringLiteral(`${importPath}${ext}`);\n }\n\n if (fileExists(\"./\" + join(importPath, `index${dtsExt}`))) {\n return ts.factory.createStringLiteral(\n \"./\" + join(importPath, `index${ext}`),\n );\n }\n\n return node; // Return the original node if no modification was made\n }\n\n const sourceFile = ts.createSourceFile(\n \"temp.ts\",\n content,\n ts.ScriptTarget.ESNext,\n true,\n );\n\n const transformer: TS.TransformerFactory<TS.SourceFile> =\n (context) => (rootNode) => {\n function visit(node: TS.Node): TS.Node {\n // export {} from \"moduleSpecifier\";\n if (ts.isExportDeclaration(node)) {\n const moduleSpecifier = node.moduleSpecifier;\n if (moduleSpecifier && ts.isStringLiteral(moduleSpecifier)) {\n const updatedSpecifier = addExtension(\n ts,\n moduleSpecifier,\n ext,\n dtsExt,\n fileExists,\n );\n return ts.factory.updateExportDeclaration(\n node,\n node.modifiers,\n node.isTypeOnly,\n node.exportClause,\n updatedSpecifier,\n node.attributes,\n );\n }\n }\n\n // import {} from \"moduleSpecifier\";\n if (ts.isImportDeclaration(node)) {\n const moduleSpecifier = node.moduleSpecifier;\n if (moduleSpecifier && ts.isStringLiteral(moduleSpecifier)) {\n const updatedSpecifier = addExtension(\n ts,\n moduleSpecifier,\n ext,\n dtsExt,\n fileExists,\n );\n return ts.factory.updateImportDeclaration(\n node,\n node.modifiers,\n node.importClause,\n updatedSpecifier,\n node.attributes,\n );\n }\n }\n\n // import(\"argument\");\n if (\n ts.isCallExpression(node) &&\n node.expression.kind === ts.SyntaxKind.ImportKeyword\n ) {\n const [argument] = node.arguments;\n if (argument && ts.isStringLiteral(argument)) {\n const updatedArgument = addExtension(\n ts,\n argument,\n ext,\n dtsExt,\n fileExists,\n );\n return ts.factory.updateCallExpression(\n node,\n node.expression,\n node.typeArguments,\n [updatedArgument],\n );\n }\n }\n\n // Generic<import(\"node\")>;\n if (\n ts.isStringLiteral(node) &&\n ts.isLiteralTypeNode(node.parent) &&\n node.parent.parent.kind === ts.SyntaxKind.ImportType\n ) {\n return addExtension(ts, node, ext, dtsExt, fileExists);\n }\n\n return ts.visitEachChild(node, visit, context);\n }\n\n return ts.visitNode(rootNode, visit) as TS.SourceFile;\n };\n\n const result = ts.transform(sourceFile, [transformer]);\n const printer = ts.createPrinter();\n const transformedSourceFile = result.transformed[0];\n const output = printer.printFile(transformedSourceFile);\n result.dispose();\n\n return { output, usedLibraries };\n}\n\nexport function inlineExtensionsMjs(\n ts: typeof import(\"typescript\"),\n content: string,\n fileExists: FileExists,\n) {\n return transformAndExtractImports(ts, content, \".mjs\", \".d.mts\", fileExists);\n}\n\nexport function inlineExtensionsCjs(\n ts: typeof import(\"typescript\"),\n content: string,\n fileExists: FileExists,\n) {\n return transformAndExtractImports(ts, content, \".js\", \".d.ts\", fileExists);\n}\n"],"names":["ts","ext","dtsExt","fileExists"],"mappings":"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"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"copyStaticFilesTask.mjs","sources":["../../../../../src/tasks/copyStaticFilesTask.ts"],"sourcesContent":["import { join } from \"node:path\";\nimport { copyFile, readdir } from \"node:fs/promises\";\nimport { okLog } from \"../log.js\";\n\nexport async function copyStaticFilesTask(sourceDir: string, outDir: string) {\n const files = await copyStaticFiles({\n relativeFiles: new Set([\"readme.md\"]),\n sourceDir,\n outDir,\n });\n\n okLog(\"Static files:\", [...files].join(\", \"));\n\n return files;\n}\n\ntype CopyStaticFilesOptions = {\n relativeFiles: Set<string>;\n sourceDir: string;\n outDir: string;\n};\n\nasync function copyStaticFiles({\n sourceDir,\n outDir,\n relativeFiles,\n}: CopyStaticFilesOptions) {\n const dirFiles = new Map(\n (await readdir(sourceDir, { recursive: true })).map(\n (f) => [f.toLowerCase(), f] as const,\n ),\n );\n\n const res = new Set<string>();\n for (const file of relativeFiles) {\n try {\n const matchingFile = dirFiles.get(file.toLowerCase());\n\n if (matchingFile) {\n const outFilePath = join(outDir, matchingFile);\n const filePath = join(sourceDir, matchingFile);\n await copyFile(filePath, outFilePath);\n res.add(matchingFile);\n }\n } catch {}\n }\n\n return res;\n}\n"],"names":[],"mappings":";;;AAIsB,eAAA,oBAAoB,WAAmB,QAAgB;AACrE,QAAA,QAAQ,MAAM,gBAAgB;AAAA,IAClC,eAAe,oBAAI,IAAI,CAAC,WAAW,CAAC;AAAA,IACpC;AAAA,IACA;AAAA,EAAA,CACD;AAED,QAAM,iBAAiB,CAAC,GAAG,KAAK,EAAE,KAAK,IAAI,CAAC;AAErC,SAAA;AACT;AAQA,eAAe,gBAAgB;AAAA,EAC7B;AAAA,EACA;AAAA,EACA;AACF,GAA2B;AACzB,QAAM,WAAW,IAAI;AAAA,KAClB,MAAM,QAAQ,WAAW,EAAE,WAAW,KAAM,CAAA,GAAG;AAAA,MAC9C,CAAC,MAAM,CAAC,EAAE,
|
1
|
+
{"version":3,"file":"copyStaticFilesTask.mjs","sources":["../../../../../src/tasks/copyStaticFilesTask.ts"],"sourcesContent":["import { join } from \"node:path\";\nimport { copyFile, readdir } from \"node:fs/promises\";\nimport { okLog } from \"../log.js\";\n\nexport async function copyStaticFilesTask(sourceDir: string, outDir: string) {\n const files = await copyStaticFiles({\n relativeFiles: new Set([\"readme.md\"]),\n sourceDir,\n outDir,\n });\n\n okLog(\"Static files:\", [...files].join(\", \"));\n\n return files;\n}\n\ntype CopyStaticFilesOptions = {\n relativeFiles: Set<string>;\n sourceDir: string;\n outDir: string;\n};\n\nasync function copyStaticFiles({\n sourceDir,\n outDir,\n relativeFiles,\n}: CopyStaticFilesOptions) {\n const dirFiles = new Map(\n (await readdir(sourceDir, { recursive: true })).map(\n (f) => [f.toLowerCase(), f] as const,\n ),\n );\n\n const res = new Set<string>();\n for (const file of relativeFiles) {\n try {\n const matchingFile = dirFiles.get(file.toLowerCase());\n\n if (matchingFile) {\n const outFilePath = join(outDir, matchingFile);\n const filePath = join(sourceDir, matchingFile);\n await copyFile(filePath, outFilePath);\n res.add(matchingFile);\n }\n } catch {}\n }\n\n return res;\n}\n"],"names":[],"mappings":";;;AAIsB,eAAA,oBAAoB,WAAmB,QAAgB;AACrE,QAAA,QAAQ,MAAM,gBAAgB;AAAA,IAClC,eAAe,oBAAI,IAAI,CAAC,WAAW,CAAC;AAAA,IACpC;AAAA,IACA;AAAA,EAAA,CACD;AAED,QAAM,iBAAiB,CAAC,GAAG,KAAK,EAAE,KAAK,IAAI,CAAC;AAErC,SAAA;AACT;AAQA,eAAe,gBAAgB;AAAA,EAC7B;AAAA,EACA;AAAA,EACA;AACF,GAA2B;AACzB,QAAM,WAAW,IAAI;AAAA,KAClB,MAAM,QAAQ,WAAW,EAAE,WAAW,KAAM,CAAA,GAAG;AAAA,MAC9C,CAAC,MAAM,CAAC,EAAE,eAAe,CAAC;AAAA,IAAA;AAAA,EAE9B;AAEM,QAAA,0BAAU,IAAY;AAC5B,aAAW,QAAQ,eAAe;AAC5B,QAAA;AACF,YAAM,eAAe,SAAS,IAAI,KAAK,aAAa;AAEpD,UAAI,cAAc;AACV,cAAA,cAAc,KAAK,QAAQ,YAAY;AACvC,cAAA,WAAW,KAAK,WAAW,YAAY;AACvC,cAAA,SAAS,UAAU,WAAW;AACpC,YAAI,IAAI,YAAY;AAAA,MAAA;AAAA,IACtB,QACM;AAAA,IAAA;AAAA,EAAC;AAGJ,SAAA;AACT;"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"jsFilesTask.mjs","sources":["../../../../../src/tasks/jsFilesTask.ts"],"sourcesContent":["import type { Rollup } from \"vite\";\nimport { dirname, join, relative } from \"node:path\";\nimport { mkdir, writeFile } from \"node:fs/promises\";\nimport { okLog } from \"../log.js\";\n\ntype JsFilesTaskOption = {\n buildOutput: Rollup.OutputChunk[];\n entrypoints: Map<string, string>;\n outDir: string;\n};\n\nfunction findCompiledPath(\n buildOutput: Rollup.OutputChunk[],\n originalFile: string,\n type: \"js\" | \"mjs\",\n) {\n for (const el of buildOutput) {\n if (el.facadeModuleId === originalFile) {\n if (type === \"js\" && el.fileName.endsWith(\".js\")) {\n return {\n path: el.fileName,\n hasDefault: el.exports.includes(\"default\"),\n };\n }\n if (type === \"mjs\" && el.fileName.endsWith(\".mjs\")) {\n return {\n path: el.fileName,\n hasDefault: el.exports.includes(\"default\"),\n };\n }\n }\n }\n return { path: \"\", hasDefault: false };\n}\n\nexport async function jsFilesTask({\n buildOutput,\n entrypoints,\n outDir,\n}: JsFilesTaskOption) {\n const res = new Map<string, string>();\n for (const [name, filePath] of entrypoints) {\n const totalName = join(outDir, name);\n\n const esmName = join(totalName, \"index.mjs\");\n const esmCompiled = findCompiledPath(buildOutput, filePath, \"mjs\");\n const esmPath = relative(totalName, join(outDir, esmCompiled.path));\n await mkdir(dirname(esmName), { recursive: true });\n let esmContent = `export * from \"./${esmPath}\";\\n`;\n if (esmCompiled.hasDefault) {\n esmContent += `import Default from \"./${esmPath}\";\\nexport default Default;\\n`;\n }\n await writeFile(esmName, esmContent);\n res.set(relative(outDir, join(dirname(esmName), esmPath)), name);\n const cjsName = join(totalName, \"index.js\");\n const cjsCompiled = findCompiledPath(buildOutput, filePath, \"js\");\n const cjsPath = relative(totalName, join(outDir, cjsCompiled.path));\n await mkdir(dirname(esmName), { recursive: true });\n const cjsContent = `module.exports = require(\"./${cjsPath}\");\\n`;\n await writeFile(cjsName, cjsContent);\n res.set(relative(outDir, join(dirname(cjsName), cjsPath)), name);\n\n // moduleResolution: \"node10\" in tsconfig.json\n const cdtsPath = cjsName.replace(/\\.js$/, \".d.ts\");\n await writeFile(cdtsPath, `export * from \"./${cjsPath}\";\\n`);\n }\n\n okLog(\"no-exports compat layer\");\n return res;\n}\n"],"names":[],"mappings":";;;AAWA,SAAS,iBACP,aACA,cACA,MACA;AACA,aAAW,MAAM,aAAa;AACxB,QAAA,GAAG,mBAAmB,cAAc;AACtC,UAAI,SAAS,QAAQ,GAAG,SAAS,SAAS,KAAK,GAAG;AACzC,eAAA;AAAA,UACL,MAAM,GAAG;AAAA,UACT,YAAY,GAAG,QAAQ,SAAS,SAAS;AAAA,
|
1
|
+
{"version":3,"file":"jsFilesTask.mjs","sources":["../../../../../src/tasks/jsFilesTask.ts"],"sourcesContent":["import type { Rollup } from \"vite\";\nimport { dirname, join, relative } from \"node:path\";\nimport { mkdir, writeFile } from \"node:fs/promises\";\nimport { okLog } from \"../log.js\";\n\ntype JsFilesTaskOption = {\n buildOutput: Rollup.OutputChunk[];\n entrypoints: Map<string, string>;\n outDir: string;\n};\n\nfunction findCompiledPath(\n buildOutput: Rollup.OutputChunk[],\n originalFile: string,\n type: \"js\" | \"mjs\",\n) {\n for (const el of buildOutput) {\n if (el.facadeModuleId === originalFile) {\n if (type === \"js\" && el.fileName.endsWith(\".js\")) {\n return {\n path: el.fileName,\n hasDefault: el.exports.includes(\"default\"),\n };\n }\n if (type === \"mjs\" && el.fileName.endsWith(\".mjs\")) {\n return {\n path: el.fileName,\n hasDefault: el.exports.includes(\"default\"),\n };\n }\n }\n }\n return { path: \"\", hasDefault: false };\n}\n\nexport async function jsFilesTask({\n buildOutput,\n entrypoints,\n outDir,\n}: JsFilesTaskOption) {\n const res = new Map<string, string>();\n for (const [name, filePath] of entrypoints) {\n const totalName = join(outDir, name);\n\n const esmName = join(totalName, \"index.mjs\");\n const esmCompiled = findCompiledPath(buildOutput, filePath, \"mjs\");\n const esmPath = relative(totalName, join(outDir, esmCompiled.path));\n await mkdir(dirname(esmName), { recursive: true });\n let esmContent = `export * from \"./${esmPath}\";\\n`;\n if (esmCompiled.hasDefault) {\n esmContent += `import Default from \"./${esmPath}\";\\nexport default Default;\\n`;\n }\n await writeFile(esmName, esmContent);\n res.set(relative(outDir, join(dirname(esmName), esmPath)), name);\n const cjsName = join(totalName, \"index.js\");\n const cjsCompiled = findCompiledPath(buildOutput, filePath, \"js\");\n const cjsPath = relative(totalName, join(outDir, cjsCompiled.path));\n await mkdir(dirname(esmName), { recursive: true });\n const cjsContent = `module.exports = require(\"./${cjsPath}\");\\n`;\n await writeFile(cjsName, cjsContent);\n res.set(relative(outDir, join(dirname(cjsName), cjsPath)), name);\n\n // moduleResolution: \"node10\" in tsconfig.json\n const cdtsPath = cjsName.replace(/\\.js$/, \".d.ts\");\n await writeFile(cdtsPath, `export * from \"./${cjsPath}\";\\n`);\n }\n\n okLog(\"no-exports compat layer\");\n return res;\n}\n"],"names":[],"mappings":";;;AAWA,SAAS,iBACP,aACA,cACA,MACA;AACA,aAAW,MAAM,aAAa;AACxB,QAAA,GAAG,mBAAmB,cAAc;AACtC,UAAI,SAAS,QAAQ,GAAG,SAAS,SAAS,KAAK,GAAG;AACzC,eAAA;AAAA,UACL,MAAM,GAAG;AAAA,UACT,YAAY,GAAG,QAAQ,SAAS,SAAS;AAAA,QAC3C;AAAA,MAAA;AAEF,UAAI,SAAS,SAAS,GAAG,SAAS,SAAS,MAAM,GAAG;AAC3C,eAAA;AAAA,UACL,MAAM,GAAG;AAAA,UACT,YAAY,GAAG,QAAQ,SAAS,SAAS;AAAA,QAC3C;AAAA,MAAA;AAAA,IACF;AAAA,EACF;AAEF,SAAO,EAAE,MAAM,IAAI,YAAY,MAAM;AACvC;AAEA,eAAsB,YAAY;AAAA,EAChC;AAAA,EACA;AAAA,EACA;AACF,GAAsB;AACd,QAAA,0BAAU,IAAoB;AACpC,aAAW,CAAC,MAAM,QAAQ,KAAK,aAAa;AACpC,UAAA,YAAY,KAAK,QAAQ,IAAI;AAE7B,UAAA,UAAU,KAAK,WAAW,WAAW;AAC3C,UAAM,cAAc,iBAAiB,aAAa,UAAU,KAAK;AACjE,UAAM,UAAU,SAAS,WAAW,KAAK,QAAQ,YAAY,IAAI,CAAC;AAClE,UAAM,MAAM,QAAQ,OAAO,GAAG,EAAE,WAAW,MAAM;AAC7C,QAAA,aAAa,oBAAoB,OAAO;AAAA;AAC5C,QAAI,YAAY,YAAY;AAC1B,oBAAc,0BAA0B,OAAO;AAAA;AAAA;AAAA,IAAA;AAE3C,UAAA,UAAU,SAAS,UAAU;AAC/B,QAAA,IAAI,SAAS,QAAQ,KAAK,QAAQ,OAAO,GAAG,OAAO,CAAC,GAAG,IAAI;AACzD,UAAA,UAAU,KAAK,WAAW,UAAU;AAC1C,UAAM,cAAc,iBAAiB,aAAa,UAAU,IAAI;AAChE,UAAM,UAAU,SAAS,WAAW,KAAK,QAAQ,YAAY,IAAI,CAAC;AAClE,UAAM,MAAM,QAAQ,OAAO,GAAG,EAAE,WAAW,MAAM;AAC3C,UAAA,aAAa,+BAA+B,OAAO;AAAA;AACnD,UAAA,UAAU,SAAS,UAAU;AAC/B,QAAA,IAAI,SAAS,QAAQ,KAAK,QAAQ,OAAO,GAAG,OAAO,CAAC,GAAG,IAAI;AAG/D,UAAM,WAAW,QAAQ,QAAQ,SAAS,OAAO;AAC3C,UAAA,UAAU,UAAU,oBAAoB,OAAO;AAAA,CAAM;AAAA,EAAA;AAG7D,QAAM,yBAAyB;AACxB,SAAA;AACT;"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"utils.mjs","sources":["../../../../../src/tasks/utils.ts"],"sourcesContent":["export function reverseMap(\n map: Map<string, string>,\n): Map<string, Array<string>> {\n const reversed = new Map<string, Array<string>>();\n for (const [key, value] of map) {\n const arr = reversed.get(value) ?? [];\n arr.push(key);\n reversed.set(value, arr);\n }\n return reversed;\n}\n"],"names":[],"mappings":"AAAO,SAAS,WACd,KAC4B;AACtB,QAAA,+BAAe;
|
1
|
+
{"version":3,"file":"utils.mjs","sources":["../../../../../src/tasks/utils.ts"],"sourcesContent":["export function reverseMap(\n map: Map<string, string>,\n): Map<string, Array<string>> {\n const reversed = new Map<string, Array<string>>();\n for (const [key, value] of map) {\n const arr = reversed.get(value) ?? [];\n arr.push(key);\n reversed.set(value, arr);\n }\n return reversed;\n}\n"],"names":[],"mappings":"AAAO,SAAS,WACd,KAC4B;AACtB,QAAA,+BAAe,IAA2B;AAChD,aAAW,CAAC,KAAK,KAAK,KAAK,KAAK;AAC9B,UAAM,MAAM,SAAS,IAAI,KAAK,KAAK,CAAC;AACpC,QAAI,KAAK,GAAG;AACH,aAAA,IAAI,OAAO,GAAG;AAAA,EAAA;AAElB,SAAA;AACT;"}
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import { type UserConfig, type Rollup } from "vite";
|
2
|
+
type ViteTaskParams = {
|
3
|
+
viteConfig: UserConfig;
|
4
|
+
};
|
5
|
+
type BuildSuccess = {
|
6
|
+
error: false;
|
7
|
+
output: Rollup.OutputChunk[];
|
8
|
+
};
|
9
|
+
type BuildErrorType = {
|
10
|
+
error: true;
|
11
|
+
errors: Array<string>;
|
12
|
+
};
|
13
|
+
type BuildResult = BuildSuccess | BuildErrorType;
|
14
|
+
export declare function buildVite({ viteConfig, }: ViteTaskParams): Promise<BuildResult>;
|
15
|
+
export declare function viteTask({ viteConfig }: ViteTaskParams): Promise<any>;
|
16
|
+
export {};
|
@@ -1,5 +1,7 @@
|
|
1
1
|
import { build } from "vite";
|
2
|
-
import { errors } from "
|
2
|
+
import { errors } from "../errors.mjs";
|
3
|
+
import { okLog } from "../log.mjs";
|
4
|
+
import { BuildError } from "../error.mjs";
|
3
5
|
async function buildVite({
|
4
6
|
viteConfig
|
5
7
|
}) {
|
@@ -30,7 +32,16 @@ async function buildVite({
|
|
30
32
|
errors: [errors.rollupError]
|
31
33
|
};
|
32
34
|
}
|
35
|
+
async function viteTask({ viteConfig }) {
|
36
|
+
const outputs = await buildVite({ viteConfig });
|
37
|
+
if (outputs.error) {
|
38
|
+
throw outputs.errors.map((e) => new BuildError(e));
|
39
|
+
}
|
40
|
+
okLog("Vite");
|
41
|
+
return outputs.output;
|
42
|
+
}
|
33
43
|
export {
|
34
|
-
buildVite
|
44
|
+
buildVite,
|
45
|
+
viteTask
|
35
46
|
};
|
36
|
-
//# sourceMappingURL=
|
47
|
+
//# sourceMappingURL=viteTask.mjs.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"viteTask.mjs","sources":["../../../../../src/tasks/viteTask.ts"],"sourcesContent":["import { build, type UserConfig, type Rollup } from \"vite\";\nimport { errors } from \"../errors.js\";\nimport { okLog } from \"../log.js\";\nimport { BuildError } from \"../error.js\";\n\ntype ViteTaskParams = {\n viteConfig: UserConfig;\n};\n\ntype BuildSuccess = {\n error: false;\n output: Rollup.OutputChunk[];\n};\ntype BuildErrorType = {\n error: true;\n errors: Array<string>;\n};\n\ntype BuildResult = BuildSuccess | BuildErrorType;\n\nexport async function buildVite({\n viteConfig,\n}: ViteTaskParams): Promise<BuildResult> {\n try {\n const outputs = await build(viteConfig);\n if (!Array.isArray(outputs)) {\n return {\n error: true,\n errors: [errors.rollupError],\n };\n }\n\n return {\n error: false,\n output: outputs.flatMap((x) =>\n x.output.filter((x) => x.type === \"chunk\"),\n ),\n };\n } catch (e) {\n if (e instanceof Error) {\n return {\n error: true,\n errors: [e.message],\n };\n }\n }\n return {\n error: true,\n errors: [errors.rollupError],\n };\n}\n\nexport async function viteTask({ viteConfig }: ViteTaskParams) {\n const outputs = await buildVite({ viteConfig });\n if (outputs.error) {\n throw outputs.errors.map((e) => new BuildError(e));\n }\n\n okLog(\"Vite\");\n return outputs.output;\n}\n"],"names":["x"],"mappings":";;;;AAoBA,eAAsB,UAAU;AAAA,EAC9B;AACF,GAAyC;AACnC,MAAA;AACI,UAAA,UAAU,MAAM,MAAM,UAAU;AACtC,QAAI,CAAC,MAAM,QAAQ,OAAO,GAAG;AACpB,aAAA;AAAA,QACL,OAAO;AAAA,QACP,QAAQ,CAAC,OAAO,WAAW;AAAA,MAC7B;AAAA,IAAA;AAGK,WAAA;AAAA,MACL,OAAO;AAAA,MACP,QAAQ,QAAQ;AAAA,QAAQ,CAAC,MACvB,EAAE,OAAO,OAAO,CAACA,OAAMA,GAAE,SAAS,OAAO;AAAA,MAAA;AAAA,IAE7C;AAAA,WACO,GAAG;AACV,QAAI,aAAa,OAAO;AACf,aAAA;AAAA,QACL,OAAO;AAAA,QACP,QAAQ,CAAC,EAAE,OAAO;AAAA,MACpB;AAAA,IAAA;AAAA,EACF;AAEK,SAAA;AAAA,IACL,OAAO;AAAA,IACP,QAAQ,CAAC,OAAO,WAAW;AAAA,EAC7B;AACF;AAEsB,eAAA,SAAS,EAAE,cAA8B;AAC7D,QAAM,UAAU,MAAM,UAAU,EAAE,YAAY;AAC9C,MAAI,QAAQ,OAAO;AACX,UAAA,QAAQ,OAAO,IAAI,CAAC,MAAM,IAAI,WAAW,CAAC,CAAC;AAAA,EAAA;AAGnD,QAAM,MAAM;AACZ,SAAO,QAAQ;AACjB;"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"writePackageJson.mjs","sources":["../../../../src/writePackageJson.ts"],"sourcesContent":["import { writeFile } from \"node:fs/promises\";\nimport { type PackageJson } from \"./packageJson.js\";\nimport { okLog } from \"./log.js\";\n\nexport type ExportsObject = {\n mjs?: string;\n dmts?: string;\n dcts?: string;\n cjs?: string;\n raw?: string;\n};\n\ntype BuildResult = {\n exportsMap: Map<string, ExportsObject>;\n binsMap: Map<string, string>;\n};\n\ntype ExportsPackageJsonObj =\n | {\n import?: ExportsPackageJsonObj;\n require?: ExportsPackageJsonObj;\n types?: string;\n default?: string;\n }\n | string;\n\nfunction extractValue(value?: ExportsPackageJsonObj) {\n if (!value) {\n return undefined;\n }\n if (typeof value === \"string\") {\n return value;\n }\n return value.default;\n}\n\nexport async function writePackageJson(\n outDir: string,\n parsed: PackageJson,\n { exportsMap, binsMap }: BuildResult,\n) {\n // we always want to have `exports` property in the target package.json\n // If you want to export something, please, specify them\n const allExports: Record<string, ExportsPackageJsonObj> = {};\n for (const [key, value] of exportsMap) {\n const anExport: ExportsPackageJsonObj = {};\n\n if (value.mjs) {\n anExport.import = {};\n if (value.dmts) {\n anExport.import.types = value.dmts;\n }\n anExport.import.default = value.mjs;\n }\n if (value.cjs) {\n anExport.require = {};\n if (value.dcts) {\n anExport.require.types = value.dcts;\n }\n anExport.require.default = value.cjs;\n }\n\n // should be first for correct resolving\n anExport.types = value.dcts ?? value.dmts;\n // because we need to have default and types key on the end\n // JSON.stringify will put it on the end if we put value at the last step\n anExport.default = value.cjs;\n\n allExports[key] = anExport;\n }\n allExports[\"./package.json\"] = \"./package.json\";\n\n const bin = binsMap.size > 0 ? Object.fromEntries(binsMap) : undefined;\n\n const rootExport =\n typeof allExports[\".\"] === \"object\" ? allExports[\".\"] : undefined;\n const res = {\n name: parsed.name,\n type: \"commonjs\",\n version: parsed.version,\n bin,\n types: rootExport?.types,\n module: extractValue(rootExport?.import),\n main: extractValue(rootExport?.require),\n description: parsed.description ?? \"\",\n exports: allExports,\n dependencies: parsed.dependencies ?? undefined,\n optionalDependencies: parsed.optionalDependencies ?? undefined,\n repository: parsed.repository,\n keywords: parsed.keywords,\n author: parsed.author,\n contributors: parsed.contributors,\n license: parsed.license,\n peerDependencies: parsed.peerDependencies,\n engines: parsed.engines,\n browser: parsed.browser,\n funding: parsed.funding,\n os: parsed.os,\n cpu: parsed.cpu,\n maintainers: parsed.maintainers,\n bugs: parsed.bugs,\n sideEffects: parsed.sideEffects,\n unpkg: parsed.unpkg,\n homepage: parsed.homepage,\n devDependencies: parsed.devDependencies,\n peerDependenciesMeta: parsed.peerDependenciesMeta,\n };\n\n await writeFile(`${outDir}/package.json`, JSON.stringify(res, null, 2));\n\n okLog(\"package.json\");\n}\n"],"names":[],"mappings":";;;;AA0BA,SAAS,aAAa,OAA+B;AACnD,MAAI,CAAC,OAAO;AACH,WAAA;AAAA,
|
1
|
+
{"version":3,"file":"writePackageJson.mjs","sources":["../../../../src/writePackageJson.ts"],"sourcesContent":["import { writeFile } from \"node:fs/promises\";\nimport { type PackageJson } from \"./packageJson.js\";\nimport { okLog } from \"./log.js\";\n\nexport type ExportsObject = {\n mjs?: string;\n dmts?: string;\n dcts?: string;\n cjs?: string;\n raw?: string;\n};\n\ntype BuildResult = {\n exportsMap: Map<string, ExportsObject>;\n binsMap: Map<string, string>;\n};\n\ntype ExportsPackageJsonObj =\n | {\n import?: ExportsPackageJsonObj;\n require?: ExportsPackageJsonObj;\n types?: string;\n default?: string;\n }\n | string;\n\nfunction extractValue(value?: ExportsPackageJsonObj) {\n if (!value) {\n return undefined;\n }\n if (typeof value === \"string\") {\n return value;\n }\n return value.default;\n}\n\nexport async function writePackageJson(\n outDir: string,\n parsed: PackageJson,\n { exportsMap, binsMap }: BuildResult,\n) {\n // we always want to have `exports` property in the target package.json\n // If you want to export something, please, specify them\n const allExports: Record<string, ExportsPackageJsonObj> = {};\n for (const [key, value] of exportsMap) {\n const anExport: ExportsPackageJsonObj = {};\n\n if (value.mjs) {\n anExport.import = {};\n if (value.dmts) {\n anExport.import.types = value.dmts;\n }\n anExport.import.default = value.mjs;\n }\n if (value.cjs) {\n anExport.require = {};\n if (value.dcts) {\n anExport.require.types = value.dcts;\n }\n anExport.require.default = value.cjs;\n }\n\n // should be first for correct resolving\n anExport.types = value.dcts ?? value.dmts;\n // because we need to have default and types key on the end\n // JSON.stringify will put it on the end if we put value at the last step\n anExport.default = value.cjs;\n\n allExports[key] = anExport;\n }\n allExports[\"./package.json\"] = \"./package.json\";\n\n const bin = binsMap.size > 0 ? Object.fromEntries(binsMap) : undefined;\n\n const rootExport =\n typeof allExports[\".\"] === \"object\" ? allExports[\".\"] : undefined;\n const res = {\n name: parsed.name,\n type: \"commonjs\",\n version: parsed.version,\n bin,\n types: rootExport?.types,\n module: extractValue(rootExport?.import),\n main: extractValue(rootExport?.require),\n description: parsed.description ?? \"\",\n exports: allExports,\n dependencies: parsed.dependencies ?? undefined,\n optionalDependencies: parsed.optionalDependencies ?? undefined,\n repository: parsed.repository,\n keywords: parsed.keywords,\n author: parsed.author,\n contributors: parsed.contributors,\n license: parsed.license,\n peerDependencies: parsed.peerDependencies,\n engines: parsed.engines,\n browser: parsed.browser,\n funding: parsed.funding,\n os: parsed.os,\n cpu: parsed.cpu,\n maintainers: parsed.maintainers,\n bugs: parsed.bugs,\n sideEffects: parsed.sideEffects,\n unpkg: parsed.unpkg,\n homepage: parsed.homepage,\n devDependencies: parsed.devDependencies,\n peerDependenciesMeta: parsed.peerDependenciesMeta,\n };\n\n await writeFile(`${outDir}/package.json`, JSON.stringify(res, null, 2));\n\n okLog(\"package.json\");\n}\n"],"names":[],"mappings":";;;;AA0BA,SAAS,aAAa,OAA+B;AACnD,MAAI,CAAC,OAAO;AACH,WAAA;AAAA,EAAA;AAEL,MAAA,OAAO,UAAU,UAAU;AACtB,WAAA;AAAA,EAAA;AAET,SAAO,MAAM;AACf;AAEA,eAAsB,iBACpB,QACA,QACA,EAAE,YAAY,WACd;AAGA,QAAM,aAAoD,CAAC;AAC3D,aAAW,CAAC,KAAK,KAAK,KAAK,YAAY;AACrC,UAAM,WAAkC,CAAC;AAEzC,QAAI,MAAM,KAAK;AACb,eAAS,SAAS,CAAC;AACnB,UAAI,MAAM,MAAM;AACL,iBAAA,OAAO,QAAQ,MAAM;AAAA,MAAA;AAEvB,eAAA,OAAO,UAAU,MAAM;AAAA,IAAA;AAElC,QAAI,MAAM,KAAK;AACb,eAAS,UAAU,CAAC;AACpB,UAAI,MAAM,MAAM;AACL,iBAAA,QAAQ,QAAQ,MAAM;AAAA,MAAA;AAExB,eAAA,QAAQ,UAAU,MAAM;AAAA,IAAA;AAI1B,aAAA,QAAQ,MAAM,QAAQ,MAAM;AAGrC,aAAS,UAAU,MAAM;AAEzB,eAAW,GAAG,IAAI;AAAA,EAAA;AAEpB,aAAW,gBAAgB,IAAI;AAE/B,QAAM,MAAM,QAAQ,OAAO,IAAI,OAAO,YAAY,OAAO,IAAI;AAEvD,QAAA,aACJ,OAAO,WAAW,GAAG,MAAM,WAAW,WAAW,GAAG,IAAI;AAC1D,QAAM,MAAM;AAAA,IACV,MAAM,OAAO;AAAA,IACb,MAAM;AAAA,IACN,SAAS,OAAO;AAAA,IAChB;AAAA,IACA,OAAO,yCAAY;AAAA,IACnB,QAAQ,aAAa,yCAAY,MAAM;AAAA,IACvC,MAAM,aAAa,yCAAY,OAAO;AAAA,IACtC,aAAa,OAAO,eAAe;AAAA,IACnC,SAAS;AAAA,IACT,cAAc,OAAO,gBAAgB;AAAA,IACrC,sBAAsB,OAAO,wBAAwB;AAAA,IACrD,YAAY,OAAO;AAAA,IACnB,UAAU,OAAO;AAAA,IACjB,QAAQ,OAAO;AAAA,IACf,cAAc,OAAO;AAAA,IACrB,SAAS,OAAO;AAAA,IAChB,kBAAkB,OAAO;AAAA,IACzB,SAAS,OAAO;AAAA,IAChB,SAAS,OAAO;AAAA,IAChB,SAAS,OAAO;AAAA,IAChB,IAAI,OAAO;AAAA,IACX,KAAK,OAAO;AAAA,IACZ,aAAa,OAAO;AAAA,IACpB,MAAM,OAAO;AAAA,IACb,aAAa,OAAO;AAAA,IACpB,OAAO,OAAO;AAAA,IACd,UAAU,OAAO;AAAA,IACjB,iBAAiB,OAAO;AAAA,IACxB,sBAAsB,OAAO;AAAA,EAC/B;AAEM,QAAA,UAAU,GAAG,MAAM,iBAAiB,KAAK,UAAU,KAAK,MAAM,CAAC,CAAC;AAEtE,QAAM,cAAc;AACtB;"}
|
package/package.json
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
{
|
2
2
|
"name": "smartbundle",
|
3
3
|
"type": "commonjs",
|
4
|
-
"version": "0.
|
4
|
+
"version": "0.12.0",
|
5
5
|
"bin": {
|
6
6
|
"smartbundle": "__bin__/smartbundle.js"
|
7
7
|
},
|
@@ -28,7 +28,7 @@
|
|
28
28
|
"semver": "^7.6.3",
|
29
29
|
"vite": "^5.4.11",
|
30
30
|
"yargs": "^17.7.2",
|
31
|
-
"zod": "^3.
|
31
|
+
"zod": "^3.24.0"
|
32
32
|
},
|
33
33
|
"repository": {
|
34
34
|
"type": "git",
|
@@ -50,7 +50,8 @@
|
|
50
50
|
"license": "MIT",
|
51
51
|
"peerDependencies": {
|
52
52
|
"@babel/core": "^7.26.0",
|
53
|
-
"typescript": "^5.
|
53
|
+
"typescript": "^5.0.0",
|
54
|
+
"vitest": "^2.1.8"
|
54
55
|
},
|
55
56
|
"bugs": {
|
56
57
|
"url": "https://github.com/xavescor/smartbundle/issues"
|
@@ -58,14 +59,14 @@
|
|
58
59
|
"homepage": "https://github.com/xavescor/smartbundle",
|
59
60
|
"devDependencies": {
|
60
61
|
"@types/babel__core": "^7.20.5",
|
61
|
-
"@types/node": "^
|
62
|
+
"@types/node": "^22.10.1",
|
62
63
|
"@types/semver": "^7.5.8",
|
63
64
|
"@types/yargs": "^17.0.33",
|
64
|
-
"prettier": "^3.
|
65
|
-
"typescript": "^5.
|
66
|
-
"vitest": "^2.1.
|
67
|
-
"vitest-directory-snapshot": "^0.
|
68
|
-
"zx": "^8.2.
|
65
|
+
"prettier": "^3.4.2",
|
66
|
+
"typescript": "^5.7.2",
|
67
|
+
"vitest": "^2.1.8",
|
68
|
+
"vitest-directory-snapshot": "^0.3.0",
|
69
|
+
"zx": "^8.2.4"
|
69
70
|
},
|
70
71
|
"peerDependenciesMeta": {
|
71
72
|
"@babel/core": {
|
@@ -73,6 +74,9 @@
|
|
73
74
|
},
|
74
75
|
"typescript": {
|
75
76
|
"optional": true
|
77
|
+
},
|
78
|
+
"vitest": {
|
79
|
+
"optional": true
|
76
80
|
}
|
77
81
|
}
|
78
82
|
}
|
@@ -1,15 +0,0 @@
|
|
1
|
-
import { type UserConfig, type Rollup } from "vite";
|
2
|
-
type BuildViteOptions = {
|
3
|
-
viteConfig: UserConfig;
|
4
|
-
};
|
5
|
-
type BuildSuccess = {
|
6
|
-
error: false;
|
7
|
-
output: Rollup.OutputChunk[];
|
8
|
-
};
|
9
|
-
type BuildError = {
|
10
|
-
error: true;
|
11
|
-
errors: Array<string>;
|
12
|
-
};
|
13
|
-
type BuildResult = BuildSuccess | BuildError;
|
14
|
-
export declare function buildVite({ viteConfig, }: BuildViteOptions): Promise<BuildResult>;
|
15
|
-
export {};
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"buildVite.js","sources":["../../../../src/buildVite.ts"],"sourcesContent":["import { build, type UserConfig, type Rollup } from \"vite\";\nimport { errors } from \"./errors.js\";\n\ntype BuildViteOptions = {\n viteConfig: UserConfig;\n};\n\ntype BuildSuccess = {\n error: false;\n output: Rollup.OutputChunk[];\n};\ntype BuildError = {\n error: true;\n errors: Array<string>;\n};\n\ntype BuildResult = BuildSuccess | BuildError;\n\nexport async function buildVite({\n viteConfig,\n}: BuildViteOptions): Promise<BuildResult> {\n try {\n const outputs = await build(viteConfig);\n if (!Array.isArray(outputs)) {\n return {\n error: true,\n errors: [errors.rollupError],\n };\n }\n\n return {\n error: false,\n output: outputs.flatMap((x) =>\n x.output.filter((x) => x.type === \"chunk\"),\n ),\n };\n } catch (e) {\n if (e instanceof Error) {\n return {\n error: true,\n errors: [e.message],\n };\n }\n }\n return {\n error: true,\n errors: [errors.rollupError],\n };\n}\n"],"names":["build","errors","x"],"mappings":";;;;AAkBA,eAAsB,UAAU;AAAA,EAC9B;AACF,GAA2C;AACrC,MAAA;AACI,UAAA,UAAU,MAAMA,WAAM,UAAU;AACtC,QAAI,CAAC,MAAM,QAAQ,OAAO,GAAG;AACpB,aAAA;AAAA,QACL,OAAO;AAAA,QACP,QAAQ,CAACC,OAAA,OAAO,WAAW;AAAA,MAAA;AAAA,IAE/B;AAEO,WAAA;AAAA,MACL,OAAO;AAAA,MACP,QAAQ,QAAQ;AAAA,QAAQ,CAAC,MACvB,EAAE,OAAO,OAAO,CAACC,OAAMA,GAAE,SAAS,OAAO;AAAA,MAC3C;AAAA,IAAA;AAAA,WAEK,GAAG;AACV,QAAI,aAAa,OAAO;AACf,aAAA;AAAA,QACL,OAAO;AAAA,QACP,QAAQ,CAAC,EAAE,OAAO;AAAA,MAAA;AAAA,IAEtB;AAAA,EACF;AACO,SAAA;AAAA,IACL,OAAO;AAAA,IACP,QAAQ,CAACD,OAAA,OAAO,WAAW;AAAA,EAAA;AAE/B;;"}
|
@@ -1 +0,0 @@
|
|
1
|
-
export {};
|
@@ -1,15 +0,0 @@
|
|
1
|
-
import { type UserConfig, type Rollup } from "vite";
|
2
|
-
type BuildViteOptions = {
|
3
|
-
viteConfig: UserConfig;
|
4
|
-
};
|
5
|
-
type BuildSuccess = {
|
6
|
-
error: false;
|
7
|
-
output: Rollup.OutputChunk[];
|
8
|
-
};
|
9
|
-
type BuildError = {
|
10
|
-
error: true;
|
11
|
-
errors: Array<string>;
|
12
|
-
};
|
13
|
-
type BuildResult = BuildSuccess | BuildError;
|
14
|
-
export declare function buildVite({ viteConfig, }: BuildViteOptions): Promise<BuildResult>;
|
15
|
-
export {};
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"buildVite.mjs","sources":["../../../../src/buildVite.ts"],"sourcesContent":["import { build, type UserConfig, type Rollup } from \"vite\";\nimport { errors } from \"./errors.js\";\n\ntype BuildViteOptions = {\n viteConfig: UserConfig;\n};\n\ntype BuildSuccess = {\n error: false;\n output: Rollup.OutputChunk[];\n};\ntype BuildError = {\n error: true;\n errors: Array<string>;\n};\n\ntype BuildResult = BuildSuccess | BuildError;\n\nexport async function buildVite({\n viteConfig,\n}: BuildViteOptions): Promise<BuildResult> {\n try {\n const outputs = await build(viteConfig);\n if (!Array.isArray(outputs)) {\n return {\n error: true,\n errors: [errors.rollupError],\n };\n }\n\n return {\n error: false,\n output: outputs.flatMap((x) =>\n x.output.filter((x) => x.type === \"chunk\"),\n ),\n };\n } catch (e) {\n if (e instanceof Error) {\n return {\n error: true,\n errors: [e.message],\n };\n }\n }\n return {\n error: true,\n errors: [errors.rollupError],\n };\n}\n"],"names":["x"],"mappings":";;AAkBA,eAAsB,UAAU;AAAA,EAC9B;AACF,GAA2C;AACrC,MAAA;AACI,UAAA,UAAU,MAAM,MAAM,UAAU;AACtC,QAAI,CAAC,MAAM,QAAQ,OAAO,GAAG;AACpB,aAAA;AAAA,QACL,OAAO;AAAA,QACP,QAAQ,CAAC,OAAO,WAAW;AAAA,MAAA;AAAA,IAE/B;AAEO,WAAA;AAAA,MACL,OAAO;AAAA,MACP,QAAQ,QAAQ;AAAA,QAAQ,CAAC,MACvB,EAAE,OAAO,OAAO,CAACA,OAAMA,GAAE,SAAS,OAAO;AAAA,MAC3C;AAAA,IAAA;AAAA,WAEK,GAAG;AACV,QAAI,aAAa,OAAO;AACf,aAAA;AAAA,QACL,OAAO;AAAA,QACP,QAAQ,CAAC,EAAE,OAAO;AAAA,MAAA;AAAA,IAEtB;AAAA,EACF;AACO,SAAA;AAAA,IACL,OAAO;AAAA,IACP,QAAQ,CAAC,OAAO,WAAW;AAAA,EAAA;AAE/B;"}
|
@@ -1 +0,0 @@
|
|
1
|
-
export {};
|