chore: improve buildscript

This commit is contained in:
xxnuo
2026-01-01 17:13:45 +08:00
parent 8308383b18
commit ac45b5cd65
2 changed files with 44 additions and 12 deletions

View File

@@ -14,12 +14,12 @@
],
"scripts": {
"dev": "bun src/main.ts --log-level debug",
"build": "rm -rf dist && bun build src/main.ts --compile --outfile ./dist/mtranserver --minify --sourcemap",
"build:all": "bun scripts/build.ts",
"build": "bun scripts/build.ts --single",
"build:all": "bun scripts/build.ts --all",
"build:docker": "bun scripts/build.ts --docker",
"build:node": "bun run gen && rm -rf dist && bun build src/main.ts --outdir dist --target node --format esm --sourcemap --external zstd-wasm-decoder --external express",
"build:dev": "bun run gen && rm -rf dist && bun build src/main.ts --outdir dist --target node --format esm --sourcemap --external zstd-wasm-decoder --external express",
"build:lib": "bun run gen && rm -rf dist && rm -f ui/dist/assets/*.d.ts && bun build src/index.ts src/main.ts --outdir dist --target node --format esm --sourcemap --external zstd-wasm-decoder --external express && tsc -p tsconfig.lib.json",
"build:node": "bun scripts/build.ts --node",
"build:dev": "bun scripts/build.ts --dev",
"build:lib": "bun scripts/build.ts --lib",
"prepublishOnly": "bun run build:lib",
"start": "node dist/main.js",
"test": "bun test",

View File

@@ -1,8 +1,14 @@
import { $ } from "bun";
import fs from "fs";
import pkg from "../package.json";
const version = pkg.version;
const isDocker = Bun.argv.includes("--docker");
const args = new Set(Bun.argv.slice(2));
const isDocker = args.has("--docker");
const isLib = args.has("--lib");
const isNode = args.has("--node") || args.has("--dev") || isDocker;
const isSingle = args.has("--single");
const isAll = args.has("--all") || (!isLib && !isNode && !isSingle);
const allTargets = [
{ bun: "bun-darwin-x64", name: "darwin-amd64" },
@@ -22,8 +28,15 @@ console.log("Cleaning dist...");
await $`rm -rf dist`;
await $`mkdir -p dist`;
if (isLib) {
await $`rm -f ui/dist/assets/*.d.ts`;
}
console.log("Building UI...");
await $`cd ui && bun install && bun run build`;
if (!fs.existsSync("ui/node_modules")) {
await $`cd ui && bun install`;
}
await $`cd ui && bun run build`;
console.log("Generating UI assets map...");
await $`bun run scripts/gen-ui-assets.ts`;
@@ -34,15 +47,34 @@ await $`bun run scripts/gen-swagger-assets.ts`;
console.log("Generating routes and spec...");
await $`bun run gen`;
if (isDocker) {
console.log("Building for Docker...");
await $`bun run build:node`;
} else {
if (isLib) {
console.log("Building library...");
await $`bun build src/index.ts src/main.ts --outdir dist --target node --format esm --sourcemap --external zstd-wasm-decoder --external express`;
await $`tsc -p tsconfig.lib.json`;
console.log("Build complete!");
process.exit(0);
}
if (isNode) {
console.log("Building for Node...");
await $`bun build src/main.ts --outdir dist --target node --format esm --sourcemap --external zstd-wasm-decoder --external express`;
console.log("Build complete!");
process.exit(0);
}
if (isSingle) {
console.log("Building single binary...");
await $`bun build src/main.ts --compile --outfile ./dist/mtranserver --minify --sourcemap`;
console.log("Build complete!");
process.exit(0);
}
if (isAll) {
for (const target of allTargets) {
const ext = target.bun.includes("windows") ? ".exe" : "";
const outfile = `dist/mtranserver-${version}-${target.name}${ext}`;
console.log(`Building for ${target.bun} -> ${outfile}...`);
await $`bun build src/main.ts --compile --target=${target.bun} --outfile=${outfile} --minify --sourcemap`;
}
console.log("Build complete!");
}
console.log("Build complete!");