@simplysm/sd-cli 14.0.66 → 14.0.70

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 (99) hide show
  1. package/dist/commands/init/generators/client-common.d.ts +3 -0
  2. package/dist/commands/init/generators/client-common.d.ts.map +1 -0
  3. package/dist/commands/init/generators/client-common.js +17 -0
  4. package/dist/commands/init/generators/client-common.js.map +1 -0
  5. package/dist/commands/init/generators/client.d.ts +3 -0
  6. package/dist/commands/init/generators/client.d.ts.map +1 -0
  7. package/dist/commands/init/generators/client.js +20 -0
  8. package/dist/commands/init/generators/client.js.map +1 -0
  9. package/dist/commands/init/generators/common.d.ts +3 -0
  10. package/dist/commands/init/generators/common.d.ts.map +1 -0
  11. package/dist/commands/init/generators/common.js +14 -0
  12. package/dist/commands/init/generators/common.js.map +1 -0
  13. package/dist/commands/init/generators/root.d.ts +3 -0
  14. package/dist/commands/init/generators/root.d.ts.map +1 -0
  15. package/dist/commands/init/generators/root.js +28 -0
  16. package/dist/commands/init/generators/root.js.map +1 -0
  17. package/dist/commands/init/generators/server.d.ts +3 -0
  18. package/dist/commands/init/generators/server.d.ts.map +1 -0
  19. package/dist/commands/init/generators/server.js +11 -0
  20. package/dist/commands/init/generators/server.js.map +1 -0
  21. package/dist/commands/init/init.d.ts +5 -0
  22. package/dist/commands/init/init.d.ts.map +1 -0
  23. package/dist/commands/init/init.js +44 -0
  24. package/dist/commands/init/init.js.map +1 -0
  25. package/dist/commands/init/normalize.d.ts +3 -0
  26. package/dist/commands/init/normalize.d.ts.map +1 -0
  27. package/dist/commands/init/normalize.js +42 -0
  28. package/dist/commands/init/normalize.js.map +1 -0
  29. package/dist/commands/init/prompts.d.ts +3 -0
  30. package/dist/commands/init/prompts.d.ts.map +1 -0
  31. package/dist/commands/init/prompts.js +89 -0
  32. package/dist/commands/init/prompts.js.map +1 -0
  33. package/dist/commands/init/render.d.ts +4 -0
  34. package/dist/commands/init/render.d.ts.map +1 -0
  35. package/dist/commands/init/render.js +20 -0
  36. package/dist/commands/init/render.js.map +1 -0
  37. package/dist/commands/init/template-paths.d.ts +2 -0
  38. package/dist/commands/init/template-paths.d.ts.map +1 -0
  39. package/dist/commands/init/template-paths.js +7 -0
  40. package/dist/commands/init/template-paths.js.map +1 -0
  41. package/dist/commands/init/types.d.ts +47 -0
  42. package/dist/commands/init/types.d.ts.map +1 -0
  43. package/dist/commands/init/types.js +2 -0
  44. package/dist/commands/init/types.js.map +1 -0
  45. package/dist/commands/init/validate.d.ts +4 -0
  46. package/dist/commands/init/validate.d.ts.map +1 -0
  47. package/dist/commands/init/validate.js +31 -0
  48. package/dist/commands/init/validate.js.map +1 -0
  49. package/dist/sd-cli-entry.d.ts.map +1 -1
  50. package/dist/sd-cli-entry.js +14 -1
  51. package/dist/sd-cli-entry.js.map +1 -1
  52. package/package.json +5 -4
  53. package/src/commands/init/generators/client-common.ts +29 -0
  54. package/src/commands/init/generators/client.ts +29 -0
  55. package/src/commands/init/generators/common.ts +22 -0
  56. package/src/commands/init/generators/root.ts +32 -0
  57. package/src/commands/init/generators/server.ts +15 -0
  58. package/src/commands/init/init.ts +54 -0
  59. package/src/commands/init/normalize.ts +46 -0
  60. package/src/commands/init/prompts.ts +101 -0
  61. package/src/commands/init/render.ts +25 -0
  62. package/src/commands/init/template-paths.ts +8 -0
  63. package/src/commands/init/templates/client/ngsw-config.json +27 -0
  64. package/src/commands/init/templates/client/package.json.hbs +29 -0
  65. package/src/commands/init/templates/client/src/AppPage.ts.hbs +18 -0
  66. package/src/commands/init/templates/client/src/index.html.hbs +12 -0
  67. package/src/commands/init/templates/client/src/main.ts.hbs +28 -0
  68. package/src/commands/init/templates/client/src/polyfills.ts +2 -0
  69. package/src/commands/init/templates/client/src/routes.ts +3 -0
  70. package/src/commands/init/templates/client/src/styles.scss +1 -0
  71. package/src/commands/init/templates/client/tsconfig.json +20 -0
  72. package/src/commands/init/templates/client-common/package.json.hbs +20 -0
  73. package/src/commands/init/templates/client-common/src/index.ts.hbs +11 -0
  74. package/src/commands/init/templates/client-common/src/providers/AppOrmProvider.ts.hbs +36 -0
  75. package/src/commands/init/templates/client-common/src/providers/AppServiceProvider.ts +27 -0
  76. package/src/commands/init/templates/client-common/tsconfig.json +20 -0
  77. package/src/commands/init/templates/common/package.json.hbs +10 -0
  78. package/src/commands/init/templates/common/src/MainDbContext.ts +4 -0
  79. package/src/commands/init/templates/common/src/index.ts.hbs +5 -0
  80. package/src/commands/init/templates/common/tsconfig.json +8 -0
  81. package/src/commands/init/templates/server/package.json.hbs +23 -0
  82. package/src/commands/init/templates/server/src/main.ts.hbs +25 -0
  83. package/src/commands/init/templates/server/tsconfig.json +8 -0
  84. package/src/commands/init/templates/workspace-root/.prettierignore +1 -0
  85. package/src/commands/init/templates/workspace-root/.prettierrc.yaml +12 -0
  86. package/src/commands/init/templates/workspace-root/eslint.config.ts +4 -0
  87. package/src/commands/init/templates/workspace-root/mise.toml.hbs +7 -0
  88. package/src/commands/init/templates/workspace-root/package.json.hbs +43 -0
  89. package/src/commands/init/templates/workspace-root/pnpm-workspace.yaml +17 -0
  90. package/src/commands/init/templates/workspace-root/sd.config.ts.hbs +63 -0
  91. package/src/commands/init/templates/workspace-root/tsconfig.json.hbs +30 -0
  92. package/src/commands/init/templates/workspace-root/vitest.config.ts.hbs +72 -0
  93. package/src/commands/init/types.ts +51 -0
  94. package/src/commands/init/validate.ts +41 -0
  95. package/src/sd-cli-entry.ts +19 -1
  96. package/tests/init/__snapshots__/render.spec.ts.snap +213 -0
  97. package/tests/init/normalize.spec.ts +114 -0
  98. package/tests/init/render.spec.ts +216 -0
  99. package/tests/init/validate.spec.ts +80 -0
