UNPKG

@dependabot/yarn-lib

Version:

📦🐈 Fast, reliable, and secure dependency management.

379 lines (297 loc) 12.4 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.execCommand = exports.execFromManifest = exports.executeLifecycleScript = exports.makeEnv = undefined; var _extends2; function _load_extends() { return _extends2 = _interopRequireDefault(require('babel-runtime/helpers/extends')); } var _asyncToGenerator2; function _load_asyncToGenerator() { return _asyncToGenerator2 = _interopRequireDefault(require('babel-runtime/helpers/asyncToGenerator')); } let makeEnv = exports.makeEnv = (() => { var _ref = (0, (_asyncToGenerator2 || _load_asyncToGenerator()).default)(function* (stage, cwd, config) { const env = (0, (_extends2 || _load_extends()).default)({ NODE: process.execPath }, process.env); // Merge in the `env` object specified in .yarnrc const customEnv = config.getOption('env'); if (customEnv && typeof customEnv === 'object') { Object.assign(env, customEnv); } env.npm_lifecycle_event = stage; env.npm_node_execpath = env.NODE; env.npm_execpath = env.npm_execpath || process.mainModule.filename; // Set the env to production for npm compat if production mode. // https://github.com/npm/npm/blob/30d75e738b9cb7a6a3f9b50e971adcbe63458ed3/lib/utils/lifecycle.js#L336 if (config.production) { env.NODE_ENV = 'production'; } // Note: npm_config_argv environment variable contains output of nopt - command-line // parser used by npm. Since we use other parser, we just roughly emulate it's output. (See: #684) env.npm_config_argv = JSON.stringify({ remain: [], cooked: config.commandName === 'run' ? [config.commandName, stage] : [config.commandName], original: process.argv.slice(2) }); const manifest = yield config.maybeReadManifest(cwd); if (manifest) { if (manifest.scripts && Object.prototype.hasOwnProperty.call(manifest.scripts, stage)) { env.npm_lifecycle_script = manifest.scripts[stage]; } // add npm_package_* const queue = [['', manifest]]; while (queue.length) { var _queue$pop = queue.pop(); const key = _queue$pop[0], val = _queue$pop[1]; if (key[0] === '_') { continue; } if (typeof val === 'object') { for (const subKey in val) { const completeKey = [key, subKey].filter(function (part) { return !!part; }).join('_'); queue.push([completeKey, val[subKey]]); } } else if (IGNORE_MANIFEST_KEYS.indexOf(key) < 0) { let cleanVal = String(val); if (cleanVal.indexOf('\n') >= 0) { cleanVal = JSON.stringify(cleanVal); } //replacing invalid chars with underscore const cleanKey = key.replace(/[^a-zA-Z0-9_]/g, '_'); env[`npm_package_${cleanKey}`] = cleanVal; } } } // add npm_config_* const keys = new Set([...Object.keys(config.registries.yarn.config), ...Object.keys(config.registries.npm.config)]); for (var _iterator = keys, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) { var _ref2; if (_isArray) { if (_i >= _iterator.length) break; _ref2 = _iterator[_i++]; } else { _i = _iterator.next(); if (_i.done) break; _ref2 = _i.value; } const key = _ref2; if (key.match(/:_/) || IGNORE_CONFIG_KEYS.indexOf(key) >= 0) { continue; } let val = config.getOption(key); if (!val) { val = ''; } else if (typeof val === 'number') { val = '' + val; } else if (typeof val !== 'string') { val = JSON.stringify(val); } if (val.indexOf('\n') >= 0) { val = JSON.stringify(val); } const cleanKey = key.replace(/^_+/, ''); const envKey = `npm_config_${cleanKey}`.replace(/[^a-zA-Z0-9_]/g, '_'); env[envKey] = val; } // split up the path const envPath = env[(_constants || _load_constants()).ENV_PATH_KEY]; const pathParts = envPath ? envPath.split(path.delimiter) : []; // Include node-gyp version that was bundled with the current Node.js version, // if available. pathParts.unshift(path.join(path.dirname(process.execPath), 'node_modules', 'npm', 'bin', 'node-gyp-bin')); pathParts.unshift(path.join(path.dirname(process.execPath), '..', 'lib', 'node_modules', 'npm', 'bin', 'node-gyp-bin')); // Include node-gyp version from homebrew managed npm, if available. pathParts.unshift(path.join(path.dirname(process.execPath), '..', 'libexec', 'lib', 'node_modules', 'npm', 'bin', 'node-gyp-bin')); // Add global bin folder if it is not present already, as some packages depend // on a globally-installed version of node-gyp. const globalBin = yield (0, (_global || _load_global()).getBinFolder)(config, {}); if (pathParts.indexOf(globalBin) === -1) { pathParts.unshift(globalBin); } // add .bin folders to PATH for (var _iterator2 = Object.keys((_index || _load_index()).registries), _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) { var _ref3; if (_isArray2) { if (_i2 >= _iterator2.length) break; _ref3 = _iterator2[_i2++]; } else { _i2 = _iterator2.next(); if (_i2.done) break; _ref3 = _i2.value; } const registry = _ref3; const binFolder = path.join(config.registries[registry].folder, '.bin'); if (config.workspacesEnabled && config.workspaceRootFolder) { pathParts.unshift(path.join(config.workspaceRootFolder, binFolder)); } pathParts.unshift(path.join(config.linkFolder, binFolder)); pathParts.unshift(path.join(cwd, binFolder)); } if (config.scriptsPrependNodePath) { pathParts.unshift(path.join(path.dirname(process.execPath))); } // join path back together env[(_constants || _load_constants()).ENV_PATH_KEY] = pathParts.join(path.delimiter); return env; }); return function makeEnv(_x, _x2, _x3) { return _ref.apply(this, arguments); }; })(); let executeLifecycleScript = exports.executeLifecycleScript = (() => { var _ref4 = (0, (_asyncToGenerator2 || _load_asyncToGenerator()).default)(function* (stage, config, cwd, cmd, spinner, customShell) { // if we don't have a spinner then pipe everything to the terminal const stdio = spinner ? undefined : 'inherit'; const env = yield makeEnv(stage, cwd, config); yield checkForGypIfNeeded(config, cmd, env[(_constants || _load_constants()).ENV_PATH_KEY].split(path.delimiter)); // get shell let sh = 'sh'; let shFlag = '-c'; let windowsVerbatimArguments = undefined; if (customShell) { sh = customShell; } else if (process.platform === 'win32') { sh = process.env.comspec || 'cmd'; shFlag = '/d /s /c'; windowsVerbatimArguments = true; // handle windows run scripts starting with a relative path cmd = (0, (_fixCmdWinSlashes || _load_fixCmdWinSlashes()).fixCmdWinSlashes)(cmd); } let updateProgress; if (spinner) { updateProgress = function updateProgress(data) { const dataStr = data.toString() // turn buffer into string .trim(); // trim whitespace invariant(spinner && spinner.tick, 'We should have spinner and its ticker here'); if (dataStr) { spinner.tick(dataStr // Only get the last line .substr(dataStr.lastIndexOf('\n') + 1) // change tabs to spaces as they can interfere with the console .replace(/\t/g, ' ')); } }; } const stdout = yield (_child || _load_child()).spawn(sh, [shFlag, cmd], { cwd, env, stdio, windowsVerbatimArguments }, updateProgress); return { cwd, command: cmd, stdout }; }); return function executeLifecycleScript(_x4, _x5, _x6, _x7, _x8, _x9) { return _ref4.apply(this, arguments); }; })(); let _checkForGyp = (() => { var _ref5 = (0, (_asyncToGenerator2 || _load_asyncToGenerator()).default)(function* (config, paths) { const reporter = config.reporter; // Check every directory in the PATH const allChecks = yield Promise.all(paths.map(function (dir) { return (0, (_fs || _load_fs()).exists)(path.join(dir, 'node-gyp')); })); if (allChecks.some(Boolean)) { // node-gyp is available somewhere return; } reporter.info(reporter.lang('packageRequiresNodeGyp')); try { yield (0, (_global || _load_global()).run)(config, reporter, {}, ['add', 'node-gyp']); } catch (e) { throw new (_errors || _load_errors()).MessageError(reporter.lang('nodeGypAutoInstallFailed', e.message)); } }); return function _checkForGyp(_x10, _x11) { return _ref5.apply(this, arguments); }; })(); let execFromManifest = exports.execFromManifest = (() => { var _ref6 = (0, (_asyncToGenerator2 || _load_asyncToGenerator()).default)(function* (config, commandName, cwd) { const pkg = yield config.maybeReadManifest(cwd); if (!pkg || !pkg.scripts) { return; } const cmd = pkg.scripts[commandName]; if (cmd) { yield execCommand(commandName, config, cmd, cwd); } }); return function execFromManifest(_x12, _x13, _x14) { return _ref6.apply(this, arguments); }; })(); let execCommand = exports.execCommand = (() => { var _ref7 = (0, (_asyncToGenerator2 || _load_asyncToGenerator()).default)(function* (stage, config, cmd, cwd, customShell) { const reporter = config.reporter; try { reporter.command(cmd); yield executeLifecycleScript(stage, config, cwd, cmd, undefined, customShell); return Promise.resolve(); } catch (err) { if (err instanceof (_errors || _load_errors()).ProcessTermError) { throw new (_errors || _load_errors()).MessageError(err.EXIT_SIGNAL ? reporter.lang('commandFailedWithSignal', err.EXIT_SIGNAL) : reporter.lang('commandFailedWithCode', err.EXIT_CODE)); } else { throw err; } } }); return function execCommand(_x15, _x16, _x17, _x18, _x19) { return _ref7.apply(this, arguments); }; })(); var _errors; function _load_errors() { return _errors = require('../errors.js'); } var _constants; function _load_constants() { return _constants = _interopRequireWildcard(require('../constants.js')); } var _child; function _load_child() { return _child = _interopRequireWildcard(require('./child.js')); } var _fs; function _load_fs() { return _fs = require('./fs.js'); } var _index; function _load_index() { return _index = require('../resolvers/index.js'); } var _fixCmdWinSlashes; function _load_fixCmdWinSlashes() { return _fixCmdWinSlashes = require('./fix-cmd-win-slashes.js'); } var _global; function _load_global() { return _global = require('../cli/commands/global.js'); } function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } const invariant = require('invariant'); const path = require('path'); const IGNORE_MANIFEST_KEYS = ['readme']; // We treat these configs as internal, thus not expose them to process.env. // This helps us avoid some gyp issues when building native modules. // See https://github.com/yarnpkg/yarn/issues/2286. const IGNORE_CONFIG_KEYS = ['lastUpdateCheck']; exports.default = executeLifecycleScript; let checkGypPromise = null; /** * Special case: Some packages depend on node-gyp, but don't specify this in * their package.json dependencies. They assume that node-gyp is available * globally. We need to detect this case and show an error message. */ function checkForGypIfNeeded(config, cmd, paths) { if (cmd.substr(0, cmd.indexOf(' ')) !== 'node-gyp') { return Promise.resolve(); } // Ensure this only runs once, rather than multiple times in parallel. if (!checkGypPromise) { checkGypPromise = _checkForGyp(config, paths); } return checkGypPromise; }