/
run-script.js
83 lines (74 loc) · 1.78 KB
/
run-script.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
const chalk = require('chalk')
const ciDetect = require('@npmcli/ci-detect')
const runScript = require('@npmcli/run-script')
const readPackageJson = require('read-package-json-fast')
const npmlog = require('npmlog')
const log = require('proc-log')
const noTTY = require('./no-tty.js')
const nocolor = {
reset: s => s,
bold: s => s,
dim: s => s,
}
const run = async ({
args,
call,
color,
flatOptions,
locationMsg,
output = () => {},
path,
binPaths,
runPath,
scriptShell,
}) => {
// turn list of args into command string
const script = call || args.shift() || scriptShell
const colorize = color ? chalk : nocolor
// do the fakey runScript dance
// still should work if no package.json in cwd
const realPkg = await readPackageJson(`${path}/package.json`)
.catch(() => ({}))
const pkg = {
...realPkg,
scripts: {
...(realPkg.scripts || {}),
npx: script,
},
}
npmlog.disableProgress()
try {
if (script === scriptShell) {
const isTTY = !noTTY()
if (isTTY) {
if (ciDetect()) {
return log.warn('exec', 'Interactive mode disabled in CI environment')
}
locationMsg = locationMsg || ` at location:\n${colorize.dim(runPath)}`
output(`${
colorize.reset('\nEntering npm script environment')
}${
colorize.reset(locationMsg)
}${
colorize.bold('\nType \'exit\' or ^D when finished\n')
}`)
}
}
return await runScript({
...flatOptions,
pkg,
banner: false,
// we always run in cwd, not --prefix
path: runPath,
stdioString: true,
binPaths,
event: 'npx',
args,
stdio: 'inherit',
scriptShell,
})
} finally {
npmlog.enableProgress()
}
}
module.exports = run