@@ -0,0 +1,3 @@
1
+ import type { RenderData } from "../types";
2
+ export declare function generateClientCommon(cwd: string, data: RenderData): Promise<void>;
3
+ //# sourceMappingURL=client-common.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client-common.d.ts","sourceRoot":"","sources":["../../../../src/commands/init/generators/client-common.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAI3C,wBAAsB,oBAAoB,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAqBvF"}
@@ -0,0 +1,17 @@
1
+ import path from "path";
2
+ import { copyFixed, renderToFile } from "../render.js";
3
+ import { TEMPLATES_ROOT } from "../template-paths.js";
4
+ const TPL = path.join(TEMPLATES_ROOT, "client-common");
5
+ export async function generateClientCommon(cwd, data) {
6
+ const out = path.resolve(cwd, "packages/client-common");
7
+ await copyFixed(path.join(TPL, "tsconfig.json"), path.join(out, "tsconfig.json"));
8
+ await renderToFile(path.join(TPL, "package.json.hbs"), path.join(out, "package.json"), data);
9
+ await renderToFile(path.join(TPL, "src/index.ts.hbs"), path.join(out, "src/index.ts"), data);
10
+ if (data.hasServer) {
11
+ await copyFixed(path.join(TPL, "src/providers/AppServiceProvider.ts"), path.join(out, "src/providers/AppServiceProvider.ts"));
12
+ }
13
+ if (data.hasDb) {
14
+ await renderToFile(path.join(TPL, "src/providers/AppOrmProvider.ts.hbs"), path.join(out, "src/providers/AppOrmProvider.ts"), data);
15
+ }
16
+ }
17
+ //# sourceMappingURL=client-common.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client-common.js","sourceRoot":"","sources":["../../../../src/commands/init/generators/client-common.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAGnD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,eAAe,CAAC,CAAC;AAEvD,MAAM,CAAC,KAAK,UAAU,oBAAoB,CAAC,GAAW,EAAE,IAAgB;IACtE,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,wBAAwB,CAAC,CAAC;IAExD,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC,CAAC;IAElF,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,CAAC;IAC7F,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,CAAC;IAE7F,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;QACnB,MAAM,SAAS,CACb,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,qCAAqC,CAAC,EACrD,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,qCAAqC,CAAC,CACtD,CAAC;IACJ,CAAC;IACD,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,MAAM,YAAY,CAChB,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,qCAAqC,CAAC,EACrD,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,iCAAiC,CAAC,EACjD,IAAI,CACL,CAAC;IACJ,CAAC;AACH,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { ClientSpec, RenderData } from "../types";
2
+ export declare function generateClient(cwd: string, base: RenderData, client: ClientSpec): Promise<void>;
3
+ //# sourceMappingURL=client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../../src/commands/init/generators/client.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAIvD,wBAAsB,cAAc,CAClC,GAAG,EAAE,MAAM,EACX,IAAI,EAAE,UAAU,EAChB,MAAM,EAAE,UAAU,GACjB,OAAO,CAAC,IAAI,CAAC,CAiBf"}
@@ -0,0 +1,20 @@
1
+ import path from "path";
2
+ import { copyFixed, renderToFile } from "../render.js";
3
+ import { TEMPLATES_ROOT } from "../template-paths.js";
4
+ const TPL = path.join(TEMPLATES_ROOT, "client");
5
+ export async function generateClient(cwd, base, client) {
6
+ const out = path.resolve(cwd, "packages", client.name);
7
+ const data = { ...base, client };
8
+ await copyFixed(path.join(TPL, "tsconfig.json"), path.join(out, "tsconfig.json"));
9
+ await copyFixed(path.join(TPL, "ngsw-config.json"), path.join(out, "ngsw-config.json"));
10
+ await copyFixed(path.join(TPL, "src/polyfills.ts"), path.join(out, "src/polyfills.ts"));
11
+ await copyFixed(path.join(TPL, "src/styles.scss"), path.join(out, "src/styles.scss"));
12
+ await renderToFile(path.join(TPL, "package.json.hbs"), path.join(out, "package.json"), data);
13
+ await renderToFile(path.join(TPL, "src/main.ts.hbs"), path.join(out, "src/main.ts"), data);
14
+ await renderToFile(path.join(TPL, "src/AppPage.ts.hbs"), path.join(out, "src/AppPage.ts"), data);
15
+ await renderToFile(path.join(TPL, "src/index.html.hbs"), path.join(out, "src/index.html"), data);
16
+ if (client.hasRouter) {
17
+ await copyFixed(path.join(TPL, "src/routes.ts"), path.join(out, "src/routes.ts"));
18
+ }
19
+ }
20
+ //# sourceMappingURL=client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.js","sourceRoot":"","sources":["../../../../src/commands/init/generators/client.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAGnD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAC;AAEhD,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,GAAW,EACX,IAAgB,EAChB,MAAkB;IAElB,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;IACvD,MAAM,IAAI,GAAG,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,CAAC;IAEjC,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC,CAAC;IAClF,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,CAAC,CAAC;IACxF,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,CAAC,CAAC;IACxF,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,iBAAiB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,iBAAiB,CAAC,CAAC,CAAC;IAEtF,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,CAAC;IAC7F,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,iBAAiB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,aAAa,CAAC,EAAE,IAAI,CAAC,CAAC;IAC3F,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,oBAAoB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,gBAAgB,CAAC,EAAE,IAAI,CAAC,CAAC;IACjG,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,oBAAoB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,gBAAgB,CAAC,EAAE,IAAI,CAAC,CAAC;IAEjG,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;QACrB,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC,CAAC;IACpF,CAAC;AACH,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { RenderData } from "../types";
2
+ export declare function generateCommon(cwd: string, data: RenderData): Promise<void>;
3
+ //# sourceMappingURL=common.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../../../src/commands/init/generators/common.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAI3C,wBAAsB,cAAc,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAcjF"}
@@ -0,0 +1,14 @@
1
+ import path from "path";
2
+ import { copyFixed, renderToFile } from "../render.js";
3
+ import { TEMPLATES_ROOT } from "../template-paths.js";
4
+ const TPL = path.join(TEMPLATES_ROOT, "common");
5
+ export async function generateCommon(cwd, data) {
6
+ const out = path.resolve(cwd, "packages/common");
7
+ await copyFixed(path.join(TPL, "tsconfig.json"), path.join(out, "tsconfig.json"));
8
+ await renderToFile(path.join(TPL, "package.json.hbs"), path.join(out, "package.json"), data);
9
+ await renderToFile(path.join(TPL, "src/index.ts.hbs"), path.join(out, "src/index.ts"), data);
10
+ if (data.hasDb) {
11
+ await copyFixed(path.join(TPL, "src/MainDbContext.ts"), path.join(out, "src/MainDbContext.ts"));
12
+ }
13
+ }
14
+ //# sourceMappingURL=common.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"common.js","sourceRoot":"","sources":["../../../../src/commands/init/generators/common.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAGnD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAC;AAEhD,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,GAAW,EAAE,IAAgB;IAChE,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,iBAAiB,CAAC,CAAC;IAEjD,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC,CAAC;IAElF,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,CAAC;IAC7F,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,CAAC;IAE7F,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,MAAM,SAAS,CACb,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,sBAAsB,CAAC,EACtC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,sBAAsB,CAAC,CACvC,CAAC;IACJ,CAAC;AACH,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { RenderData } from "../types";
2
+ export declare function generateRoot(cwd: string, data: RenderData): Promise<void>;
3
+ //# sourceMappingURL=root.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"root.d.ts","sourceRoot":"","sources":["../../../../src/commands/init/generators/root.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAqB3C,wBAAsB,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAO/E"}
@@ -0,0 +1,28 @@
1
+ import path from "path";
2
+ import { copyFixed, renderToFile } from "../render.js";
3
+ import { TEMPLATES_ROOT } from "../template-paths.js";
4
+ const TPL = path.join(TEMPLATES_ROOT, "workspace-root");
5
+ const FIXED = [
6
+ ".gitignore",
7
+ ".npmrc",
8
+ ".prettierignore",
9
+ ".prettierrc.yaml",
10
+ "eslint.config.ts",
11
+ "pnpm-workspace.yaml",
12
+ ];
13
+ const HBS = [
14
+ "mise.toml",
15
+ "package.json",
16
+ "tsconfig.json",
17
+ "sd.config.ts",
18
+ "vitest.config.ts",
19
+ ];
20
+ export async function generateRoot(cwd, data) {
21
+ for (const name of FIXED) {
22
+ await copyFixed(path.join(TPL, name), path.join(cwd, name));
23
+ }
24
+ for (const name of HBS) {
25
+ await renderToFile(path.join(TPL, `${name}.hbs`), path.join(cwd, name), data);
26
+ }
27
+ }
28
+ //# sourceMappingURL=root.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"root.js","sourceRoot":"","sources":["../../../../src/commands/init/generators/root.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAGnD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,gBAAgB,CAAC,CAAC;AAExD,MAAM,KAAK,GAAG;IACZ,YAAY;IACZ,QAAQ;IACR,iBAAiB;IACjB,kBAAkB;IAClB,kBAAkB;IAClB,qBAAqB;CACtB,CAAC;AAEF,MAAM,GAAG,GAAG;IACV,WAAW;IACX,cAAc;IACd,eAAe;IACf,cAAc;IACd,kBAAkB;CACnB,CAAC;AAEF,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,GAAW,EAAE,IAAgB;IAC9D,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;IAC9D,CAAC;IACD,KAAK,MAAM,IAAI,IAAI,GAAG,EAAE,CAAC;QACvB,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,MAAM,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;IAChF,CAAC;AACH,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { RenderData } from "../types";
2
+ export declare function generateServer(cwd: string, data: RenderData): Promise<void>;
3
+ //# sourceMappingURL=server.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../../../src/commands/init/generators/server.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAI3C,wBAAsB,cAAc,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAOjF"}
@@ -0,0 +1,11 @@
1
+ import path from "path";
2
+ import { copyFixed, renderToFile } from "../render.js";
3
+ import { TEMPLATES_ROOT } from "../template-paths.js";
4
+ const TPL = path.join(TEMPLATES_ROOT, "server");
5
+ export async function generateServer(cwd, data) {
6
+ const out = path.resolve(cwd, "packages/server");
7
+ await copyFixed(path.join(TPL, "tsconfig.json"), path.join(out, "tsconfig.json"));
8
+ await renderToFile(path.join(TPL, "package.json.hbs"), path.join(out, "package.json"), data);
9
+ await renderToFile(path.join(TPL, "src/main.ts.hbs"), path.join(out, "src/main.ts"), data);
10
+ }
11
+ //# sourceMappingURL=server.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.js","sourceRoot":"","sources":["../../../../src/commands/init/generators/server.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAGnD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAC;AAEhD,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,GAAW,EAAE,IAAgB;IAChE,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,iBAAiB,CAAC,CAAC;IAEjD,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC,CAAC;IAElF,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,CAAC;IAC7F,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,iBAAiB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,aAAa,CAAC,EAAE,IAAI,CAAC,CAAC;AAC7F,CAAC"}
@@ -0,0 +1,5 @@
1
+ export interface InitOptions {
2
+ cwd: string;
3
+ }
4
+ export declare function runInit(opts: InitOptions): Promise<void>;
5
+ //# sourceMappingURL=init.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../../../src/commands/init/init.ts"],"names":[],"mappings":"AAcA,MAAM,WAAW,WAAW;IAC1B,GAAG,EAAE,MAAM,CAAC;CACb;AAED,wBAAsB,OAAO,CAAC,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAmC9D"}
@@ -0,0 +1,44 @@
1
+ import crypto from "crypto";
2
+ import { createLazyLogger } from "../../runtime/lazy-logger.js";
3
+ import { generateClient } from "./generators/client.js";
4
+ import { generateClientCommon } from "./generators/client-common.js";
5
+ import { generateCommon } from "./generators/common.js";
6
+ import { generateRoot } from "./generators/root.js";
7
+ import { generateServer } from "./generators/server.js";
8
+ import { normalize } from "./normalize.js";
9
+ import { promptInit } from "./prompts.js";
10
+ import { validateBeforePrompt, validateInput } from "./validate.js";
11
+ const logger = createLazyLogger("sd:cli:init");
12
+ export async function runInit(opts) {
13
+ await validateBeforePrompt(opts.cwd);
14
+ const input = await promptInit();
15
+ validateInput(input);
16
+ const normalized = normalize(input);
17
+ const data = {
18
+ ...normalized,
19
+ jwtSecret: crypto.randomBytes(32).toString("hex"),
20
+ };
21
+ logger.info(`워크스페이스 부트스트랩 시작: ${opts.cwd}`);
22
+ await generateRoot(opts.cwd, data);
23
+ if (data.hasServer)
24
+ await generateServer(opts.cwd, data);
25
+ if (data.hasCommon)
26
+ await generateCommon(opts.cwd, data);
27
+ if (data.hasClientCommon)
28
+ await generateClientCommon(opts.cwd, data);
29
+ for (const client of data.clients) {
30
+ await generateClient(opts.cwd, data, client);
31
+ }
32
+ logger.info("워크스페이스 부트스트랩 완료.");
33
+ const steps = ["pnpm install"];
34
+ if (data.hasDb) {
35
+ steps.push("sd.config.ts 의 configs.orm.MAIN 접속 정보 (host/port/user/password/database) 를 실제 값으로 수정");
36
+ }
37
+ if (data.hasMobile) {
38
+ steps.push(`(prod 빌드 필요 시) capacitor 키스토어를 packages/${data.firstMobileClientName}/res/ 에 배치 후 sd.config.ts 의 capacitor.platform.android.sign 블록 수동 추가`);
39
+ }
40
+ steps.push("CLAUDE.md 가 필요하면 Claude Code 내장 /init 으로 작성");
41
+ logger.info("다음 단계:");
42
+ steps.forEach((s, i) => logger.info(` ${i + 1}. ${s}`));
43
+ }
44
+ //# sourceMappingURL=init.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"init.js","sourceRoot":"","sources":["../../../src/commands/init/init.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAEvC,OAAO,EAAE,oBAAoB,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAEjE,MAAM,MAAM,GAAG,gBAAgB,CAAC,aAAa,CAAC,CAAC;AAM/C,MAAM,CAAC,KAAK,UAAU,OAAO,CAAC,IAAiB;IAC7C,MAAM,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAErC,MAAM,KAAK,GAAG,MAAM,UAAU,EAAE,CAAC;IACjC,aAAa,CAAC,KAAK,CAAC,CAAC;IAErB,MAAM,UAAU,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC;IACpC,MAAM,IAAI,GAAe;QACvB,GAAG,UAAU;QACb,SAAS,EAAE,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;KAClD,CAAC;IAEF,MAAM,CAAC,IAAI,CAAC,oBAAoB,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;IAE5C,MAAM,YAAY,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACnC,IAAI,IAAI,CAAC,SAAS;QAAE,MAAM,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACzD,IAAI,IAAI,CAAC,SAAS;QAAE,MAAM,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACzD,IAAI,IAAI,CAAC,eAAe;QAAE,MAAM,oBAAoB,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACrE,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;QAClC,MAAM,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;IAC/C,CAAC;IAED,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAEhC,MAAM,KAAK,GAAa,CAAC,cAAc,CAAC,CAAC;IACzC,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,KAAK,CAAC,IAAI,CAAC,sFAAsF,CAAC,CAAC;IACrG,CAAC;IACD,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;QACnB,KAAK,CAAC,IAAI,CAAC,2CAA2C,IAAI,CAAC,qBAAsB,sEAAsE,CAAC,CAAC;IAC3J,CAAC;IACD,KAAK,CAAC,IAAI,CAAC,6CAA6C,CAAC,CAAC;IAE1D,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtB,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;AAC3D,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { InitInput, NormalizedInput } from "./types";
2
+ export declare function normalize(input: InitInput): NormalizedInput;
3
+ //# sourceMappingURL=normalize.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"normalize.d.ts","sourceRoot":"","sources":["../../../src/commands/init/normalize.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAc,SAAS,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAQtE,wBAAgB,SAAS,CAAC,KAAK,EAAE,SAAS,GAAG,eAAe,CAqC3D"}
@@ -0,0 +1,42 @@
1
+ const DB_PORTS = {
2
+ mysql: 3306,
3
+ postgres: 5432,
4
+ mssql: 1433,
5
+ };
6
+ export function normalize(input) {
7
+ const clients = input.clients.map((c) => {
8
+ const name = c.name.startsWith("client-") ? c.name : `client-${c.name}`;
9
+ const isMobile = c.type === "mobile";
10
+ return {
11
+ name,
12
+ type: c.type,
13
+ hasRouter: isMobile ? false : c.hasRouter,
14
+ isMobile,
15
+ };
16
+ });
17
+ const hasDb = input.hasServer && input.hasDb;
18
+ const hasCommon = input.hasServer;
19
+ const hasClientCommon = input.hasServer || clients.length >= 2;
20
+ const hasMobile = clients.some((c) => c.isMobile);
21
+ return {
22
+ workspaceName: input.workspaceName,
23
+ workspaceNameUpper: input.workspaceName.toUpperCase().replace(/-/g, "_"),
24
+ description: input.description,
25
+ hasServer: input.hasServer,
26
+ hasDb,
27
+ dbDialect: hasDb ? input.dbDialect : undefined,
28
+ dbPort: hasDb && input.dbDialect != null ? DB_PORTS[input.dbDialect] : 0,
29
+ isMysql: hasDb && input.dbDialect === "mysql",
30
+ isPostgres: hasDb && input.dbDialect === "postgres",
31
+ isMssql: hasDb && input.dbDialect === "mssql",
32
+ serverPort: input.serverPort ?? 40080,
33
+ mobileAppId: hasMobile ? input.mobileAppId : undefined,
34
+ firstMobileClientName: clients.find((c) => c.isMobile)?.name,
35
+ clients,
36
+ hasCommon,
37
+ hasClientCommon,
38
+ hasMobile,
39
+ hasAnyClient: clients.length > 0,
40
+ };
41
+ }
42
+ //# sourceMappingURL=normalize.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"normalize.js","sourceRoot":"","sources":["../../../src/commands/init/normalize.ts"],"names":[],"mappings":"AAEA,MAAM,QAAQ,GAAwD;IACpE,KAAK,EAAE,IAAI;IACX,QAAQ,EAAE,IAAI;IACd,KAAK,EAAE,IAAI;CACZ,CAAC;AAEF,MAAM,UAAU,SAAS,CAAC,KAAgB;IACxC,MAAM,OAAO,GAAiB,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;QACpD,MAAM,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE,CAAC;QACxE,MAAM,QAAQ,GAAG,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC;QACrC,OAAO;YACL,IAAI;YACJ,IAAI,EAAE,CAAC,CAAC,IAAI;YACZ,SAAS,EAAE,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;YACzC,QAAQ;SACT,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,MAAM,KAAK,GAAG,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,KAAK,CAAC;IAC7C,MAAM,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;IAClC,MAAM,eAAe,GAAG,KAAK,CAAC,SAAS,IAAI,OAAO,CAAC,MAAM,IAAI,CAAC,CAAC;IAC/D,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;IAElD,OAAO;QACL,aAAa,EAAE,KAAK,CAAC,aAAa;QAClC,kBAAkB,EAAE,KAAK,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC;QACxE,WAAW,EAAE,KAAK,CAAC,WAAW;QAC9B,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,KAAK;QACL,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS;QAC9C,MAAM,EAAE,KAAK,IAAI,KAAK,CAAC,SAAS,IAAI,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;QACxE,OAAO,EAAE,KAAK,IAAI,KAAK,CAAC,SAAS,KAAK,OAAO;QAC7C,UAAU,EAAE,KAAK,IAAI,KAAK,CAAC,SAAS,KAAK,UAAU;QACnD,OAAO,EAAE,KAAK,IAAI,KAAK,CAAC,SAAS,KAAK,OAAO;QAC7C,UAAU,EAAE,KAAK,CAAC,UAAU,IAAI,KAAK;QACrC,WAAW,EAAE,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS;QACtD,qBAAqB,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,IAAI;QAC5D,OAAO;QACP,SAAS;QACT,eAAe;QACf,SAAS;QACT,YAAY,EAAE,OAAO,CAAC,MAAM,GAAG,CAAC;KACjC,CAAC;AACJ,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { InitInput } from "./types";
2
+ export declare function promptInit(): Promise<InitInput>;
3
+ //# sourceMappingURL=prompts.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prompts.d.ts","sourceRoot":"","sources":["../../../src/commands/init/prompts.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAA0C,SAAS,EAAE,MAAM,SAAS,CAAC;AAKjF,wBAAsB,UAAU,IAAI,OAAO,CAAC,SAAS,CAAC,CA8FrD"}
@@ -0,0 +1,89 @@
1
+ import { confirm, input, select } from "@inquirer/prompts";
2
+ const KEBAB_CASE_RE = /^[a-z][a-z0-9]*(-[a-z0-9]+)*$/;
3
+ const APPID_RE = /^[a-z][a-z0-9]*(\.[a-z][a-z0-9]*)+$/;
4
+ export async function promptInit() {
5
+ const workspaceName = await input({
6
+ message: "워크스페이스 이름 (영문 kebab-case, 예: my-project):",
7
+ validate: (v) => KEBAB_CASE_RE.test(v) || "영문 kebab-case 만 허용됩니다.",
8
+ });
9
+ const description = await input({
10
+ message: "한 줄 설명:",
11
+ });
12
+ const hasServer = await confirm({
13
+ message: "server 패키지를 만들까요?",
14
+ default: true,
15
+ });
16
+ let hasDb = false;
17
+ let dbDialect;
18
+ let serverPort;
19
+ if (hasServer) {
20
+ hasDb = await confirm({
21
+ message: "DB 를 사용할까요? (ORM 부트스트랩 포함)",
22
+ default: true,
23
+ });
24
+ if (hasDb) {
25
+ dbDialect = await select({
26
+ message: "DB dialect 를 선택하세요:",
27
+ choices: [
28
+ { name: "MySQL", value: "mysql" },
29
+ { name: "PostgreSQL", value: "postgres" },
30
+ { name: "MSSQL", value: "mssql" },
31
+ ],
32
+ });
33
+ }
34
+ const portStr = await input({
35
+ message: "server port (dev/prod 동일):",
36
+ default: "40080",
37
+ validate: (v) => {
38
+ const n = Number(v);
39
+ return (Number.isInteger(n) && n > 0 && n < 65536) || "유효한 포트 번호 (1-65535)";
40
+ },
41
+ });
42
+ serverPort = Number(portStr);
43
+ }
44
+ const clients = [];
45
+ for (;;) {
46
+ const shouldAdd = clients.length === 0
47
+ ? await confirm({ message: "client 를 추가할까요?", default: true })
48
+ : await confirm({ message: "다른 client 를 더 추가할까요?", default: false });
49
+ if (!shouldAdd)
50
+ break;
51
+ const clientName = await input({
52
+ message: "client 이름 (예: admin → 자동으로 client-admin):",
53
+ validate: (v) => KEBAB_CASE_RE.test(v) || "영문 kebab-case 만 허용됩니다.",
54
+ });
55
+ const clientType = await select({
56
+ message: "client 타입:",
57
+ choices: [
58
+ { name: "일반 웹", value: "web" },
59
+ { name: "모바일 (capacitor)", value: "mobile" },
60
+ ],
61
+ });
62
+ let hasRouter = false;
63
+ if (clientType !== "mobile") {
64
+ hasRouter = await confirm({
65
+ message: `${clientName}: 라우팅 (@angular/router) 을 쓸까요?`,
66
+ default: true,
67
+ });
68
+ }
69
+ clients.push({ name: clientName, type: clientType, hasRouter });
70
+ }
71
+ let mobileAppId;
72
+ if (clients.some((c) => c.type === "mobile")) {
73
+ mobileAppId = await input({
74
+ message: "capacitor appId (reverse-DNS, 예: kr.co.example.app):",
75
+ validate: (v) => APPID_RE.test(v) || "reverse-DNS 형식이어야 합니다.",
76
+ });
77
+ }
78
+ return {
79
+ workspaceName,
80
+ description,
81
+ hasServer,
82
+ clients,
83
+ hasDb,
84
+ dbDialect,
85
+ mobileAppId,
86
+ serverPort,
87
+ };
88
+ }
89
+ //# sourceMappingURL=prompts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prompts.js","sourceRoot":"","sources":["../../../src/commands/init/prompts.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAG3D,MAAM,aAAa,GAAG,+BAA+B,CAAC;AACtD,MAAM,QAAQ,GAAG,qCAAqC,CAAC;AAEvD,MAAM,CAAC,KAAK,UAAU,UAAU;IAC9B,MAAM,aAAa,GAAG,MAAM,KAAK,CAAC;QAChC,OAAO,EAAE,2CAA2C;QACpD,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,wBAAwB;KACnE,CAAC,CAAC;IAEH,MAAM,WAAW,GAAG,MAAM,KAAK,CAAC;QAC9B,OAAO,EAAE,SAAS;KACnB,CAAC,CAAC;IAEH,MAAM,SAAS,GAAG,MAAM,OAAO,CAAC;QAC9B,OAAO,EAAE,mBAAmB;QAC5B,OAAO,EAAE,IAAI;KACd,CAAC,CAAC;IAEH,IAAI,KAAK,GAAG,KAAK,CAAC;IAClB,IAAI,SAAgC,CAAC;IACrC,IAAI,UAA8B,CAAC;IACnC,IAAI,SAAS,EAAE,CAAC;QACd,KAAK,GAAG,MAAM,OAAO,CAAC;YACpB,OAAO,EAAE,4BAA4B;YACrC,OAAO,EAAE,IAAI;SACd,CAAC,CAAC;QACH,IAAI,KAAK,EAAE,CAAC;YACV,SAAS,GAAG,MAAM,MAAM,CAAY;gBAClC,OAAO,EAAE,qBAAqB;gBAC9B,OAAO,EAAE;oBACP,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE;oBACjC,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,UAAU,EAAE;oBACzC,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE;iBAClC;aACF,CAAC,CAAC;QACL,CAAC;QAED,MAAM,OAAO,GAAG,MAAM,KAAK,CAAC;YAC1B,OAAO,EAAE,4BAA4B;YACrC,OAAO,EAAE,OAAO;YAChB,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE;gBACd,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;gBACpB,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,IAAI,qBAAqB,CAAC;YAC9E,CAAC;SACF,CAAC,CAAC;QACH,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;IAC/B,CAAC;IAED,MAAM,OAAO,GAAsB,EAAE,CAAC;IACtC,SAAS,CAAC;QACR,MAAM,SAAS,GACb,OAAO,CAAC,MAAM,KAAK,CAAC;YAClB,CAAC,CAAC,MAAM,OAAO,CAAC,EAAE,OAAO,EAAE,iBAAiB,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;YAC9D,CAAC,CAAC,MAAM,OAAO,CAAC,EAAE,OAAO,EAAE,sBAAsB,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;QACzE,IAAI,CAAC,SAAS;YAAE,MAAM;QAEtB,MAAM,UAAU,GAAG,MAAM,KAAK,CAAC;YAC7B,OAAO,EAAE,2CAA2C;YACpD,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,wBAAwB;SACnE,CAAC,CAAC;QACH,MAAM,UAAU,GAAG,MAAM,MAAM,CAAa;YAC1C,OAAO,EAAE,YAAY;YACrB,OAAO,EAAE;gBACP,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE;gBAC9B,EAAE,IAAI,EAAE,iBAAiB,EAAE,KAAK,EAAE,QAAQ,EAAE;aAC7C;SACF,CAAC,CAAC;QAEH,IAAI,SAAS,GAAG,KAAK,CAAC;QACtB,IAAI,UAAU,KAAK,QAAQ,EAAE,CAAC;YAC5B,SAAS,GAAG,MAAM,OAAO,CAAC;gBACxB,OAAO,EAAE,GAAG,UAAU,gCAAgC;gBACtD,OAAO,EAAE,IAAI;aACd,CAAC,CAAC;QACL,CAAC;QAED,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC;IAClE,CAAC;IAED,IAAI,WAA+B,CAAC;IACpC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,EAAE,CAAC;QAC7C,WAAW,GAAG,MAAM,KAAK,CAAC;YACxB,OAAO,EAAE,sDAAsD;YAC/D,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,wBAAwB;SAC9D,CAAC,CAAC;IACL,CAAC;IAED,OAAO;QACL,aAAa;QACb,WAAW;QACX,SAAS;QACT,OAAO;QACP,KAAK;QACL,SAAS;QACT,WAAW;QACX,UAAU;KACX,CAAC;AACJ,CAAC"}
@@ -0,0 +1,4 @@
1
+ export declare function renderTemplate(tplPath: string, data: unknown): Promise<string>;
2
+ export declare function renderToFile(tplPath: string, outPath: string, data: unknown): Promise<void>;
3
+ export declare function copyFixed(sourcePath: string, outPath: string): Promise<void>;
4
+ //# sourceMappingURL=render.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"render.d.ts","sourceRoot":"","sources":["../../../src/commands/init/render.ts"],"names":[],"mappings":"AAOA,wBAAsB,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAQpF;AAED,wBAAsB,YAAY,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAGjG;AAED,wBAAsB,SAAS,CAAC,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAElF"}
@@ -0,0 +1,20 @@
1
+ import Handlebars from "handlebars";
2
+ import { fsx } from "@simplysm/core-node";
3
+ const compileCache = new Map();
4
+ export async function renderTemplate(tplPath, data) {
5
+ let tpl = compileCache.get(tplPath);
6
+ if (tpl == null) {
7
+ const source = await fsx.read(tplPath);
8
+ tpl = Handlebars.compile(source, { noEscape: true });
9
+ compileCache.set(tplPath, tpl);
10
+ }
11
+ return tpl(data);
12
+ }
13
+ export async function renderToFile(tplPath, outPath, data) {
14
+ const rendered = await renderTemplate(tplPath, data);
15
+ await fsx.write(outPath, rendered);
16
+ }
17
+ export async function copyFixed(sourcePath, outPath) {
18
+ await fsx.copy(sourcePath, outPath);
19
+ }
20
+ //# sourceMappingURL=render.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"render.js","sourceRoot":"","sources":["../../../src/commands/init/render.ts"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,YAAY,CAAC;AACpC,OAAO,EAAE,GAAG,EAAE,MAAM,qBAAqB,CAAC;AAI1C,MAAM,YAAY,GAAG,IAAI,GAAG,EAAoB,CAAC;AAEjD,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,OAAe,EAAE,IAAa;IACjE,IAAI,GAAG,GAAG,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IACpC,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC;QAChB,MAAM,MAAM,GAAG,MAAM,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvC,GAAG,GAAG,UAAU,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QACrD,YAAY,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;IACjC,CAAC;IACD,OAAO,GAAG,CAAC,IAAI,CAAC,CAAC;AACnB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,OAAe,EAAE,OAAe,EAAE,IAAa;IAChF,MAAM,QAAQ,GAAG,MAAM,cAAc,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IACrD,MAAM,GAAG,CAAC,KAAK,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;AACrC,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,UAAkB,EAAE,OAAe;IACjE,MAAM,GAAG,CAAC,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;AACtC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare const TEMPLATES_ROOT: string;
2
+ //# sourceMappingURL=template-paths.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"template-paths.d.ts","sourceRoot":"","sources":["../../../src/commands/init/template-paths.ts"],"names":[],"mappings":"AAOA,eAAO,MAAM,cAAc,QAA6D,CAAC"}
@@ -0,0 +1,7 @@
1
+ import path from "node:path";
2
+ import { fileURLToPath } from "node:url";
3
+ const here = path.dirname(fileURLToPath(import.meta.url));
4
+ const isProd = here.includes(`${path.sep}dist${path.sep}`);
5
+ const pkgRoot = path.resolve(here, isProd ? "../../.." : "../../..");
6
+ export const TEMPLATES_ROOT = path.join(pkgRoot, "src", "commands", "init", "templates");
7
+ //# sourceMappingURL=template-paths.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"template-paths.js","sourceRoot":"","sources":["../../../src/commands/init/template-paths.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAEzC,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AAC1D,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,GAAG,OAAO,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;AAC3D,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;AAErE,MAAM,CAAC,MAAM,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC"}
@@ -0,0 +1,47 @@
1
+ export type ClientType = "web" | "mobile";
2
+ export type DbDialect = "mysql" | "postgres" | "mssql";
3
+ export interface ClientInputSpec {
4
+ name: string;
5
+ type: ClientType;
6
+ hasRouter: boolean;
7
+ }
8
+ export interface InitInput {
9
+ workspaceName: string;
10
+ description: string;
11
+ hasServer: boolean;
12
+ clients: ClientInputSpec[];
13
+ hasDb: boolean;
14
+ dbDialect?: DbDialect;
15
+ mobileAppId?: string;
16
+ serverPort?: number;
17
+ }
18
+ export interface ClientSpec {
19
+ name: string;
20
+ type: ClientType;
21
+ hasRouter: boolean;
22
+ isMobile: boolean;
23
+ }
24
+ export interface NormalizedInput {
25
+ workspaceName: string;
26
+ workspaceNameUpper: string;
27
+ description: string;
28
+ hasServer: boolean;
29
+ hasDb: boolean;
30
+ dbDialect?: DbDialect;
31
+ dbPort: number;
32
+ isMysql: boolean;
33
+ isPostgres: boolean;
34
+ isMssql: boolean;
35
+ serverPort: number;
36
+ mobileAppId?: string;
37
+ firstMobileClientName?: string;
38
+ clients: ClientSpec[];
39
+ hasCommon: boolean;
40
+ hasClientCommon: boolean;
41
+ hasMobile: boolean;
42
+ hasAnyClient: boolean;
43
+ }
44
+ export interface RenderData extends NormalizedInput {
45
+ jwtSecret: string;
46
+ }
47
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/commands/init/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,UAAU,GAAG,KAAK,GAAG,QAAQ,CAAC;AAC1C,MAAM,MAAM,SAAS,GAAG,OAAO,GAAG,UAAU,GAAG,OAAO,CAAC;AAEvD,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,UAAU,CAAC;IACjB,SAAS,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,SAAS;IACxB,aAAa,EAAE,MAAM,CAAC;IACtB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;IACnB,OAAO,EAAE,eAAe,EAAE,CAAC;IAC3B,KAAK,EAAE,OAAO,CAAC;IACf,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,UAAU,CAAC;IACjB,SAAS,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,OAAO,CAAC;CACnB;AAED,MAAM,WAAW,eAAe;IAC9B,aAAa,EAAE,MAAM,CAAC;IACtB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,OAAO,CAAC;IACf,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,OAAO,CAAC;IACpB,OAAO,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,qBAAqB,CAAC,EAAE,MAAM,CAAC;IAC/B,OAAO,EAAE,UAAU,EAAE,CAAC;IACtB,SAAS,EAAE,OAAO,CAAC;IACnB,eAAe,EAAE,OAAO,CAAC;IACzB,SAAS,EAAE,OAAO,CAAC;IACnB,YAAY,EAAE,OAAO,CAAC;CACvB;AAED,MAAM,WAAW,UAAW,SAAQ,eAAe;IACjD,SAAS,EAAE,MAAM,CAAC;CACnB"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/commands/init/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,4 @@
1
+ import type { InitInput } from "./types";
2
+ export declare function validateBeforePrompt(cwd: string): Promise<void>;
3
+ export declare function validateInput(input: InitInput): void;
4
+ //# sourceMappingURL=validate.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validate.d.ts","sourceRoot":"","sources":["../../../src/commands/init/validate.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAIzC,wBAAsB,oBAAoB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CASrE;AAED,wBAAgB,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI,CAwBpD"}
@@ -0,0 +1,31 @@
1
+ import { fsx } from "@simplysm/core-node";
2
+ const KEBAB_CASE_RE = /^[a-z][a-z0-9]*(-[a-z0-9]+)*$/;
3
+ export async function validateBeforePrompt(cwd) {
4
+ if (!(await fsx.exists(cwd)))
5
+ return;
6
+ const children = await fsx.readdir(cwd);
7
+ const significant = children.filter((n) => n !== ".git");
8
+ if (significant.length > 0) {
9
+ throw new Error(`작업 디렉토리가 비어있지 않습니다 (감지된 항목: ${significant.join(", ")}). 빈 디렉토리에서 다시 실행하세요.`);
10
+ }
11
+ }
12
+ export function validateInput(input) {
13
+ if (!input.hasServer && input.clients.length === 0) {
14
+ throw new Error("server 도 client 도 없는 워크스페이스는 만들 수 없습니다.");
15
+ }
16
+ if (!KEBAB_CASE_RE.test(input.workspaceName)) {
17
+ throw new Error(`워크스페이스 이름은 영문 kebab-case 여야 합니다 (예: my-workspace). 입력값: "${input.workspaceName}"`);
18
+ }
19
+ const clientNames = new Set();
20
+ for (const c of input.clients) {
21
+ if (!KEBAB_CASE_RE.test(c.name)) {
22
+ throw new Error(`client 이름은 영문 kebab-case 여야 합니다. 입력값: "${c.name}"`);
23
+ }
24
+ const normalized = c.name.startsWith("client-") ? c.name : `client-${c.name}`;
25
+ if (clientNames.has(normalized)) {
26
+ throw new Error(`client 이름이 중복됩니다: "${normalized}"`);
27
+ }
28
+ clientNames.add(normalized);
29
+ }
30
+ }
31
+ //# sourceMappingURL=validate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validate.js","sourceRoot":"","sources":["../../../src/commands/init/validate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,qBAAqB,CAAC;AAG1C,MAAM,aAAa,GAAG,+BAA+B,CAAC;AAEtD,MAAM,CAAC,KAAK,UAAU,oBAAoB,CAAC,GAAW;IACpD,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAAE,OAAO;IACrC,MAAM,QAAQ,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IACxC,MAAM,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC;IACzD,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC3B,MAAM,IAAI,KAAK,CACb,+BAA+B,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,uBAAuB,CAC7E,CAAC;IACJ,CAAC;AACH,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,KAAgB;IAC5C,IAAI,CAAC,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACnD,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;IAC7D,CAAC;IAED,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,EAAE,CAAC;QAC7C,MAAM,IAAI,KAAK,CACb,4DAA4D,KAAK,CAAC,aAAa,GAAG,CACnF,CAAC;IACJ,CAAC;IAED,MAAM,WAAW,GAAG,IAAI,GAAG,EAAU,CAAC;IACtC,KAAK,MAAM,CAAC,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;QAC9B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;YAChC,MAAM,IAAI,KAAK,CACb,0CAA0C,CAAC,CAAC,IAAI,GAAG,CACpD,CAAC;QACJ,CAAC;QACD,MAAM,UAAU,GAAG,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE,CAAC;QAC9E,IAAI,WAAW,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC;YAChC,MAAM,IAAI,KAAK,CAAC,sBAAsB,UAAU,GAAG,CAAC,CAAC;QACvD,CAAC;QACD,WAAW,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IAC9B,CAAC;AACH,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"sd-cli-entry.d.ts","sourceRoot":"","sources":["../src/sd-cli-entry.ts"],"names":[],"mappings":";AAKA,OAAc,EAAE,KAAK,IAAI,EAAE,MAAM,OAAO,CAAC;AAsCzC;;;GAGG;AACH,wBAAgB,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA8RpD"}
1
+ {"version":3,"file":"sd-cli-entry.d.ts","sourceRoot":"","sources":["../src/sd-cli-entry.ts"],"names":[],"mappings":";AAKA,OAAc,EAAE,KAAK,IAAI,EAAE,MAAM,OAAO,CAAC;AAgDzC;;;GAGG;AACH,wBAAgB,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAsSpD"}
@@ -8,6 +8,7 @@ import { runCheck } from "./commands/check.js";
8
8
  import { runWatch } from "./commands/watch.js";
