create-mbler 0.0.1 → 0.0.2-rc.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.
package/README.md CHANGED
@@ -1,11 +1,46 @@
1
1
  # create-mbler
2
2
 
3
- ## Github
3
+ CLI scaffolding tool for creating new MCX / mbler projects. Quickly generate a project with the correct directory structure, configuration files, and dependencies.
4
4
 
5
- [GIthub](https://github.com/RuanhoR/mcx-core/tree/main/packages/create-mbler) | [Mbler](https://github.com/RuanhoR/mbler)
5
+ ## Usage
6
6
 
7
- ## Info
7
+ ```bash
8
+ # Using pnpm
9
+ pnpm create mbler my-addon
8
10
 
9
- Run `mbler init` or `pnpm create mbler` to use.
11
+ # Using npx
12
+ npx create-mbler my-addon
10
13
 
11
- It can generate a mbler project fast.
14
+ # Using the CLI directly
15
+ create-mbler my-addon
16
+ ```
17
+
18
+ The CLI will prompt you for:
19
+
20
+ - **Project name / description**
21
+ - **Minecraft version target**
22
+ - **Modules to include**
23
+ - **Language** — MCX DSL (`.mcx`), TypeScript (`.ts`), or JavaScript (`.js`)
24
+ - **Package manager** — pnpm or npm
25
+
26
+ ## Generated Structure
27
+
28
+ ```
29
+ my-addon/
30
+ ├── behavior/
31
+ │ └── scripts/
32
+ │ └── main.js
33
+ ├── resources/
34
+ ├── package.json
35
+ ├── mbler.config.js
36
+ ├── tsconfig.json
37
+ └── .gitignore
38
+ ```
39
+
40
+ ## GitHub
41
+
42
+ [Repository](https://github.com/RuanhoR/mcx-core/tree/main/packages/create-mbler) | [Mbler](https://github.com/RuanhoR/mbler)
43
+
44
+ ## License
45
+
46
+ MIT
package/dist/main.mjs CHANGED
@@ -1,117 +1,115 @@
1
- import { Command, Argument } from 'commander';
2
- import inpurer from 'inquirer';
3
- import { stdout } from 'node:process';
4
- import path from 'node:path';
5
- import { spawn } from 'node:child_process';
6
- import { mkdir, cp, writeFile, stat } from 'node:fs/promises';
7
-
8
- const LanguageList = ['zh', 'en'];
1
+ import { Argument, Command } from "commander";
2
+ import inpurer from "inquirer";
3
+ import { stdout } from "node:process";
4
+ import path from "node:path";
5
+ import { spawn } from "node:child_process";
6
+ import { cp, mkdir, stat, writeFile } from "node:fs/promises";
7
+ //#region src/i18n.ts
8
+ const LanguageList = ["zh", "en"];
9
9
  const LanguageMap = {
10
- zh: {
11
- InputCreateAt: '创建在哪呢?',
12
- Name: '项目名称',
13
- Need: '需要什么?',
14
- McVersion: '依赖的 mc 版本(像 1.21.100 )?',
15
- Description: '项目描述?',
16
- PackageManager: '使用哪个包管理器?',
17
- },
18
- en: {
19
- InputCreateAt: 'Create mbler project at ...?',
20
- Need: 'Need?',
21
- Description: 'Project description?',
22
- McVersion: 'Need mcbe version(like 1.21.100)?',
23
- Name: 'Project name? ',
24
- PackageManager: 'Which package manager to use?',
25
- },
10
+ zh: {
11
+ InputCreateAt: "创建在哪呢?",
12
+ Name: "项目名称",
13
+ Need: "需要什么?",
14
+ McVersion: "依赖的 mc 版本(像 1.21.100 )?",
15
+ Description: "项目描述?",
16
+ PackageManager: "使用哪个包管理器?"
17
+ },
18
+ en: {
19
+ InputCreateAt: "Create mbler project at ...?",
20
+ Need: "Need?",
21
+ Description: "Project description?",
22
+ McVersion: "Need mcbe version(like 1.21.100)?",
23
+ Name: "Project name? ",
24
+ PackageManager: "Which package manager to use?"
25
+ }
26
26
  };
27
27
  function getI18n(key, language) {
28
- return LanguageMap[language][key];
28
+ return LanguageMap[language][key];
29
29
  }
30
-
30
+ //#endregion
31
+ //#region src/utils.ts
31
32
  function showText(etxt) {
32
- stdout.write(etxt + '\n');
33
+ stdout.write(etxt + "\n");
33
34
  }
34
35
  function verifyType(obj, typeMapping) {
35
- for (const key in typeMapping) {
36
- const expected = typeMapping[key];
37
- const val = obj[key];
38
- if (typeof val !== expected)
39
- return false;
40
- }
41
- return true;
36
+ for (const key in typeMapping) {
37
+ const expected = typeMapping[key];
38
+ if (typeof obj[key] !== expected) return false;
39
+ }
40
+ return true;
42
41
  }
43
-
42
+ //#endregion
43
+ //#region src/init.ts
44
44
  function spawnCmd(cmd, args, cwd) {
45
- return new Promise((resolve, reject) => {
46
- const child = spawn(cmd, args, { cwd, stdio: 'inherit', shell: true });
47
- child.on('close', code => {
48
- if (code === 0)
49
- resolve();
50
- else
51
- reject(new Error(`${cmd} exited with code ${code}`));
52
- });
53
- child.on('error', reject);
54
- });
45
+ return new Promise((resolve, reject) => {
46
+ const child = spawn(cmd, args, {
47
+ cwd,
48
+ stdio: "inherit",
49
+ shell: true
50
+ });
51
+ child.on("close", (code) => {
52
+ if (code === 0) resolve();
53
+ else reject(/* @__PURE__ */ new Error(`${cmd} exited with code ${code}`));
54
+ });
55
+ child.on("error", reject);
56
+ });
55
57
  }
56
58
  async function fileExists(f) {
57
- try {
58
- await stat(path.resolve(f));
59
- return true;
60
- }
61
- catch {
62
- return false;
63
- }
59
+ try {
60
+ await stat(path.resolve(f));
61
+ return true;
62
+ } catch {
63
+ return false;
64
+ }
64
65
  }
65
66
  async function findTemplate(language) {
66
- const d = path.join('template', language);
67
- if (await fileExists(path.join(import.meta.dirname, '../', d))) {
68
- return path.join(import.meta.dirname, '../', d);
69
- }
70
- if (await fileExists(path.join(import.meta.dirname, '../../', d))) {
71
- return path.join(import.meta.dirname, '../../', d);
72
- }
73
- throw new Error("Can't find template");
67
+ const d = path.join("template", language);
68
+ if (await fileExists(path.join(import.meta.dirname, "../", d))) return path.join(import.meta.dirname, "../", d);
69
+ if (await fileExists(path.join(import.meta.dirname, "../../", d))) return path.join(import.meta.dirname, "../../", d);
70
+ throw new Error("Can't find template");
74
71
  }
75
72
  function mcVersionToGameTest(mcVersion) {
76
- const map = {
77
- '1.21.100': '2.0.0',
78
- '1.21.120': '2.0.0',
79
- };
80
- return map[mcVersion] || '2.0.0';
73
+ return {
74
+ "1.21.100": "2.0.0",
75
+ "1.21.120": "2.0.0"
76
+ }[mcVersion] || "2.0.0";
81
77
  }
82
78
  async function initProject(inputOpt) {
83
- const dir = path.resolve(inputOpt.createAt);
84
- const isMcx = inputOpt.Language === 'mcx';
85
- await mkdir(dir, { recursive: true });
86
- const templatePath = await findTemplate(inputOpt.Language);
87
- await cp(templatePath, dir, { recursive: true, force: true });
88
- const packageJson = {
89
- name: inputOpt.Name,
90
- description: inputOpt.Description,
91
- version: '0.0.1',
92
- packageManager: inputOpt.PackageManager,
93
- engines: { node: '>=18.0.0' },
94
- scripts: {
95
- dev: 'mbler watch',
96
- build: 'mcx-tsc && BUILD_MODULE=release mbler build',
97
- 'dev-build': 'mbler build',
98
- },
99
- type: 'module',
100
- dependencies: {
101
- '@minecraft/server': mcVersionToGameTest(inputOpt.McVersion),
102
- },
103
- devDependencies: {
104
- mbler: 'latest',
105
- },
106
- };
107
- if (isMcx) {
108
- packageJson.dependencies['@mbler/mcx'] = '0.0.3-alpha.r1';
109
- packageJson.devDependencies['@mbler/mcx-core'] = 'latest';
110
- }
111
- await writeFile(path.join(dir, 'package.json'), JSON.stringify(packageJson, null, 2) + '\n');
112
- const ui = inputOpt.OtherModule.includes('ui');
113
- const beta = inputOpt.OtherModule.includes('beta-api');
114
- const mblerConfig = `import { defineConfig } from "mbler"
79
+ const dir = path.resolve(inputOpt.createAt);
80
+ const isMcx = inputOpt.Language === "mcx";
81
+ await mkdir(dir, { recursive: true });
82
+ await cp(await findTemplate(inputOpt.Language), dir, {
83
+ recursive: true,
84
+ force: true
85
+ });
86
+ const packageJson = {
87
+ name: inputOpt.Name,
88
+ description: inputOpt.Description,
89
+ version: "0.0.1",
90
+ packageManager: inputOpt.PackageManager,
91
+ engines: { node: ">=18.0.0" },
92
+ scripts: {
93
+ dev: "mbler watch",
94
+ build: "mcx-tsc && cross-env BUILD_MODULE=release mbler build",
95
+ "dev-build": "mbler build"
96
+ },
97
+ type: "module",
98
+ dependencies: { "@minecraft/server": mcVersionToGameTest(inputOpt.McVersion) },
99
+ devDependencies: {
100
+ "cross-env": "^7.0.3",
101
+ mbler: "latest"
102
+ }
103
+ };
104
+ if (isMcx) {
105
+ packageJson.dependencies["@mbler/mcx"] = "0.0.3-alpha.r1";
106
+ packageJson.dependencies["@mbler/mcx-component"] = "0.0.0-alpha.1";
107
+ packageJson.devDependencies["@mbler/mcx-core"] = "latest";
108
+ }
109
+ await writeFile(path.join(dir, "package.json"), JSON.stringify(packageJson, null, 2) + "\n");
110
+ const ui = inputOpt.OtherModule.includes("ui");
111
+ const beta = inputOpt.OtherModule.includes("beta-api");
112
+ const mblerConfig = `import { defineConfig } from "mbler"
115
113
  export default defineConfig({
116
114
  description: '${inputOpt.Description}',
117
115
  mcVersion: '${inputOpt.McVersion}',
@@ -120,119 +118,111 @@ export default defineConfig({
120
118
  build: { bundle: true, cache: "file" },
121
119
  outdir: { resources: './dist/res', behavior: './dist/dep', dist: './dist.mcaddon' }
122
120
  });\n`;
123
- await writeFile(path.join(dir, 'mbler.config.js'), mblerConfig);
124
- if (inputOpt.Language !== 'js') {
125
- const tsconfig = {
126
- compilerOptions: {
127
- module: 'esnext',
128
- noEmit: true,
129
- target: 'esnext',
130
- sourceMap: true,
131
- declaration: false,
132
- strict: true,
133
- moduleResolution: 'bundler',
134
- allowImportingTsExtensions: true,
135
- isolatedModules: true,
136
- moduleDetection: 'force',
137
- skipLibCheck: true,
138
- types: ['mbler/client'],
139
- },
140
- include: ['./behavior/scripts/**/*'],
141
- };
142
- await writeFile(path.join(dir, 'tsconfig.json'), JSON.stringify(tsconfig, null, 2) + '\n');
143
- }
144
- await writeFile(path.join(dir, '.gitignore'), 'node_modules\ndist\ndist.mcaddon\n.mbler\ncache\n');
145
- if (inputOpt.OtherModule.includes('init git')) {
146
- try {
147
- await spawnCmd('git', ['init'], dir);
148
- }
149
- catch (err) {
150
- console.log('Failed to initialize git, you can try to run it manually later. ERR: ', err);
151
- }
152
- }
153
- if (inputOpt.OtherModule.includes('init dep')) {
154
- try {
155
- await spawnCmd(inputOpt.PackageManager, ['install'], dir);
156
- }
157
- catch (err) {
158
- console.log('Failed to install dependencies, you can try to run it manually later. ERR: ', err);
159
- }
160
- }
121
+ await writeFile(path.join(dir, "mbler.config.js"), mblerConfig);
122
+ if (inputOpt.Language !== "js") await writeFile(path.join(dir, "tsconfig.json"), JSON.stringify({
123
+ compilerOptions: {
124
+ module: "esnext",
125
+ noEmit: true,
126
+ target: "esnext",
127
+ sourceMap: true,
128
+ declaration: false,
129
+ strict: true,
130
+ moduleResolution: "bundler",
131
+ allowImportingTsExtensions: true,
132
+ isolatedModules: true,
133
+ moduleDetection: "force",
134
+ skipLibCheck: true,
135
+ types: ["mbler/client"]
136
+ },
137
+ include: ["./behavior/scripts/**/*"]
138
+ }, null, 2) + "\n");
139
+ await writeFile(path.join(dir, ".gitignore"), "node_modules\ndist\ndist.mcaddon\n.mbler\ncache\n");
140
+ if (inputOpt.OtherModule.includes("init git")) try {
141
+ await spawnCmd("git", ["init"], dir);
142
+ } catch (err) {
143
+ console.log("Failed to initialize git, you can try to run it manually later. ERR: ", err);
144
+ }
145
+ if (inputOpt.OtherModule.includes("init dep")) try {
146
+ await spawnCmd(inputOpt.PackageManager, ["install"], dir);
147
+ } catch (err) {
148
+ console.log("Failed to install dependencies, you can try to run it manually later. ERR: ", err);
149
+ }
161
150
  }
162
-
151
+ //#endregion
152
+ //#region src/main.ts
163
153
  function throwErr(text) {
164
- showText('×: ERR: ' + text);
165
- process.exit(1);
154
+ showText("×: ERR: " + text);
155
+ process.exit(1);
166
156
  }
167
- const program = new Command('create-mbler');
168
- program
169
- .name('create-mbler')
170
- .description('Create mbler project')
171
- .addArgument(new Argument('[dir]', 'Where to create mbler project'))
172
- .option('-l, --language <value>', 'Define Create mbler tool language', 'en')
173
- .action(async function (...argv) {
174
- const language = this.getOptionValue('language');
175
- if (!LanguageList.includes(language)) {
176
- throwErr('Invaild Language, should such as ' + JSON.stringify(LanguageList));
177
- }
178
- const inputResult = (await inpurer.prompt([
179
- {
180
- type: 'input',
181
- default: argv[0] || './',
182
- message: getI18n('InputCreateAt', language),
183
- name: 'createAt',
184
- },
185
- {
186
- type: 'input',
187
- name: 'Name',
188
- message: getI18n('Name', language),
189
- },
190
- {
191
- type: 'input',
192
- name: 'Description',
193
- message: getI18n('Description', language),
194
- default: 'The package is a ...',
195
- },
196
- {
197
- type: 'input',
198
- name: 'McVersion',
199
- message: getI18n('McVersion', language),
200
- default: '1.21.100',
201
- },
202
- {
203
- type: 'checkbox',
204
- name: 'OtherModule',
205
- message: getI18n('Need', language),
206
- choices: ['ui', 'beta-api', 'init git', 'init dep'],
207
- },
208
- {
209
- type: 'select',
210
- name: 'Language',
211
- message: getI18n('Need', language),
212
- choices: ['mcx', 'js', 'ts'],
213
- },
214
- {
215
- type: 'select',
216
- name: 'PackageManager',
217
- message: getI18n('PackageManager', language),
218
- choices: ['npm', 'pnpm'],
219
- },
220
- ]));
221
- if (!verifyType(inputResult, {
222
- createAt: 'string',
223
- Description: 'string',
224
- Language: 'string',
225
- McVersion: 'string',
226
- PackageManager: 'string',
227
- Name: 'string',
228
- OtherModule: 'object',
229
- })) {
230
- throwErr('basic type error');
231
- }
232
- await initProject(inputResult);
157
+ const program = new Command("create-mbler");
158
+ program.name("create-mbler").description("Create mbler project").addArgument(new Argument("[dir]", "Where to create mbler project")).option("-l, --language <value>", "Define Create mbler tool language", "en").action(async function(...argv) {
159
+ const language = this.getOptionValue("language");
160
+ if (!LanguageList.includes(language)) throwErr("Invaild Language, should such as " + JSON.stringify(LanguageList));
161
+ const inputResult = await inpurer.prompt([
162
+ {
163
+ type: "input",
164
+ default: argv[0] || "./",
165
+ message: getI18n("InputCreateAt", language),
166
+ name: "createAt"
167
+ },
168
+ {
169
+ type: "input",
170
+ name: "Name",
171
+ message: getI18n("Name", language)
172
+ },
173
+ {
174
+ type: "input",
175
+ name: "Description",
176
+ message: getI18n("Description", language),
177
+ default: "The package is a ..."
178
+ },
179
+ {
180
+ type: "input",
181
+ name: "McVersion",
182
+ message: getI18n("McVersion", language),
183
+ default: "1.21.100"
184
+ },
185
+ {
186
+ type: "checkbox",
187
+ name: "OtherModule",
188
+ message: getI18n("Need", language),
189
+ choices: [
190
+ "ui",
191
+ "beta-api",
192
+ "init git",
193
+ "init dep"
194
+ ]
195
+ },
196
+ {
197
+ type: "select",
198
+ name: "Language",
199
+ message: getI18n("Need", language),
200
+ choices: [
201
+ "mcx",
202
+ "js",
203
+ "ts"
204
+ ]
205
+ },
206
+ {
207
+ type: "select",
208
+ name: "PackageManager",
209
+ message: getI18n("PackageManager", language),
210
+ choices: ["npm", "pnpm"]
211
+ }
212
+ ]);
213
+ if (!verifyType(inputResult, {
214
+ createAt: "string",
215
+ Description: "string",
216
+ Language: "string",
217
+ McVersion: "string",
218
+ PackageManager: "string",
219
+ Name: "string",
220
+ OtherModule: "object"
221
+ })) throwErr("basic type error");
222
+ await initProject(inputResult);
233
223
  });
234
224
  const cli = () => {
235
- program.parse();
225
+ program.parse();
236
226
  };
237
-
227
+ //#endregion
238
228
  export { LanguageList, LanguageMap, cli, getI18n, showText, verifyType };
package/dist/main.mts ADDED
@@ -0,0 +1,130 @@
1
+ //#region src/i18n.d.ts
2
+ var I18nKey = [
3
+ 4,
4
+ () => [],
5
+ []
6
+ ];
7
+ var LanguageList = [
8
+ 5,
9
+ () => [],
10
+ []
11
+ ];
12
+ var Language = [
13
+ 6,
14
+ () => [LanguageList],
15
+ [""]
16
+ ];
17
+ var LanguageMap = [
18
+ 7,
19
+ () => [],
20
+ [
21
+ "",
22
+ "",
23
+ "",
24
+ "",
25
+ "",
26
+ "",
27
+ "",
28
+ "",
29
+ "",
30
+ "",
31
+ "",
32
+ "",
33
+ "",
34
+ ""
35
+ ]
36
+ ];
37
+ var getI18n = [
38
+ 8,
39
+ () => [I18nKey, Language],
40
+ [
41
+ "",
42
+ "",
43
+ "",
44
+ ""
45
+ ]
46
+ ];
47
+ //#endregion
48
+ //#region src/types.d.ts
49
+ var PackageManager = [
50
+ 9,
51
+ () => [],
52
+ []
53
+ ];
54
+ var InputResult = [
55
+ 10,
56
+ () => [PackageManager],
57
+ [
58
+ "",
59
+ "",
60
+ "",
61
+ "",
62
+ "",
63
+ "",
64
+ "",
65
+ ""
66
+ ]
67
+ ];
68
+ //#endregion
69
+ //#region src/utils.d.ts
70
+ var showText = [
71
+ 1,
72
+ () => [],
73
+ [""]
74
+ ];
75
+ var JSTypeMap = [
76
+ 2,
77
+ () => [],
78
+ [
79
+ "",
80
+ "",
81
+ "",
82
+ "",
83
+ "",
84
+ "",
85
+ "",
86
+ ""
87
+ ]
88
+ ];
89
+ var verifyType = [
90
+ 3,
91
+ (T, U) => [
92
+ T,
93
+ JSTypeMap,
94
+ Record,
95
+ T,
96
+ U,
97
+ T,
98
+ U,
99
+ JSTypeMap,
100
+ U,
101
+ P
102
+ ],
103
+ [
104
+ "",
105
+ "",
106
+ "",
107
+ "",
108
+ "",
109
+ "",
110
+ "",
111
+ "",
112
+ "",
113
+ "",
114
+ "",
115
+ "",
116
+ "",
117
+ "",
118
+ "",
119
+ ""
120
+ ]
121
+ ];
122
+ //#endregion
123
+ //#region src/main.d.ts
124
+ var cli = [
125
+ 0,
126
+ () => [],
127
+ []
128
+ ];
129
+ //#endregion
130
+ export { I18nKey, InputResult, JSTypeMap, Language, LanguageList, LanguageMap, PackageManager, cli, getI18n, showText, verifyType };
package/package.json CHANGED
@@ -21,11 +21,15 @@
21
21
  "engines": {
22
22
  "node": ">= 20"
23
23
  },
24
- "version": "0.0.1",
24
+ "version": "0.0.2-rc.2",
25
25
  "dependencies": {
26
26
  "commander": "14.0.3",
27
27
  "inquirer": "13.4.3"
28
28
  },
29
+ "devDependencies": {
30
+ "rolldown": "1.0.0-rc.18",
31
+ "rolldown-plugin-dts": "0.25.2"
32
+ },
29
33
  "bin": {
30
34
  "create-mbler": "./bin/create-mbler.js"
31
35
  },
@@ -35,8 +39,8 @@
35
39
  },
36
40
  "main": "./dist/main.js",
37
41
  "scripts": {
38
- "build": "rollup -c && rm -rf ./dist/_tmp",
39
- "dev": "rollup -c -w",
42
+ "build": "rolldown -c && node -e \"require('fs').rmSync('./dist/_tmp',{recursive:true,force:true})\"",
43
+ "dev": "rolldown -c -w",
40
44
  "lint": "eslint src --ext .js,.ts",
41
45
  "lint:fix": "eslint src --ext .js,.ts --fix",
42
46
  "prepublish": "pnpm build"
@@ -4,7 +4,7 @@
4
4
  </items>
5
5
  </Component>
6
6
  <script lang="ts">
7
- import { ItemComponent } from "@mbler/mcx-core";
7
+ import { ItemComponent } from "@mbler/mcx-component";
8
8
  import { component } from "./../config/config.json"
9
9
  const item = new ItemComponent({
10
10
  id: "demo:item",
@@ -1,9 +1,9 @@
1
1
  <Event @after>
2
2
  McxExtendsBy = ./event$1.mcx
3
- PlayerJoin = eventHandler
3
+ playerJoin = eventHandler
4
4
  </Event>
5
5
  <script lang="ts">
6
- import { add } from "./test.ts";
6
+ import { add } from "./test";
7
7
  export const eventHandler = function(event: any) {
8
8
  event.player.sendMessage("欢迎进入游戏 " + add(1, 10))
9
9
  }