From f49bfd6c085cbf28a25d9404f8dc5b74368b716a Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期五, 29 五月 2026 15:54:02 +0800
Subject: [PATCH] 新疆马铃薯 1.代码更新
---
multiple/multiple-build.js | 188 +++++++++++++++-------------------------------
1 files changed, 61 insertions(+), 127 deletions(-)
diff --git a/multiple/multiple-build.js b/multiple/multiple-build.js
index afcd4d5..8e078e1 100644
--- a/multiple/multiple-build.js
+++ b/multiple/multiple-build.js
@@ -1,152 +1,86 @@
-import fs from "fs/promises";
-import fsSync from "fs";
-import path from "path";
-import { fileURLToPath } from "url";
+import fs from 'fs/promises';
+import fsSync from 'fs';
+import path from 'path';
+import { fileURLToPath } from 'url';
import { execSync } from "child_process";
+// 鑾峰彇 __dirname
const __filename = fileURLToPath(import.meta.url);
const __dirname = path.dirname(__filename);
-const data = await fs.readFile(path.join(__dirname, "config.json"), "utf-8");
+// 璇诲彇 JSON 閰嶇疆
+const data = await fs.readFile(path.join(__dirname, 'config.json'), 'utf-8');
const config = JSON.parse(data);
-const rootPath = path.resolve(__dirname, "..");
-const resourcePath = path.join(rootPath, "multiple", "assets");
-const replacePath = path.join(rootPath, "replace");
-const envFilePath = path.join(rootPath, ".env.production.local");
+// 椤圭洰璺緞
+const rootPath = path.resolve(__dirname, '..');
+const resourcePath = path.join(rootPath, 'multiple', 'assets');
+const replacePath = path.join(rootPath, 'replace');
+// 鑾峰彇鍛戒护琛屽弬鏁�
const params = parseArgs(process.argv);
-const company = resolveCompany(params);
+const company = params["company"] ?? "default";
const companyMap = config[company];
-if (!companyMap) {
- const availableCompanies = Object.entries(config)
- .filter(([, value]) => value && typeof value === "object" && value.env)
- .map(([key]) => key)
- .sort();
- throw new Error(
- `鏈煡 company: "${company}"銆傚彲閫夊��: ${availableCompanies.join(", ")}`
- );
-}
-
-console.log(`褰撳墠 company: ${company}`);
-
-async function copyFileWithOverwrite(src, dest) {
- await fs.mkdir(path.dirname(dest), { recursive: true });
- if (fsSync.existsSync(dest)) {
- try {
- await fs.chmod(dest, 0o666);
- } catch {
- // Ignore chmod failure and continue.
- }
- await fs.rm(dest, { force: true });
- }
- await fs.copyFile(src, dest);
-}
+const envFilePath = path.join(process.cwd(), '.env.production.local');
try {
- console.log("=======鐢熸垚.env=======");
- const envContent =
- Object.entries(companyMap.env)
- .map(([key, value]) => `${key}='${value}'`)
- .join("\n") + "\n";
- await fs.writeFile(envFilePath, envContent, "utf-8");
+ // 1锔忊儯 鐢熸垚 .env
+ console.log("=======鐢熸垚.env=======");
+ const envContent = Object.entries(companyMap.env)
+ .map(([key, value]) => `${key}='${value}'`)
+ .join('\n') + '\n';
+ await fs.writeFile(envFilePath, envContent, 'utf-8');
- console.log("=======淇敼璧勬簮=======");
- for (const [key] of Object.entries(companyMap)) {
- if (key === "env") continue;
+ // 2锔忊儯 澶囦唤鍘熷璧勬簮骞舵浛鎹�
+ console.log("=======淇敼璧勬簮=======");
+ for (const [key, value] of Object.entries(companyMap)) {
+ if (key === 'env') continue;
- const originFile = path.join(rootPath, config[key]);
- const backupFile = path.join(replacePath, config[key]);
- const replaceFile = path.join(resourcePath, companyMap[key]);
+ const originFile = path.join(rootPath, config[key]);
+ const backupFile = path.join(replacePath, config[key]);
+ const replaceFile = path.join(resourcePath, companyMap[key]);
- await copyFileWithOverwrite(originFile, backupFile);
- await copyFileWithOverwrite(replaceFile, originFile);
- }
+ await fs.mkdir(path.dirname(backupFile), { recursive: true });
+ await fs.copyFile(originFile, backupFile);
+ await fs.copyFile(replaceFile, originFile);
+ }
- console.log("=====寮�濮嬫墦鍖�=====");
- const buildEnv = createBuildEnv(companyMap.env);
- execSync("vite build", { stdio: "inherit", cwd: rootPath, env: buildEnv });
- console.log("=====鎵撳寘瀹屾垚======");
+ console.log("=====寮�濮嬫墦鍖�======");
+ execSync("vite build", { stdio: "inherit" });
+ console.log("=====鎵撳寘瀹屾垚======");
} finally {
- console.log("=====鎭㈠璧勬簮======");
+ console.log("=====鎭㈠璧勬簮======");
- if (fsSync.existsSync(envFilePath)) {
- await fs.unlink(envFilePath);
- console.log(`馃棏锔� 宸插垹闄� ${envFilePath}`);
- }
-
- if (fsSync.existsSync(replacePath)) {
- for (const [key] of Object.entries(companyMap)) {
- if (key === "env") continue;
-
- const originFile = path.join(rootPath, config[key]);
- const backupFile = path.join(replacePath, config[key]);
- await copyFileWithOverwrite(backupFile, originFile);
+ // 鍒犻櫎涓存椂 .env 鏂囦欢
+ if (fsSync.existsSync(envFilePath)) {
+ await fs.unlink(envFilePath);
+ console.log(`馃棏锔� 宸插垹闄� ${envFilePath}`);
}
- await fs.rm(replacePath, { recursive: true, force: true });
- console.log(`馃棏锔� 宸插垹闄� ${replacePath}`);
- }
+
+ // 鎭㈠璧勬簮鏂囦欢
+ if (fsSync.existsSync(replacePath)) {
+ for (const [key, value] of Object.entries(companyMap)) {
+ if (key === 'env') continue;
+
+ const originFile = path.join(rootPath, config[key]);
+ const backupFile = path.join(replacePath, config[key]);
+
+ await fs.copyFile(backupFile, originFile);
+ }
+ await fs.rm(replacePath, { recursive: true, force: true });
+ console.log(`馃棏锔� 宸插垹闄� ${replacePath}`);
+ }
}
+// 绠�鍗曞懡浠よ鍙傛暟瑙f瀽
function parseArgs(argv) {
- const params = {};
- for (let index = 2; index < argv.length; index++) {
- const arg = argv[index];
- if (!arg.startsWith("--")) continue;
-
- const normalized = arg.slice(2);
- const equalIndex = normalized.indexOf("=");
- if (equalIndex >= 0) {
- const key = normalized.slice(0, equalIndex);
- const value = normalized.slice(equalIndex + 1);
- params[key] = value || true;
- continue;
+ const params = {};
+ for (const arg of argv.slice(2)) {
+ if (arg.startsWith('--')) {
+ const [key, value] = arg.slice(2).split('=');
+ params[key] = value ?? true;
+ }
}
-
- const nextArg = argv[index + 1];
- if (nextArg && !nextArg.startsWith("--")) {
- params[normalized] = nextArg;
- index += 1;
- continue;
- }
-
- params[normalized] = true;
- }
- return params;
-}
-
-function resolveCompany(parsedParams) {
- const fromArg = parseValue(parsedParams.company);
- if (fromArg) return fromArg;
-
- const fromNpmConfig = parseValue(process.env.npm_config_company);
- if (fromNpmConfig) return fromNpmConfig;
-
- const fromEnv = parseValue(process.env.COMPANY ?? process.env.company);
- if (fromEnv) return fromEnv;
-
- return "default";
-}
-
-function parseValue(value) {
- if (value == null || value === true) return undefined;
- if (typeof value !== "string") return undefined;
- const trimmed = value.trim();
- if (!trimmed) return undefined;
- return trimmed.replace(/^["']|["']$/g, "");
-}
-
-function createBuildEnv(companyEnv) {
- const env = { ...process.env };
- for (const key of Object.keys(env)) {
- if (key.startsWith("VITE_")) {
- delete env[key];
- }
- }
- return {
- ...env,
- ...companyEnv,
- VITE_APP_ENV: "production",
- };
+ return params;
}
--
Gitblit v1.9.3