1
0
mirror of https://github.com/citizenfx/cfx-server-data.git synced 2025-01-23 01:12:57 +08:00

Compare commits

...

2 Commits

Author SHA1 Message Date
blattersturm
7cbf600593 tweak(yarn): update yarn_cli.js to 1.22.5 2020-09-09 10:37:08 +02:00
blattersturm
25fd26e2e4 fix(yarn): per-server cache folder, mutex, cleaner phrasing for reinit, cleaner async call 2020-09-09 10:35:26 +02:00
2 changed files with 223 additions and 103 deletions

View File

@ -4,6 +4,8 @@ const child_process = require('child_process');
let buildingInProgress = false; let buildingInProgress = false;
let currentBuildingModule = ''; let currentBuildingModule = '';
const initCwd = process.cwd();
const yarnBuildTask = { const yarnBuildTask = {
shouldBuild(resourceName) { shouldBuild(resourceName) {
try { try {
@ -32,20 +34,19 @@ const yarnBuildTask = {
}, },
build(resourceName, cb) { build(resourceName, cb) {
let buildYarn = async () => { (async () => {
while (buildingInProgress) { while (buildingInProgress && currentBuildingModule !== resourceName) {
console.log(`yarn is busy by another process: we are waiting to compile ${resourceName}`); console.log(`yarn is currently busy: we are waiting to compile ${resourceName}`);
await sleep(3000); await sleep(3000);
} }
buildingInProgress = true; buildingInProgress = true;
currentBuildingModule = resourceName; currentBuildingModule = resourceName;
const process = child_process.fork( const process = child_process.fork(
require.resolve('./yarn_cli.js'), require.resolve('./yarn_cli.js'),
['install', '--ignore-scripts'], ['install', '--ignore-scripts', '--cache-folder', path.join(initCwd, 'cache', 'yarn-cache'), '--mutex', 'file:' + path.join(initCwd, 'cache', 'yarn-mutex')],
{ {
cwd: path.resolve(GetResourcePath(resourceName)) cwd: path.resolve(GetResourcePath(resourceName))
}); });
process.on('exit', (code, signal) => { process.on('exit', (code, signal) => {
setImmediate(() => { setImmediate(() => {
if (code != 0 || signal) { if (code != 0 || signal) {
@ -69,8 +70,7 @@ const yarnBuildTask = {
cb(true); cb(true);
}); });
}); });
}; })();
buildYarn().then();
} }
}; };

View File

@ -34805,15 +34805,27 @@ function hasMergeConflicts(str) {
function parse(str, fileLoc) { function parse(str, fileLoc) {
const parser = new Parser(str, fileLoc); const parser = new Parser(str, fileLoc);
parser.next(); parser.next();
try {
return parser.parse(); if (!fileLoc.endsWith(`.yml`)) {
} catch (error1) {
try { try {
return safeLoad(str, { return parser.parse();
schema: FAILSAFE_SCHEMA } catch (error1) {
}); try {
} catch (error2) { return safeLoad(str, {
throw error1; schema: FAILSAFE_SCHEMA
});
} catch (error2) {
throw error1;
}
}
} else {
const result = safeLoad(str, {
schema: FAILSAFE_SCHEMA
});
if (typeof result === 'object') {
return result;
} else {
return {};
} }
} }
} }
@ -44642,7 +44654,7 @@ const FOLDERS_IGNORE = [
const DEFAULT_IGNORE = (0, (_filter || _load_filter()).ignoreLinesToRegex)([...FOLDERS_IGNORE, const DEFAULT_IGNORE = (0, (_filter || _load_filter()).ignoreLinesToRegex)([...FOLDERS_IGNORE,
// ignore cruft // ignore cruft
'yarn.lock', '.lock-wscript', '.wafpickle-{0..9}', '*.swp', '._*', 'npm-debug.log', 'yarn-error.log', '.npmrc', '.yarnrc', '.npmignore', '.gitignore', '.DS_Store']); 'yarn.lock', '.lock-wscript', '.wafpickle-{0..9}', '*.swp', '._*', 'npm-debug.log', 'yarn-error.log', '.npmrc', '.yarnrc', '.yarnrc.yml', '.npmignore', '.gitignore', '.DS_Store']);
const NEVER_IGNORE = (0, (_filter || _load_filter()).ignoreLinesToRegex)([ const NEVER_IGNORE = (0, (_filter || _load_filter()).ignoreLinesToRegex)([
// never ignore these files // never ignore these files
@ -44651,6 +44663,7 @@ const NEVER_IGNORE = (0, (_filter || _load_filter()).ignoreLinesToRegex)([
function packWithIgnoreAndHeaders(cwd, ignoreFunction, { mapHeader } = {}) { function packWithIgnoreAndHeaders(cwd, ignoreFunction, { mapHeader } = {}) {
return tar.pack(cwd, { return tar.pack(cwd, {
ignore: ignoreFunction, ignore: ignoreFunction,
sort: true,
map: header => { map: header => {
const suffix = header.name === '.' ? '' : `/${header.name}`; const suffix = header.name === '.' ? '' : `/${header.name}`;
header.name = `package${suffix}`; header.name = `package${suffix}`;
@ -46666,7 +46679,7 @@ function mkdirfix (name, opts, cb) {
/* 194 */ /* 194 */
/***/ (function(module, exports) { /***/ (function(module, exports) {
module.exports = {"name":"yarn","installationMethod":"unknown","version":"1.21.0","license":"BSD-2-Clause","preferGlobal":true,"description":"📦🐈 Fast, reliable, and secure dependency management.","dependencies":{"@zkochan/cmd-shim":"^3.1.0","babel-runtime":"^6.26.0","bytes":"^3.0.0","camelcase":"^4.0.0","chalk":"^2.1.0","cli-table3":"^0.4.0","commander":"^2.9.0","death":"^1.0.0","debug":"^3.0.0","deep-equal":"^1.0.1","detect-indent":"^5.0.0","dnscache":"^1.0.1","glob":"^7.1.1","gunzip-maybe":"^1.4.0","hash-for-dep":"^1.2.3","imports-loader":"^0.8.0","ini":"^1.3.4","inquirer":"^6.2.0","invariant":"^2.2.0","is-builtin-module":"^2.0.0","is-ci":"^1.0.10","is-webpack-bundle":"^1.0.0","js-yaml":"^3.13.1","leven":"^2.0.0","loud-rejection":"^1.2.0","micromatch":"^2.3.11","mkdirp":"^0.5.1","node-emoji":"^1.6.1","normalize-url":"^2.0.0","npm-logical-tree":"^1.2.1","object-path":"^0.11.2","proper-lockfile":"^2.0.0","puka":"^1.0.0","read":"^1.0.7","request":"^2.87.0","request-capture-har":"^1.2.2","rimraf":"^2.5.0","semver":"^5.1.0","ssri":"^5.3.0","strip-ansi":"^4.0.0","strip-bom":"^3.0.0","tar-fs":"^1.16.0","tar-stream":"^1.6.1","uuid":"^3.0.1","v8-compile-cache":"^2.0.0","validate-npm-package-license":"^3.0.4","yn":"^2.0.0"},"devDependencies":{"babel-core":"^6.26.0","babel-eslint":"^7.2.3","babel-loader":"^6.2.5","babel-plugin-array-includes":"^2.0.3","babel-plugin-inline-import":"^3.0.0","babel-plugin-transform-builtin-extend":"^1.1.2","babel-plugin-transform-inline-imports-commonjs":"^1.0.0","babel-plugin-transform-runtime":"^6.4.3","babel-preset-env":"^1.6.0","babel-preset-flow":"^6.23.0","babel-preset-stage-0":"^6.0.0","babylon":"^6.5.0","commitizen":"^2.9.6","cz-conventional-changelog":"^2.0.0","eslint":"^4.3.0","eslint-config-fb-strict":"^22.0.0","eslint-plugin-babel":"^5.0.0","eslint-plugin-flowtype":"^2.35.0","eslint-plugin-jasmine":"^2.6.2","eslint-plugin-jest":"^21.0.0","eslint-plugin-jsx-a11y":"^6.0.2","eslint-plugin-prefer-object-spread":"^1.2.1","eslint-plugin-prettier":"^2.1.2","eslint-plugin-react":"^7.1.0","eslint-plugin-relay":"^0.0.28","eslint-plugin-yarn-internal":"file:scripts/eslint-rules","execa":"^0.11.0","fancy-log":"^1.3.2","flow-bin":"^0.66.0","git-release-notes":"^3.0.0","gulp":"^4.0.0","gulp-babel":"^7.0.0","gulp-if":"^2.0.1","gulp-newer":"^1.0.0","gulp-plumber":"^1.0.1","gulp-sourcemaps":"^2.2.0","jest":"^22.4.4","jsinspect":"^0.12.6","minimatch":"^3.0.4","mock-stdin":"^0.3.0","prettier":"^1.5.2","string-replace-loader":"^2.1.1","temp":"^0.8.3","webpack":"^2.1.0-beta.25","yargs":"^6.3.0"},"resolutions":{"sshpk":"^1.14.2"},"engines":{"node":">=4.0.0"},"repository":"yarnpkg/yarn","bin":{"yarn":"./bin/yarn.js","yarnpkg":"./bin/yarn.js"},"scripts":{"build":"gulp build","build-bundle":"node ./scripts/build-webpack.js","build-chocolatey":"powershell ./scripts/build-chocolatey.ps1","build-deb":"./scripts/build-deb.sh","build-dist":"bash ./scripts/build-dist.sh","build-win-installer":"scripts\\build-windows-installer.bat","changelog":"git-release-notes $(git describe --tags --abbrev=0 $(git describe --tags --abbrev=0)^)..$(git describe --tags --abbrev=0) scripts/changelog.md","dupe-check":"yarn jsinspect ./src","lint":"eslint . && flow check","pkg-tests":"yarn --cwd packages/pkg-tests jest yarn.test.js","prettier":"eslint src __tests__ --fix","release-branch":"./scripts/release-branch.sh","test":"yarn lint && yarn test-only","test-only":"node --max_old_space_size=4096 node_modules/jest/bin/jest.js --verbose","test-only-debug":"node --inspect-brk --max_old_space_size=4096 node_modules/jest/bin/jest.js --runInBand --verbose","test-coverage":"node --max_old_space_size=4096 node_modules/jest/bin/jest.js --coverage --verbose","watch":"gulp watch","commit":"git-cz"},"jest":{"collectCoverageFrom":["src/**/*.js"],"testEnvironment":"node","modulePathIgnorePatterns":["__tests__/fixtures/","packages/pkg-tests/pkg-tests-fixtures","dist/"],"testPathIgnorePatterns":["__tests__/(fixtures|__mocks__)/","updates/","_(temp|mock|install|init|helpers).js$","packages/pkg-tests"]},"config":{"commitizen":{"path":"./node_modules/cz-conventional-changelog"}}} module.exports = {"name":"yarn","installationMethod":"unknown","version":"1.22.5","license":"BSD-2-Clause","preferGlobal":true,"description":"📦🐈 Fast, reliable, and secure dependency management.","dependencies":{"@zkochan/cmd-shim":"^3.1.0","babel-runtime":"^6.26.0","bytes":"^3.0.0","camelcase":"^4.0.0","chalk":"^2.1.0","cli-table3":"^0.4.0","commander":"^2.9.0","death":"^1.0.0","debug":"^3.0.0","deep-equal":"^1.0.1","detect-indent":"^5.0.0","dnscache":"^1.0.1","glob":"^7.1.1","gunzip-maybe":"^1.4.0","hash-for-dep":"^1.2.3","imports-loader":"^0.8.0","ini":"^1.3.4","inquirer":"^6.2.0","invariant":"^2.2.0","is-builtin-module":"^2.0.0","is-ci":"^1.0.10","is-webpack-bundle":"^1.0.0","js-yaml":"^3.13.1","leven":"^2.0.0","loud-rejection":"^1.2.0","micromatch":"^2.3.11","mkdirp":"^0.5.1","node-emoji":"^1.6.1","normalize-url":"^2.0.0","npm-logical-tree":"^1.2.1","object-path":"^0.11.2","proper-lockfile":"^2.0.0","puka":"^1.0.0","read":"^1.0.7","request":"^2.87.0","request-capture-har":"^1.2.2","rimraf":"^2.5.0","semver":"^5.1.0","ssri":"^5.3.0","strip-ansi":"^4.0.0","strip-bom":"^3.0.0","tar-fs":"^1.16.0","tar-stream":"^1.6.1","uuid":"^3.0.1","v8-compile-cache":"^2.0.0","validate-npm-package-license":"^3.0.4","yn":"^2.0.0"},"devDependencies":{"babel-core":"^6.26.0","babel-eslint":"^7.2.3","babel-loader":"^6.2.5","babel-plugin-array-includes":"^2.0.3","babel-plugin-inline-import":"^3.0.0","babel-plugin-transform-builtin-extend":"^1.1.2","babel-plugin-transform-inline-imports-commonjs":"^1.0.0","babel-plugin-transform-runtime":"^6.4.3","babel-preset-env":"^1.6.0","babel-preset-flow":"^6.23.0","babel-preset-stage-0":"^6.0.0","babylon":"^6.5.0","commitizen":"^2.9.6","cz-conventional-changelog":"^2.0.0","eslint":"^4.3.0","eslint-config-fb-strict":"^22.0.0","eslint-plugin-babel":"^5.0.0","eslint-plugin-flowtype":"^2.35.0","eslint-plugin-jasmine":"^2.6.2","eslint-plugin-jest":"^21.0.0","eslint-plugin-jsx-a11y":"^6.0.2","eslint-plugin-prefer-object-spread":"^1.2.1","eslint-plugin-prettier":"^2.1.2","eslint-plugin-react":"^7.1.0","eslint-plugin-relay":"^0.0.28","eslint-plugin-yarn-internal":"file:scripts/eslint-rules","execa":"^0.11.0","fancy-log":"^1.3.2","flow-bin":"^0.66.0","git-release-notes":"^3.0.0","gulp":"^4.0.0","gulp-babel":"^7.0.0","gulp-if":"^2.0.1","gulp-newer":"^1.0.0","gulp-plumber":"^1.0.1","gulp-sourcemaps":"^2.2.0","jest":"^22.4.4","jsinspect":"^0.12.6","minimatch":"^3.0.4","mock-stdin":"^0.3.0","prettier":"^1.5.2","string-replace-loader":"^2.1.1","temp":"^0.8.3","webpack":"^2.1.0-beta.25","yargs":"^6.3.0"},"resolutions":{"sshpk":"^1.14.2"},"engines":{"node":">=4.0.0"},"repository":"yarnpkg/yarn","bin":{"yarn":"./bin/yarn.js","yarnpkg":"./bin/yarn.js"},"scripts":{"build":"gulp build","build-bundle":"node ./scripts/build-webpack.js","build-chocolatey":"powershell ./scripts/build-chocolatey.ps1","build-deb":"./scripts/build-deb.sh","build-dist":"bash ./scripts/build-dist.sh","build-win-installer":"scripts\\build-windows-installer.bat","changelog":"git-release-notes $(git describe --tags --abbrev=0 $(git describe --tags --abbrev=0)^)..$(git describe --tags --abbrev=0) scripts/changelog.md","dupe-check":"yarn jsinspect ./src","lint":"eslint . && flow check","pkg-tests":"yarn --cwd packages/pkg-tests jest yarn.test.js","prettier":"eslint src __tests__ --fix","release-branch":"./scripts/release-branch.sh","test":"yarn lint && yarn test-only","test-only":"node --max_old_space_size=4096 node_modules/jest/bin/jest.js --verbose","test-only-debug":"node --inspect-brk --max_old_space_size=4096 node_modules/jest/bin/jest.js --runInBand --verbose","test-coverage":"node --max_old_space_size=4096 node_modules/jest/bin/jest.js --coverage --verbose","watch":"gulp watch","commit":"git-cz"},"jest":{"collectCoverageFrom":["src/**/*.js"],"testEnvironment":"node","modulePathIgnorePatterns":["__tests__/fixtures/","packages/pkg-tests/pkg-tests-fixtures","dist/"],"testPathIgnorePatterns":["__tests__/(fixtures|__mocks__)/","updates/","_(temp|mock|install|init|helpers).js$","packages/pkg-tests"]},"config":{"commitizen":{"path":"./node_modules/cz-conventional-changelog"}}}
/***/ }), /***/ }),
/* 195 */ /* 195 */
@ -52045,6 +52058,7 @@ Object.defineProperty(exports, "__esModule", {
value: true value: true
}); });
exports.isValidLicense = isValidLicense; exports.isValidLicense = isValidLicense;
exports.isValidBin = isValidBin;
exports.stringifyPerson = stringifyPerson; exports.stringifyPerson = stringifyPerson;
exports.parsePerson = parsePerson; exports.parsePerson = parsePerson;
exports.normalizePerson = normalizePerson; exports.normalizePerson = normalizePerson;
@ -52052,12 +52066,20 @@ exports.extractDescription = extractDescription;
exports.extractRepositoryUrl = extractRepositoryUrl; exports.extractRepositoryUrl = extractRepositoryUrl;
const path = __webpack_require__(0);
const validateLicense = __webpack_require__(959); const validateLicense = __webpack_require__(959);
const PARENT_PATH = /^\.\.([\\\/]|$)/;
function isValidLicense(license) { function isValidLicense(license) {
return !!license && validateLicense(license).validForNewPackages; return !!license && validateLicense(license).validForNewPackages;
} }
function isValidBin(bin) {
return !path.isAbsolute(bin) && !PARENT_PATH.test(path.normalize(bin));
}
function stringifyPerson(person) { function stringifyPerson(person) {
if (!person || typeof person !== 'object') { if (!person || typeof person !== 'object') {
return person; return person;
@ -69867,12 +69889,12 @@ function getRcConfigForFolder(cwd) {
} }
function loadRcFile(fileText, filePath) { function loadRcFile(fileText, filePath) {
var _parse = (0, (_lockfile || _load_lockfile()).parse)(fileText, 'yarnrc'); var _parse = (0, (_lockfile || _load_lockfile()).parse)(fileText, filePath);
let values = _parse.object; let values = _parse.object;
if (filePath.match(/\.yml$/)) { if (filePath.match(/\.yml$/) && typeof values.yarnPath === 'string') {
values = { 'yarn-path': values.yarnPath }; values = { 'yarn-path': values.yarnPath };
} }
@ -74839,7 +74861,20 @@ let run = exports.run = (() => {
} else { } else {
let suggestion; let suggestion;
for (const commandName in scripts) { for (var _iterator9 = scripts.keys(), _isArray9 = Array.isArray(_iterator9), _i9 = 0, _iterator9 = _isArray9 ? _iterator9 : _iterator9[Symbol.iterator]();;) {
var _ref16;
if (_isArray9) {
if (_i9 >= _iterator9.length) break;
_ref16 = _iterator9[_i9++];
} else {
_i9 = _iterator9.next();
if (_i9.done) break;
_ref16 = _i9.value;
}
const commandName = _ref16;
const steps = leven(commandName, action); const steps = leven(commandName, action);
if (steps < 2) { if (steps < 2) {
suggestion = commandName; suggestion = commandName;
@ -74924,19 +74959,19 @@ let run = exports.run = (() => {
const printedCommands = new Map(); const printedCommands = new Map();
for (var _iterator9 = pkgCommands, _isArray9 = Array.isArray(_iterator9), _i9 = 0, _iterator9 = _isArray9 ? _iterator9 : _iterator9[Symbol.iterator]();;) { for (var _iterator10 = pkgCommands, _isArray10 = Array.isArray(_iterator10), _i10 = 0, _iterator10 = _isArray10 ? _iterator10 : _iterator10[Symbol.iterator]();;) {
var _ref16; var _ref17;
if (_isArray9) { if (_isArray10) {
if (_i9 >= _iterator9.length) break; if (_i10 >= _iterator10.length) break;
_ref16 = _iterator9[_i9++]; _ref17 = _iterator10[_i10++];
} else { } else {
_i9 = _iterator9.next(); _i10 = _iterator10.next();
if (_i9.done) break; if (_i10.done) break;
_ref16 = _i9.value; _ref17 = _i10.value;
} }
const pkgCommand = _ref16; const pkgCommand = _ref17;
const action = scripts.get(pkgCommand); const action = scripts.get(pkgCommand);
invariant(action, 'Action must exists'); invariant(action, 'Action must exists');
@ -76067,6 +76102,11 @@ class TarballFetcher extends (_baseFetcher || _load_baseFetcher()).default {
chown: false, // don't chown. just leave as it is chown: false, // don't chown. just leave as it is
map: header => { map: header => {
header.mtime = now; header.mtime = now;
if (header.linkname) {
const basePath = path.posix.dirname(path.join('/', header.name));
const jailPath = path.posix.join(basePath, header.linkname);
header.linkname = path.posix.relative('/', jailPath);
}
return header; return header;
}, },
fs: patchedFs fs: patchedFs
@ -78400,6 +78440,11 @@ class RequestManager {
rejectNext(err); rejectNext(err);
}; };
const rejectWithoutUrl = function rejectWithoutUrl(err) {
err.message = err.message;
rejectNext(err);
};
const queueForRetry = reason => { const queueForRetry = reason => {
const attempts = params.retryAttempts || 0; const attempts = params.retryAttempts || 0;
if (attempts >= this.maxRetryAttempts - 1) { if (attempts >= this.maxRetryAttempts - 1) {
@ -78455,6 +78500,11 @@ class RequestManager {
} }
} }
if (res.statusCode === 401 && res.caseless && res.caseless.get('server') === 'GitHub.com') {
const message = `${res.body.message}. If using GITHUB_TOKEN in your env, check that it is valid.`;
rejectWithoutUrl(new Error(this.reporter.lang('unauthorizedResponse', res.caseless.get('server'), message)));
}
if (res.statusCode === 401 && res.headers['www-authenticate']) { if (res.statusCode === 401 && res.headers['www-authenticate']) {
const authMethods = res.headers['www-authenticate'].split(/,\s*/).map(s => s.toLowerCase()); const authMethods = res.headers['www-authenticate'].split(/,\s*/).map(s => s.toLowerCase());
@ -96957,12 +97007,14 @@ function _load_asyncToGenerator() {
let run = exports.run = (() => { let run = exports.run = (() => {
var _ref = (0, (_asyncToGenerator2 || _load_asyncToGenerator()).default)(function* (config, reporter, flags, args) { var _ref = (0, (_asyncToGenerator2 || _load_asyncToGenerator()).default)(function* (config, reporter, flags, args) {
if (flags.install) { const installVersion = flags[`2`] ? `berry` : flags.install;
if (installVersion) {
const lockfilePath = path.resolve(config.cwd, 'yarn.lock'); const lockfilePath = path.resolve(config.cwd, 'yarn.lock');
if (!(yield (_fs || _load_fs()).exists(lockfilePath))) { if (!(yield (_fs || _load_fs()).exists(lockfilePath))) {
yield (_fs || _load_fs()).writeFile(lockfilePath, ''); yield (_fs || _load_fs()).writeFile(lockfilePath, '');
} }
yield (_child || _load_child()).spawn((_constants || _load_constants()).NODE_BIN_PATH, [process.argv[1], 'policies', 'set-version', flags.install], { yield (_child || _load_child()).spawn((_constants || _load_constants()).NODE_BIN_PATH, [process.argv[1], 'policies', 'set-version', installVersion], {
stdio: 'inherit', stdio: 'inherit',
cwd: config.cwd cwd: config.cwd
}); });
@ -97257,6 +97309,7 @@ function setFlags(commander) {
commander.option('-y, --yes', 'use default options'); commander.option('-y, --yes', 'use default options');
commander.option('-p, --private', 'use default options and private true'); commander.option('-p, --private', 'use default options and private true');
commander.option('-i, --install <value>', 'install a specific Yarn release'); commander.option('-i, --install <value>', 'install a specific Yarn release');
commander.option('-2', 'generates the project using Yarn 2');
} }
function hasWrapper(commander, args) { function hasWrapper(commander, args) {
@ -98245,6 +98298,7 @@ var _buildSubCommands = (0, (_buildSubCommands2 || _load_buildSubCommands()).def
let bundleUrl; let bundleUrl;
let bundleVersion; let bundleVersion;
let isV2 = false;
if (range === 'nightly' || range === 'nightlies') { if (range === 'nightly' || range === 'nightlies') {
bundleUrl = 'https://nightly.yarnpkg.com/latest.js'; bundleUrl = 'https://nightly.yarnpkg.com/latest.js';
@ -98252,10 +98306,18 @@ var _buildSubCommands = (0, (_buildSubCommands2 || _load_buildSubCommands()).def
} else if (range === 'berry' || range === 'v2' || range === '2') { } else if (range === 'berry' || range === 'v2' || range === '2') {
bundleUrl = 'https://github.com/yarnpkg/berry/raw/master/packages/berry-cli/bin/berry.js'; bundleUrl = 'https://github.com/yarnpkg/berry/raw/master/packages/berry-cli/bin/berry.js';
bundleVersion = 'berry'; bundleVersion = 'berry';
isV2 = true;
} else { } else {
const releases = yield fetchReleases(config, { let releases = [];
includePrereleases: allowRc
}); try {
releases = yield fetchReleases(config, {
includePrereleases: allowRc
});
} catch (e) {
reporter.error(e.message);
return;
}
const release = releases.find(function (release) { const release = releases.find(function (release) {
// $FlowFixMe // $FlowFixMe
@ -98276,18 +98338,29 @@ var _buildSubCommands = (0, (_buildSubCommands2 || _load_buildSubCommands()).def
reporter.log(`Downloading ${chalk.green(bundleUrl)}...`); reporter.log(`Downloading ${chalk.green(bundleUrl)}...`);
const bundle = yield fetchBundle(config, bundleUrl); const bundle = yield fetchBundle(config, bundleUrl);
const rc = (0, (_rc || _load_rc()).getRcConfigForFolder)(config.lockfileFolder);
const yarnPath = path.resolve(config.lockfileFolder, `.yarn/releases/yarn-${bundleVersion}.js`); const yarnPath = path.resolve(config.lockfileFolder, `.yarn/releases/yarn-${bundleVersion}.cjs`);
reporter.log(`Saving it into ${chalk.magenta(yarnPath)}...`); reporter.log(`Saving it into ${chalk.magenta(yarnPath)}...`);
yield (_fs || _load_fs()).mkdirp(path.dirname(yarnPath)); yield (_fs || _load_fs()).mkdirp(path.dirname(yarnPath));
yield (_fs || _load_fs()).writeFile(yarnPath, bundle); yield (_fs || _load_fs()).writeFile(yarnPath, bundle);
yield (_fs || _load_fs()).chmod(yarnPath, 0o755); yield (_fs || _load_fs()).chmod(yarnPath, 0o755);
const rcPath = `${config.lockfileFolder}/.yarnrc`; const targetPath = path.relative(config.lockfileFolder, yarnPath).replace(/\\/g, '/');
reporter.log(`Updating ${chalk.magenta(rcPath)}...`);
rc['yarn-path'] = path.relative(config.lockfileFolder, yarnPath); if (isV2) {
yield (_fs || _load_fs()).writeFilePreservingEol(rcPath, `${(0, (_lockfile || _load_lockfile()).stringify)(rc)}\n`); const rcPath = `${config.lockfileFolder}/.yarnrc.yml`;
reporter.log(`Updating ${chalk.magenta(rcPath)}...`);
yield (_fs || _load_fs()).writeFilePreservingEol(rcPath, `yarnPath: ${JSON.stringify(targetPath)}\n`);
} else {
const rcPath = `${config.lockfileFolder}/.yarnrc`;
reporter.log(`Updating ${chalk.magenta(rcPath)}...`);
const rc = (0, (_rc || _load_rc()).getRcConfigForFolder)(config.lockfileFolder);
rc['yarn-path'] = targetPath;
yield (_fs || _load_fs()).writeFilePreservingEol(rcPath, `${(0, (_lockfile || _load_lockfile()).stringify)(rc)}\n`);
}
reporter.log(`Done!`); reporter.log(`Done!`);
})(); })();
@ -99610,11 +99683,11 @@ let run = exports.run = (() => {
throw new (_errors || _load_errors()).MessageError(reporter.lang('workspaceRootNotFound', config.cwd)); throw new (_errors || _load_errors()).MessageError(reporter.lang('workspaceRootNotFound', config.cwd));
} }
if (flags.originalArgs < 1) { if (args.length < 1) {
throw new (_errors || _load_errors()).MessageError(reporter.lang('workspaceMissingWorkspace')); throw new (_errors || _load_errors()).MessageError(reporter.lang('workspaceMissingWorkspace'));
} }
if (flags.originalArgs < 2) { if (args.length < 2) {
throw new (_errors || _load_errors()).MessageError(reporter.lang('workspaceMissingCommand')); throw new (_errors || _load_errors()).MessageError(reporter.lang('workspaceMissingCommand'));
} }
@ -99623,7 +99696,7 @@ let run = exports.run = (() => {
const workspaces = yield config.resolveWorkspaces(workspaceRootFolder, manifest); const workspaces = yield config.resolveWorkspaces(workspaceRootFolder, manifest);
var _ref2 = flags.originalArgs || []; var _ref2 = args || [];
const workspaceName = _ref2[0], const workspaceName = _ref2[0],
rest = _ref2.slice(1); rest = _ref2.slice(1);
@ -99809,28 +99882,23 @@ let runScript = exports.runScript = (() => {
const workspaces = yield config.resolveWorkspaces(workspaceRootFolder, manifest); const workspaces = yield config.resolveWorkspaces(workspaceRootFolder, manifest);
try { try {
var _ref6 = flags.originalArgs || [];
const _ = _ref6[0],
rest = _ref6.slice(1);
for (var _iterator4 = Object.keys(workspaces), _isArray4 = Array.isArray(_iterator4), _i4 = 0, _iterator4 = _isArray4 ? _iterator4 : _iterator4[Symbol.iterator]();;) { for (var _iterator4 = Object.keys(workspaces), _isArray4 = Array.isArray(_iterator4), _i4 = 0, _iterator4 = _isArray4 ? _iterator4 : _iterator4[Symbol.iterator]();;) {
var _ref7; var _ref6;
if (_isArray4) { if (_isArray4) {
if (_i4 >= _iterator4.length) break; if (_i4 >= _iterator4.length) break;
_ref7 = _iterator4[_i4++]; _ref6 = _iterator4[_i4++];
} else { } else {
_i4 = _iterator4.next(); _i4 = _iterator4.next();
if (_i4.done) break; if (_i4.done) break;
_ref7 = _i4.value; _ref6 = _i4.value;
} }
const workspaceName = _ref7; const workspaceName = _ref6;
const loc = workspaces[workspaceName].loc; const loc = workspaces[workspaceName].loc;
reporter.log(`${os.EOL}> ${workspaceName}`); reporter.log(`${os.EOL}> ${workspaceName}`);
yield (_child || _load_child()).spawn((_constants2 || _load_constants2()).NODE_BIN_PATH, [(_constants2 || _load_constants2()).YARN_BIN_PATH, ...rest], { yield (_child || _load_child()).spawn((_constants2 || _load_constants2()).NODE_BIN_PATH, [(_constants2 || _load_constants2()).YARN_BIN_PATH, 'run', ...args], {
stdio: 'inherit', stdio: 'inherit',
cwd: loc cwd: loc
}); });
@ -100050,7 +100118,11 @@ let main = exports.main = (() => {
commandName = 'install'; commandName = 'install';
isKnownCommand = true; isKnownCommand = true;
} }
if (commandName === 'set' && args[0] === 'version') {
commandName = 'policies';
args.splice(0, 1, 'set-version');
isKnownCommand = true;
}
if (!isKnownCommand) { if (!isKnownCommand) {
// if command is not recognized, then set default to `run` // if command is not recognized, then set default to `run`
args.unshift(commandName); args.unshift(commandName);
@ -100061,15 +100133,20 @@ let main = exports.main = (() => {
let warnAboutRunDashDash = false; let warnAboutRunDashDash = false;
// we are using "yarn <script> -abc", "yarn run <script> -abc", or "yarn node -abc", we want -abc // we are using "yarn <script> -abc", "yarn run <script> -abc", or "yarn node -abc", we want -abc
// to be script options, not yarn options // to be script options, not yarn options
const PROXY_COMMANDS = new Set([`run`, `create`, `node`]);
if (PROXY_COMMANDS.has(commandName)) { // PROXY_COMMANDS is a map of command name to the number of preservedArgs
const PROXY_COMMANDS = {
run: 1, // yarn run {command}
create: 1, // yarn create {project}
node: 0, // yarn node
workspaces: 1, // yarn workspaces {command}
workspace: 2 // yarn workspace {package} {command}
};
if (PROXY_COMMANDS.hasOwnProperty(commandName)) {
if (endArgs.length === 0) { if (endArgs.length === 0) {
let preservedArgs = 0; // $FlowFixMe doesn't like that PROXY_COMMANDS doesn't have keys for all commands.
// the "run" and "create" command take one argument that we want to parse as usual (the let preservedArgs = PROXY_COMMANDS[commandName];
// script/package name), hence the splice(1)
if (command === (_index3 || _load_index3()).default.run || command === (_index3 || _load_index3()).default.create) {
preservedArgs += 1;
}
// If the --into option immediately follows the command (or the script name in the "run/create" // If the --into option immediately follows the command (or the script name in the "run/create"
// case), we parse them as regular options so that we can cd into them // case), we parse them as regular options so that we can cd into them
if (args[preservedArgs] === `--into`) { if (args[preservedArgs] === `--into`) {
@ -100081,7 +100158,6 @@ let main = exports.main = (() => {
} }
} }
(_commander || _load_commander()).default.originalArgs = args;
args = [...preCommandArgs, ...args]; args = [...preCommandArgs, ...args];
command.setFlags((_commander || _load_commander()).default); command.setFlags((_commander || _load_commander()).default);
@ -100115,7 +100191,7 @@ let main = exports.main = (() => {
const config = new (_config || _load_config()).default(reporter); const config = new (_config || _load_config()).default(reporter);
const outputWrapperEnabled = (0, (_conversion || _load_conversion()).boolifyWithDefault)(process.env.YARN_WRAP_OUTPUT, true); const outputWrapperEnabled = (0, (_conversion || _load_conversion()).boolifyWithDefault)(process.env.YARN_WRAP_OUTPUT, true);
const shouldWrapOutput = outputWrapperEnabled && !(_commander || _load_commander()).default.json && command.hasWrapper((_commander || _load_commander()).default, (_commander || _load_commander()).default.args); const shouldWrapOutput = outputWrapperEnabled && !(_commander || _load_commander()).default.json && command.hasWrapper((_commander || _load_commander()).default, (_commander || _load_commander()).default.args) && !(commandName === 'init' && (_commander || _load_commander()).default[`2`]);
if (shouldWrapOutput) { if (shouldWrapOutput) {
reporter.header(commandName, { name: 'yarn', version: (_yarnVersion || _load_yarnVersion()).version }); reporter.header(commandName, { name: 'yarn', version: (_yarnVersion || _load_yarnVersion()).version });
@ -100523,8 +100599,13 @@ let start = (() => {
const opts = { stdio: 'inherit', env: Object.assign({}, process.env, { YARN_IGNORE_PATH: 1 }) }; const opts = { stdio: 'inherit', env: Object.assign({}, process.env, { YARN_IGNORE_PATH: 1 }) };
let exitCode = 0; let exitCode = 0;
process.on(`SIGINT`, function () {
// We don't want SIGINT to kill our process; we want it to kill the
// innermost process, whose end will cause our own to exit.
});
try { try {
if (yarnPath.endsWith(`.js`)) { if (/\.[cm]?js$/.test(yarnPath)) {
exitCode = yield (0, (_child || _load_child()).spawnp)(process.execPath, [yarnPath, ...argv], opts); exitCode = yield (0, (_child || _load_child()).spawnp)(process.execPath, [yarnPath, ...argv], opts);
} else { } else {
exitCode = yield (0, (_child || _load_child()).spawnp)(yarnPath, argv, opts); exitCode = yield (0, (_child || _load_child()).spawnp)(yarnPath, argv, opts);
@ -104614,7 +104695,8 @@ const messages = {
couldntClearPackageFromCache: "Couldn't clear package $0 from cache", couldntClearPackageFromCache: "Couldn't clear package $0 from cache",
clearedPackageFromCache: 'Cleared package $0 from cache', clearedPackageFromCache: 'Cleared package $0 from cache',
packWroteTarball: 'Wrote tarball to $0.', packWroteTarball: 'Wrote tarball to $0.',
invalidBinField: 'Invalid bin field for $0.',
invalidBinEntry: 'Invalid bin entry for $1 (in $0).',
helpExamples: ' Examples:\n$0\n', helpExamples: ' Examples:\n$0\n',
helpCommands: ' Commands:\n$0\n', helpCommands: ' Commands:\n$0\n',
helpCommandsMore: ' Run `$0` for more information on specific commands.', helpCommandsMore: ' Run `$0` for more information on specific commands.',
@ -104913,6 +104995,7 @@ const messages = {
errorExtractingTarball: 'Extracting tar content of $1 failed, the file appears to be corrupt: $0', errorExtractingTarball: 'Extracting tar content of $1 failed, the file appears to be corrupt: $0',
updateInstalling: 'Installing $0...', updateInstalling: 'Installing $0...',
hostedGitResolveError: 'Error connecting to repository. Please, check the url.', hostedGitResolveError: 'Error connecting to repository. Please, check the url.',
unauthorizedResponse: 'Received a 401 from $0. $1',
unknownFetcherFor: 'Unknown fetcher for $0', unknownFetcherFor: 'Unknown fetcher for $0',
@ -106787,6 +106870,8 @@ const semver = __webpack_require__(22);
const path = __webpack_require__(0); const path = __webpack_require__(0);
const url = __webpack_require__(24); const url = __webpack_require__(24);
const VALID_BIN_KEYS = /^(?!\.{0,2}$)[a-z0-9._-]+$/i;
const LICENSE_RENAMES = { const LICENSE_RENAMES = {
'MIT/X11': 'MIT', 'MIT/X11': 'MIT',
X11: 'MIT' X11: 'MIT'
@ -106954,6 +107039,37 @@ exports.default = (() => {
info.bin = { [name]: info.bin }; info.bin = { [name]: info.bin };
} }
// Validate that the bin entries reference only files within their package, and that
// their name is a valid file name
if (typeof info.bin === 'object' && info.bin !== null) {
const bin = info.bin;
for (var _iterator3 = Object.keys(bin), _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {
var _ref4;
if (_isArray3) {
if (_i3 >= _iterator3.length) break;
_ref4 = _iterator3[_i3++];
} else {
_i3 = _iterator3.next();
if (_i3.done) break;
_ref4 = _i3.value;
}
const key = _ref4;
const target = bin[key];
if (!VALID_BIN_KEYS.test(key) || !(0, (_util || _load_util()).isValidBin)(target)) {
delete bin[key];
warn(reporter.lang('invalidBinEntry', info.name, key));
} else {
bin[key] = path.normalize(target);
}
}
} else if (typeof info.bin !== 'undefined') {
delete info.bin;
warn(reporter.lang('invalidBinField', info.name));
}
// bundleDependencies is an alias for bundledDependencies // bundleDependencies is an alias for bundledDependencies
if (info.bundledDependencies) { if (info.bundledDependencies) {
info.bundleDependencies = info.bundledDependencies; info.bundleDependencies = info.bundledDependencies;
@ -106994,19 +107110,19 @@ exports.default = (() => {
const fullBinDir = path.join(moduleLoc, binDir); const fullBinDir = path.join(moduleLoc, binDir);
if (yield (_fs || _load_fs()).exists(fullBinDir)) { if (yield (_fs || _load_fs()).exists(fullBinDir)) {
for (var _iterator3 = yield (_fs || _load_fs()).readdir(fullBinDir), _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) { for (var _iterator4 = yield (_fs || _load_fs()).readdir(fullBinDir), _isArray4 = Array.isArray(_iterator4), _i4 = 0, _iterator4 = _isArray4 ? _iterator4 : _iterator4[Symbol.iterator]();;) {
var _ref4; var _ref5;
if (_isArray3) { if (_isArray4) {
if (_i3 >= _iterator3.length) break; if (_i4 >= _iterator4.length) break;
_ref4 = _iterator3[_i3++]; _ref5 = _iterator4[_i4++];
} else { } else {
_i3 = _iterator3.next(); _i4 = _iterator4.next();
if (_i3.done) break; if (_i4.done) break;
_ref4 = _i3.value; _ref5 = _i4.value;
} }
const scriptName = _ref4; const scriptName = _ref5;
if (scriptName[0] === '.') { if (scriptName[0] === '.') {
continue; continue;
@ -107025,19 +107141,19 @@ exports.default = (() => {
const fullManDir = path.join(moduleLoc, manDir); const fullManDir = path.join(moduleLoc, manDir);
if (yield (_fs || _load_fs()).exists(fullManDir)) { if (yield (_fs || _load_fs()).exists(fullManDir)) {
for (var _iterator4 = yield (_fs || _load_fs()).readdir(fullManDir), _isArray4 = Array.isArray(_iterator4), _i4 = 0, _iterator4 = _isArray4 ? _iterator4 : _iterator4[Symbol.iterator]();;) { for (var _iterator5 = yield (_fs || _load_fs()).readdir(fullManDir), _isArray5 = Array.isArray(_iterator5), _i5 = 0, _iterator5 = _isArray5 ? _iterator5 : _iterator5[Symbol.iterator]();;) {
var _ref5; var _ref6;
if (_isArray4) { if (_isArray5) {
if (_i4 >= _iterator4.length) break; if (_i5 >= _iterator5.length) break;
_ref5 = _iterator4[_i4++]; _ref6 = _iterator5[_i5++];
} else { } else {
_i4 = _iterator4.next(); _i5 = _iterator5.next();
if (_i4.done) break; if (_i5.done) break;
_ref5 = _i4.value; _ref6 = _i5.value;
} }
const filename = _ref5; const filename = _ref6;
if (/^(.*?)\.[0-9]$/.test(filename)) { if (/^(.*?)\.[0-9]$/.test(filename)) {
man.push(path.join('.', manDir, filename)); man.push(path.join('.', manDir, filename));
@ -107056,19 +107172,19 @@ exports.default = (() => {
if (Array.isArray(licenses) && !info.license) { if (Array.isArray(licenses) && !info.license) {
let licenseTypes = []; let licenseTypes = [];
for (var _iterator5 = licenses, _isArray5 = Array.isArray(_iterator5), _i5 = 0, _iterator5 = _isArray5 ? _iterator5 : _iterator5[Symbol.iterator]();;) { for (var _iterator6 = licenses, _isArray6 = Array.isArray(_iterator6), _i6 = 0, _iterator6 = _isArray6 ? _iterator6 : _iterator6[Symbol.iterator]();;) {
var _ref6; var _ref7;
if (_isArray5) { if (_isArray6) {
if (_i5 >= _iterator5.length) break; if (_i6 >= _iterator6.length) break;
_ref6 = _iterator5[_i5++]; _ref7 = _iterator6[_i6++];
} else { } else {
_i5 = _iterator5.next(); _i6 = _iterator6.next();
if (_i5.done) break; if (_i6.done) break;
_ref6 = _i5.value; _ref7 = _i6.value;
} }
let license = _ref6; let license = _ref7;
if (license && typeof license === 'object') { if (license && typeof license === 'object') {
license = license.type; license = license.type;
@ -107153,19 +107269,19 @@ exports.default = (() => {
} }
} }
for (var _iterator6 = (_constants || _load_constants()).MANIFEST_FIELDS, _isArray6 = Array.isArray(_iterator6), _i6 = 0, _iterator6 = _isArray6 ? _iterator6 : _iterator6[Symbol.iterator]();;) { for (var _iterator7 = (_constants || _load_constants()).MANIFEST_FIELDS, _isArray7 = Array.isArray(_iterator7), _i7 = 0, _iterator7 = _isArray7 ? _iterator7 : _iterator7[Symbol.iterator]();;) {
var _ref7; var _ref8;
if (_isArray6) { if (_isArray7) {
if (_i6 >= _iterator6.length) break; if (_i7 >= _iterator7.length) break;
_ref7 = _iterator6[_i6++]; _ref8 = _iterator7[_i7++];
} else { } else {
_i6 = _iterator6.next(); _i7 = _iterator7.next();
if (_i6.done) break; if (_i7.done) break;
_ref7 = _i6.value; _ref8 = _i7.value;
} }
const dependencyType = _ref7; const dependencyType = _ref8;
const dependencyList = info[dependencyType]; const dependencyList = info[dependencyType];
if (dependencyList && typeof dependencyList === 'object') { if (dependencyList && typeof dependencyList === 'object') {
@ -107617,7 +107733,11 @@ function parseRcPaths(paths, parser) {
try { try {
return parser((0, (_fs || _load_fs()).readFileSync)(path).toString(), path); return parser((0, (_fs || _load_fs()).readFileSync)(path).toString(), path);
} catch (error) { } catch (error) {
return {}; if (error.code === 'ENOENT' || error.code === 'EISDIR') {
return {};
} else {
throw error;
}
} }
})); }));
} }