mirror of
https://github.com/discourse/discourse.git
synced 2024-11-23 20:43:19 +08:00
DEV: Automatically add --ignore-workspace
when pnpm used in plugins (#28878)
This commit is contained in:
parent
00ae6cc430
commit
600801f194
|
@ -1,7 +1,9 @@
|
|||
const fs = require("fs");
|
||||
const { execSync } = require("child_process");
|
||||
const { execSync, execFileSync } = require("child_process");
|
||||
|
||||
if (fs.existsSync("node_modules/.yarn-integrity")) {
|
||||
const discourseRoot = __dirname;
|
||||
|
||||
if (fs.existsSync(`${discourseRoot}/node_modules/.yarn-integrity`)) {
|
||||
console.log(
|
||||
"Detected yarn-managed node_modules. Performing one-time cleanup..."
|
||||
);
|
||||
|
@ -9,8 +11,40 @@ if (fs.existsSync("node_modules/.yarn-integrity")) {
|
|||
// Delete entire contents of all node_modules directories
|
||||
// But keep the directories themselves, in case they are volume mounts (e.g. in devcontainer)
|
||||
execSync(
|
||||
"find ./node_modules ./app/assets/javascripts/*/node_modules -mindepth 1 -maxdepth 1 -exec rm -rf {} +"
|
||||
`find ${discourseRoot}/node_modules ${discourseRoot}/app/assets/javascripts/*/node_modules -mindepth 1 -maxdepth 1 -exec rm -rf {} +`
|
||||
);
|
||||
|
||||
console.log("cleanup done");
|
||||
}
|
||||
|
||||
const pluginBase = `${discourseRoot}/plugins/`;
|
||||
const cwd = process.cwd();
|
||||
const pluginName =
|
||||
cwd.startsWith(pluginBase) && cwd.replace(pluginBase, "").split("/", 2)[0];
|
||||
|
||||
if (
|
||||
pluginName &&
|
||||
fs.existsSync(`${discourseRoot}/plugins/${pluginName}/package.json`) &&
|
||||
!process.argv.includes("--ignore-workspace")
|
||||
) {
|
||||
console.log(
|
||||
"> pnpm was run inside a plugin directory. Re-executing with --ignore-workspace..."
|
||||
);
|
||||
|
||||
try {
|
||||
execFileSync(
|
||||
process.argv[0],
|
||||
[...process.argv.slice(1), "--ignore-workspace"],
|
||||
{
|
||||
stdio: "inherit",
|
||||
}
|
||||
);
|
||||
} catch (e) {
|
||||
if (e.status) {
|
||||
process.exit(e.status);
|
||||
}
|
||||
throw e;
|
||||
}
|
||||
|
||||
process.exit(0);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue
Block a user