forked from jchomaz/Vulture
Tracking de l'application VApp (IHM du jeu)
This commit is contained in:
76
VApp/node_modules/@rushstack/eslint-patch/lib/eslint-bulk-suppressions/cli/suppress.js
generated
vendored
Normal file
76
VApp/node_modules/@rushstack/eslint-patch/lib/eslint-bulk-suppressions/cli/suppress.js
generated
vendored
Normal file
@@ -0,0 +1,76 @@
|
||||
"use strict";
|
||||
// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.
|
||||
// See LICENSE in the project root for license information.
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.suppress = void 0;
|
||||
const child_process_1 = require("child_process");
|
||||
const get_eslint_cli_1 = require("./utils/get-eslint-cli");
|
||||
const print_help_1 = require("./utils/print-help");
|
||||
function suppress() {
|
||||
const args = process.argv.slice(3);
|
||||
if (args.includes('--help') || args.includes('-h')) {
|
||||
(0, print_help_1.printSuppressHelp)();
|
||||
process.exit(0);
|
||||
}
|
||||
// Use reduce to create an object with all the parsed arguments
|
||||
const parsedArgs = args.reduce((acc, arg, index, arr) => {
|
||||
if (arg === '--rule') {
|
||||
// continue because next arg should be the rule
|
||||
}
|
||||
else if (index > 0 && arr[index - 1] === '--rule' && arr[index + 1]) {
|
||||
acc.rules.push(arg);
|
||||
}
|
||||
else if (arg === '--all') {
|
||||
acc.all = true;
|
||||
}
|
||||
else if (arg.startsWith('--')) {
|
||||
throw new Error(`@rushstack/eslint-bulk: Unknown option: ${arg}`);
|
||||
}
|
||||
else {
|
||||
acc.files.push(arg);
|
||||
}
|
||||
return acc;
|
||||
}, { rules: [], all: false, files: [] });
|
||||
if (parsedArgs.files.length === 0) {
|
||||
throw new Error('@rushstack/eslint-bulk: Files argument is required. Use glob patterns to specify files or use `.` to suppress all files for the specified rules.');
|
||||
}
|
||||
if (parsedArgs.rules.length === 0 && !parsedArgs.all) {
|
||||
throw new Error('@rushstack/eslint-bulk: Please specify at least one rule to suppress. Use --all to suppress all rules.');
|
||||
}
|
||||
const eslintCLI = (0, get_eslint_cli_1.getEslintCli)(process.cwd());
|
||||
// Find the index of the last argument that starts with '--'
|
||||
const lastOptionIndex = args
|
||||
.map((arg, i) => (arg.startsWith('--') ? i : -1))
|
||||
.reduce((lastIndex, currentIndex) => Math.max(lastIndex, currentIndex), -1);
|
||||
// Check if options come before files
|
||||
if (parsedArgs.files.some((file) => args.indexOf(file) < lastOptionIndex)) {
|
||||
throw new Error('@rushstack/eslint-bulk: Unable to parse command line arguments. All options should come before files argument.');
|
||||
}
|
||||
const env = Object.assign({}, process.env);
|
||||
if (parsedArgs.all) {
|
||||
env.ESLINT_BULK_SUPPRESS = '*';
|
||||
}
|
||||
else if (parsedArgs.rules.length > 0) {
|
||||
env.ESLINT_BULK_SUPPRESS = parsedArgs.rules.join(',');
|
||||
}
|
||||
(0, child_process_1.exec)(`${eslintCLI} ${parsedArgs.files.join(' ')} --format=json`, { env }, (error, stdout, stderr) => {
|
||||
// if errorCount != 0, ESLint will process.exit(1) giving the false impression
|
||||
// that the exec failed, even though linting errors are to be expected
|
||||
const eslintOutputWithErrorRegex = /"errorCount":(?!0)\d+/;
|
||||
const isEslintError = error !== null && error.code === 1 && eslintOutputWithErrorRegex.test(stdout);
|
||||
if (error && !isEslintError) {
|
||||
throw new Error(`@rushstack/eslint-bulk execution error: ${error.message}`);
|
||||
}
|
||||
if (stderr) {
|
||||
throw new Error(`@rushstack/eslint-bulk ESLint errors: ${stderr}`);
|
||||
}
|
||||
if (parsedArgs.all) {
|
||||
console.log(`@rushstack/eslint-bulk: Successfully suppressed all rules for file(s) ${parsedArgs.files}`);
|
||||
}
|
||||
else if (parsedArgs.rules.length > 0) {
|
||||
console.log(`@rushstack/eslint-bulk: Successfully suppressed rules ${parsedArgs.rules} for file(s) ${parsedArgs.files}`);
|
||||
}
|
||||
});
|
||||
}
|
||||
exports.suppress = suppress;
|
||||
//# sourceMappingURL=suppress.js.map
|
||||
Reference in New Issue
Block a user