@merkur/cli 0.37.8 → 0.37.12
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/bin/merkur.mjs +31 -2
- package/package.json +2 -2
- package/src/commands/start.mjs +4 -2
- package/src/commands/userDefined.mjs +45 -0
- package/src/merkurConfig.mjs +2 -1
package/bin/merkur.mjs
CHANGED
|
@@ -6,8 +6,12 @@ import { start } from '../src/commands/start.mjs';
|
|
|
6
6
|
import { test } from '../src/commands/test.mjs';
|
|
7
7
|
import { custom, CUSTOM_PART } from '../src/commands/custom.mjs';
|
|
8
8
|
import { COMMAND_NAME } from '../src/commands/constant.mjs';
|
|
9
|
+
import { userDefinedCommandsPaths } from '../src/commands/userDefined.mjs';
|
|
10
|
+
import { createCommandConfig } from '../src/commandConfig.mjs';
|
|
9
11
|
|
|
10
|
-
|
|
12
|
+
import path from 'node:path';
|
|
13
|
+
|
|
14
|
+
// eslint-disable-next-line
|
|
11
15
|
import packageFile from '../package.json' with { type: 'json' };
|
|
12
16
|
|
|
13
17
|
const program = new Command();
|
|
@@ -102,7 +106,7 @@ program
|
|
|
102
106
|
.addOption(verboseOption)
|
|
103
107
|
.action(async (options, cmd) => {
|
|
104
108
|
const args = {
|
|
105
|
-
...{ watch: false, hasRunWidgetServer: true }, ...cmd.optsWithGlobals(), ...options
|
|
109
|
+
...{ watch: false, hasRunWidgetServer: true, hasRunDevServer: true }, ...cmd.optsWithGlobals(), ...options
|
|
106
110
|
};
|
|
107
111
|
process.env.NODE_ENV = process.env.NODE_ENV ?? 'production';
|
|
108
112
|
|
|
@@ -138,4 +142,29 @@ program
|
|
|
138
142
|
await custom({ args, commandArgs: cmd.args, command: COMMAND_NAME.CUSTOM });
|
|
139
143
|
});
|
|
140
144
|
|
|
145
|
+
// Load user-defined commands
|
|
146
|
+
let userDefinedCommands = [];
|
|
147
|
+
for (const { command, dir } of userDefinedCommandsPaths) {
|
|
148
|
+
const programCustom = new Command();
|
|
149
|
+
let commandName = '';
|
|
150
|
+
|
|
151
|
+
try {
|
|
152
|
+
const commandModule = await import(path.join(dir, command));
|
|
153
|
+
commandName = commandModule.default(({ program: programCustom, createCommandConfig })).name();
|
|
154
|
+
} catch (error) {
|
|
155
|
+
console.error(`Error loading command from ${dir}/${command} package:`, error);
|
|
156
|
+
continue;
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
if (userDefinedCommands.includes(commandName)) {
|
|
160
|
+
console.warn(`Command "${commandName}" from ${dir} package cannot be used.\nCommand with the same name already exists.`);
|
|
161
|
+
continue;
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
userDefinedCommands.push(commandName);
|
|
165
|
+
programCustom.commands.forEach(cmd => {
|
|
166
|
+
program.addCommand(cmd);
|
|
167
|
+
});
|
|
168
|
+
};
|
|
169
|
+
|
|
141
170
|
program.parse(process.argv);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@merkur/cli",
|
|
3
|
-
"version": "0.37.
|
|
3
|
+
"version": "0.37.12",
|
|
4
4
|
"description": "Merkur is tiny and extensible library for creating front-end microservices.",
|
|
5
5
|
"bin": {
|
|
6
6
|
"merkur": "./bin/merkur.mjs"
|
|
@@ -67,5 +67,5 @@
|
|
|
67
67
|
"engines": {
|
|
68
68
|
"node": ">=20"
|
|
69
69
|
},
|
|
70
|
-
"gitHead": "
|
|
70
|
+
"gitHead": "a7a363751ea00c47e770dae4e9ad13503175043f"
|
|
71
71
|
}
|
package/src/commands/start.mjs
CHANGED
|
@@ -11,6 +11,8 @@ export async function start({ args, command }) {
|
|
|
11
11
|
|
|
12
12
|
await handleExit({ context });
|
|
13
13
|
|
|
14
|
-
|
|
15
|
-
|
|
14
|
+
cliConfig.hasRunDevServer &&
|
|
15
|
+
(await runDevServer({ merkurConfig, cliConfig, context }));
|
|
16
|
+
cliConfig.hasRunWidgetServer &&
|
|
17
|
+
(await runWidgetServer({ merkurConfig, cliConfig, context }));
|
|
16
18
|
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
import fs from 'node:fs';
|
|
3
|
+
|
|
4
|
+
let userDefinedCommandsPaths = [];
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Extend the commands from a directory
|
|
8
|
+
* @param {string} commandsDir - The directory containing the commands
|
|
9
|
+
* @returns {Promise<void>}
|
|
10
|
+
*/
|
|
11
|
+
const extendCommandsFromDir = async (commandsDir) => {
|
|
12
|
+
userDefinedCommandsPaths = userDefinedCommandsPaths.concat(
|
|
13
|
+
fs
|
|
14
|
+
.readdirSync(commandsDir)
|
|
15
|
+
.map((command) => ({ dir: commandsDir, command }))
|
|
16
|
+
.filter(({ command, dir }) => {
|
|
17
|
+
return (
|
|
18
|
+
fs.statSync(path.join(dir, command)).isFile() &&
|
|
19
|
+
(command.endsWith('.js') ||
|
|
20
|
+
command.endsWith('.mjs') ||
|
|
21
|
+
command.endsWith('.cjs'))
|
|
22
|
+
);
|
|
23
|
+
}),
|
|
24
|
+
);
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
const existsMerkurConfig = fs
|
|
28
|
+
.readdirSync(process.cwd())
|
|
29
|
+
.includes('merkur.config.mjs');
|
|
30
|
+
|
|
31
|
+
if (existsMerkurConfig) {
|
|
32
|
+
const merkurDir = path.resolve(process.cwd(), 'node_modules/@merkur');
|
|
33
|
+
if (fs.existsSync(merkurDir)) {
|
|
34
|
+
let dirs = fs.readdirSync(merkurDir);
|
|
35
|
+
|
|
36
|
+
for (const dir of dirs) {
|
|
37
|
+
const fullPath = path.join(merkurDir, `${dir}/commands`);
|
|
38
|
+
if (fs.existsSync(fullPath)) {
|
|
39
|
+
await extendCommandsFromDir(fullPath);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export { userDefinedCommandsPaths };
|
package/src/merkurConfig.mjs
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import path from 'node:path';
|
|
2
|
+
import { pathToFileURL } from 'node:url';
|
|
2
3
|
|
|
3
4
|
import { EMITTER_EVENTS, emitter, RESULT_KEY } from './emitter.mjs';
|
|
4
5
|
import { updateCLIConfig } from './CLIConfig.mjs';
|
|
@@ -20,7 +21,7 @@ export async function createMerkurConfig({ cliConfig, context, args } = {}) {
|
|
|
20
21
|
);
|
|
21
22
|
|
|
22
23
|
const file = await import(
|
|
23
|
-
path.resolve(`${projectFolder}/${MERKUR_CONFIG_FILE}`)
|
|
24
|
+
pathToFileURL(path.resolve(`${projectFolder}/${MERKUR_CONFIG_FILE}`))
|
|
24
25
|
);
|
|
25
26
|
merkurConfig = await file.default({
|
|
26
27
|
cliConfig,
|