9
9
  import { runDev } from "./commands/dev.js";
10
10
  import { runBuild } from "./commands/build.js";
11
+ import { runInit } from "./commands/init/init.js";
11
12
  import { runPublish } from "./commands/publish/publish-command.js";
12
13
  import { runReplaceDeps } from "./commands/replace-deps.js";
13
14
  import path from "path";
@@ -19,7 +20,16 @@ import { createLazyLogger } from "./runtime/lazy-logger.js";
19
20
  const logger = createLazyLogger("sd:cli:entry");
20
21
  Error.stackTraceLimit = Infinity;
21
22
  EventEmitter.defaultMaxListeners = 100;
22
- const COMMAND_NAMES = ["check", "watch", "dev", "device", "build", "publish", "replace-deps"];
23
+ const COMMAND_NAMES = [
24
+ "check",
25
+ "watch",
26
+ "dev",
27
+ "device",
28
+ "build",
29
+ "publish",
30
+ "replace-deps",
31
+ "init",
32
+ ];
23
33
  async function collectYargsHelp(argv) {
24
34
  const lines = [];
25
35
  const orig = console.log;
@@ -255,6 +265,9 @@ export function createCliParser(argv) {
255
265
  await runReplaceDeps({
256
266
  options: args.opt,
257
267
  });
268
+ })
269
+ .command("init", "Bootstrap a new SI workspace via interactive prompts", (cmd) => cmd.version(false).hide("help"), async () => {
270
+ await runInit({ cwd: process.cwd() });
258
271
  })
259
272
  .demandCommand(1, "Please specify a command.")
260
273
  .strict()