mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-04 20:45:52 +01:00
Do not fork ui-script commands
Forking of the commands could lead to open processes, even if the parent was stopped with ctrl+c.
This commit is contained in:
committed by
René Pfeuffer
parent
0a4b5d0439
commit
d8a04a1113
@@ -22,10 +22,20 @@
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
*/
|
||||
/* eslint-disable no-console */
|
||||
const { spawnSync } = require("child_process");
|
||||
|
||||
const commands = ["plugin", "plugin-watch", "plugin-publish", "publish", "version"];
|
||||
const fs = require("fs");
|
||||
const path = require("path");
|
||||
|
||||
const commandDir = path.join(__dirname, "../src/commands");
|
||||
const commands = fs
|
||||
.readdirSync(commandDir)
|
||||
.map(script => {
|
||||
if (script.endsWith(".js")) {
|
||||
return script.replace(".js", "");
|
||||
}
|
||||
return undefined;
|
||||
})
|
||||
.filter(cmd => !!cmd);
|
||||
|
||||
const args = process.argv.slice(2);
|
||||
|
||||
@@ -33,33 +43,14 @@ const commandIndex = args.findIndex(arg => {
|
||||
return commands.includes(arg);
|
||||
});
|
||||
|
||||
const command = commandIndex === -1 ? args[0] : args[commandIndex];
|
||||
const nodeArgs = commandIndex > 0 ? args.slice(0, commandIndex) : [];
|
||||
|
||||
if (commands.includes(command)) {
|
||||
const result = spawnSync(
|
||||
"node",
|
||||
nodeArgs.concat(require.resolve(`../src/commands/${command}`)).concat(args.slice(commandIndex + 1)),
|
||||
{ stdio: "inherit" }
|
||||
);
|
||||
if (result.signal) {
|
||||
if (result.signal === "SIGKILL") {
|
||||
console.log(
|
||||
"The build failed because the process exited too early. " +
|
||||
"This probably means the system ran out of memory or someone called " +
|
||||
"`kill -9` on the process."
|
||||
);
|
||||
} else if (result.signal === "SIGTERM") {
|
||||
console.log(
|
||||
"The build failed because the process exited too early. " +
|
||||
"Someone might have called `kill` or `killall`, or the system could " +
|
||||
"be shutting down."
|
||||
);
|
||||
}
|
||||
process.exit(1);
|
||||
}
|
||||
process.exit(result.status);
|
||||
const commandName = commandIndex === -1 ? args[0] : args[commandIndex];
|
||||
if (!commandName) {
|
||||
console.log(`Use plugin-scripts [${commands.join(", ")}]`);
|
||||
} else if (commands.includes(commandName)) {
|
||||
// eslint-disable-next-line
|
||||
const command = require(path.join(commandDir, `${commandName}.js`));
|
||||
command(args.slice(commandIndex + 1));
|
||||
} else {
|
||||
console.log(`Unknown script "${command}".`);
|
||||
console.log("Perhaps you need to update ui-scripts?");
|
||||
console.log(`Unknown script "${commandName}".`);
|
||||
console.log("Perhaps you need to update plugin-scripts?");
|
||||
}
|
||||
|
||||
@@ -24,22 +24,22 @@
|
||||
const yarn = require("../yarn");
|
||||
const versions = require("../versions");
|
||||
|
||||
const args = process.argv.slice(2);
|
||||
module.exports = args => {
|
||||
if (args.length < 1) {
|
||||
console.log("usage ui-scripts publish <version>");
|
||||
process.exit(1);
|
||||
}
|
||||
|
||||
if (args.length < 1) {
|
||||
console.log("usage ui-scripts publish <version>");
|
||||
process.exit(1);
|
||||
}
|
||||
|
||||
const version = args[0];
|
||||
const index = version.indexOf("-SNAPSHOT");
|
||||
if (index > 0) {
|
||||
const snapshotVersion = `${version.substring(0, index)}-${versions.createSnapshotVersion()}`;
|
||||
console.log(`publish snapshot release ${snapshotVersion}`);
|
||||
yarn.version(snapshotVersion);
|
||||
yarn.publish(snapshotVersion);
|
||||
yarn.version(version);
|
||||
} else {
|
||||
// ?? not sure
|
||||
yarn.publish(version);
|
||||
}
|
||||
const version = args[0];
|
||||
const index = version.indexOf("-SNAPSHOT");
|
||||
if (index > 0) {
|
||||
const snapshotVersion = `${version.substring(0, index)}-${versions.createSnapshotVersion()}`;
|
||||
console.log(`publish snapshot release ${snapshotVersion}`);
|
||||
yarn.version(snapshotVersion);
|
||||
yarn.publish(snapshotVersion);
|
||||
yarn.version(version);
|
||||
} else {
|
||||
// ?? not sure
|
||||
yarn.publish(version);
|
||||
}
|
||||
};
|
||||
|
||||
@@ -24,11 +24,15 @@
|
||||
const webpack = require("webpack");
|
||||
const createPluginConfig = require("../createPluginConfig");
|
||||
|
||||
const config = createPluginConfig("development");
|
||||
const compiler = webpack(config);
|
||||
module.exports = () => {
|
||||
const config = createPluginConfig("development");
|
||||
const compiler = webpack(config);
|
||||
|
||||
compiler.watch({}, (err, stats) => {
|
||||
console.log(stats.toString({
|
||||
colors: true
|
||||
}));
|
||||
});
|
||||
compiler.watch({}, (err, stats) => {
|
||||
console.log(
|
||||
stats.toString({
|
||||
colors: true
|
||||
})
|
||||
);
|
||||
});
|
||||
};
|
||||
|
||||
@@ -24,13 +24,17 @@
|
||||
const webpack = require("webpack");
|
||||
const createPluginConfig = require("../createPluginConfig");
|
||||
|
||||
const config = createPluginConfig("production");
|
||||
module.exports = () => {
|
||||
const config = createPluginConfig("production");
|
||||
|
||||
webpack(config, (err, stats) => {
|
||||
console.log(stats.toString({
|
||||
colors: true
|
||||
}));
|
||||
if (err || stats.hasErrors()) {
|
||||
process.exit(1);
|
||||
}
|
||||
});
|
||||
webpack(config, (err, stats) => {
|
||||
console.log(
|
||||
stats.toString({
|
||||
colors: true
|
||||
})
|
||||
);
|
||||
if (err || stats.hasErrors()) {
|
||||
process.exit(1);
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
@@ -24,26 +24,22 @@
|
||||
const lerna = require("../lerna");
|
||||
const versions = require("../versions");
|
||||
|
||||
const args = process.argv.slice(2);
|
||||
|
||||
if (args.length < 1) {
|
||||
console.log("usage ui-scripts publish <version>");
|
||||
process.exit(1);
|
||||
}
|
||||
|
||||
const version = args[0];
|
||||
const index = version.indexOf("-SNAPSHOT");
|
||||
if (index > 0) {
|
||||
const snapshotVersion = version.substring(0, index) + "-" + versions.createSnapshotVersion();
|
||||
console.log("publish snapshot release " + snapshotVersion);
|
||||
lerna.version(snapshotVersion);
|
||||
lerna.publish();
|
||||
lerna.version(version);
|
||||
} else {
|
||||
// ?? not sure
|
||||
lerna.publish();
|
||||
}
|
||||
|
||||
|
||||
|
||||
module.exports = args => {
|
||||
if (args.length < 1) {
|
||||
console.log("usage ui-scripts publish <version>");
|
||||
process.exit(1);
|
||||
}
|
||||
|
||||
const version = args[0];
|
||||
const index = version.indexOf("-SNAPSHOT");
|
||||
if (index > 0) {
|
||||
const snapshotVersion = `${version.substring(0, index)}-${versions.createSnapshotVersion()}`;
|
||||
console.log(`publish snapshot release ${snapshotVersion}`);
|
||||
lerna.version(snapshotVersion);
|
||||
lerna.publish();
|
||||
lerna.version(version);
|
||||
} else {
|
||||
// ?? not sure
|
||||
lerna.publish();
|
||||
}
|
||||
};
|
||||
|
||||
@@ -23,13 +23,13 @@
|
||||
*/
|
||||
const lerna = require("../lerna");
|
||||
|
||||
const args = process.argv.slice(2);
|
||||
module.exports = args => {
|
||||
if (args.length < 1) {
|
||||
console.log("usage ui-scripts version <new-version>");
|
||||
process.exit(1);
|
||||
}
|
||||
|
||||
if (args.length < 1) {
|
||||
console.log("usage ui-scripts version <new-version>");
|
||||
process.exit(1);
|
||||
}
|
||||
const version = args[0];
|
||||
|
||||
const version = args[0];
|
||||
|
||||
lerna.version(version);
|
||||
lerna.version(version);
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user