polyforge-cli 0.1.1 → 0.1.2

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.
@@ -18,13 +18,27 @@ function run(cmd, args, cwd) {
18
18
  });
19
19
  });
20
20
  }
21
+ async function installNodeDeps(pm, cwd) {
22
+ try {
23
+ await run(pm, ["install"], cwd);
24
+ return;
25
+ }
26
+ catch (error) {
27
+ if (pm === "npm") {
28
+ console.warn("[scaffold] npm install failed, retrying with --legacy-peer-deps");
29
+ await run("npm", ["install", "--legacy-peer-deps"], cwd);
30
+ return;
31
+ }
32
+ throw error;
33
+ }
34
+ }
21
35
  async function maybeInstallDeps(config) {
22
36
  if (!config.installDeps)
23
37
  return;
24
38
  if (config.frontend !== "none") {
25
39
  const webDir = path_1.default.join(config.targetDir, "apps", "web");
26
40
  if ((0, fs_1.existsSync)(path_1.default.join(webDir, "package.json"))) {
27
- await run(config.packageManager, ["install"], webDir);
41
+ await installNodeDeps(config.packageManager, webDir);
28
42
  }
29
43
  }
30
44
  if (config.extraModules.includes("python-worker")) {
@@ -41,13 +55,13 @@ async function maybeInstallDeps(config) {
41
55
  if (config.extraModules.includes("gateway-bff")) {
42
56
  const bffDir = path_1.default.join(config.targetDir, "apps", "gateway-bff");
43
57
  if ((0, fs_1.existsSync)(path_1.default.join(bffDir, "package.json"))) {
44
- await run(config.packageManager, ["install"], bffDir);
58
+ await installNodeDeps(config.packageManager, bffDir);
45
59
  }
46
60
  }
47
61
  if (config.extraModules.includes("auth-center")) {
48
62
  const authDir = path_1.default.join(config.targetDir, "apps", "auth-center");
49
63
  if ((0, fs_1.existsSync)(path_1.default.join(authDir, "package.json"))) {
50
- await run(config.packageManager, ["install"], authDir);
64
+ await installNodeDeps(config.packageManager, authDir);
51
65
  }
52
66
  }
53
67
  if (config.extraModules.includes("python-ai")) {
@@ -64,7 +78,7 @@ async function maybeInstallDeps(config) {
64
78
  if (config.extraModules.includes("mq")) {
65
79
  const mqDir = path_1.default.join(config.targetDir, "apps", "mq-worker");
66
80
  if ((0, fs_1.existsSync)(path_1.default.join(mqDir, "package.json"))) {
67
- await run(config.packageManager, ["install"], mqDir);
81
+ await installNodeDeps(config.packageManager, mqDir);
68
82
  }
69
83
  }
70
84
  }
package/dist/index.js CHANGED
@@ -6,7 +6,7 @@ const create_1 = require("./commands/create");
6
6
  const doctor_1 = require("./commands/doctor");
7
7
  const list_1 = require("./commands/list");
8
8
  const program = new commander_1.Command();
9
- program.name("scaffold").description("Hybrid full-stack scaffold CLI").version("0.1.0");
9
+ program.name("scaffold").description("Hybrid full-stack scaffold CLI").version("0.1.2");
10
10
  program
11
11
  .command("create")
12
12
  .argument("<project-name>", "project name")
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "polyforge-cli",
3
- "version": "0.1.1",
3
+ "version": "0.1.2",
4
4
  "description": "PolyForge hybrid full-stack scaffold CLI for go-gin and springboot",
5
5
  "main": "dist/index.js",
6
6
  "files": [