Bump eslint-plugin-import to avoid vulnerability in dependency
This commit is contained in:
parent
10695e6a20
commit
ed9506bbaf
1660 changed files with 67726 additions and 27926 deletions
63
node_modules/eslint-module-utils/parse.js
generated
vendored
63
node_modules/eslint-module-utils/parse.js
generated
vendored
|
|
@ -3,9 +3,53 @@ exports.__esModule = true;
|
|||
|
||||
const moduleRequire = require('./module-require').default;
|
||||
const extname = require('path').extname;
|
||||
const fs = require('fs');
|
||||
|
||||
const log = require('debug')('eslint-plugin-import:parse');
|
||||
|
||||
function getBabelEslintVisitorKeys(parserPath) {
|
||||
if (parserPath.endsWith('index.js')) {
|
||||
const hypotheticalLocation = parserPath.replace('index.js', 'visitor-keys.js');
|
||||
if (fs.existsSync(hypotheticalLocation)) {
|
||||
const keys = moduleRequire(hypotheticalLocation);
|
||||
return keys.default || keys;
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
function keysFromParser(parserPath, parserInstance, parsedResult) {
|
||||
// Exposed by @typescript-eslint/parser and @babel/eslint-parser
|
||||
if (parsedResult && parsedResult.visitorKeys) {
|
||||
return parsedResult.visitorKeys;
|
||||
}
|
||||
if (/.*espree.*/.test(parserPath)) {
|
||||
return parserInstance.VisitorKeys;
|
||||
}
|
||||
if (/.*babel-eslint.*/.test(parserPath)) {
|
||||
return getBabelEslintVisitorKeys(parserPath);
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
// this exists to smooth over the unintentional breaking change in v2.7.
|
||||
// TODO, semver-major: avoid mutating `ast` and return a plain object instead.
|
||||
function makeParseReturn(ast, visitorKeys) {
|
||||
if (ast) {
|
||||
ast.visitorKeys = visitorKeys;
|
||||
ast.ast = ast;
|
||||
}
|
||||
return ast;
|
||||
}
|
||||
|
||||
function stripUnicodeBOM(text) {
|
||||
return text.charCodeAt(0) === 0xFEFF ? text.slice(1) : text;
|
||||
}
|
||||
|
||||
function transformHashbang(text) {
|
||||
return text.replace(/^#!([^\r\n]+)/u, (_, captured) => `//${captured}`);
|
||||
}
|
||||
|
||||
exports.default = function parse(path, content, context) {
|
||||
|
||||
if (context == null) throw new Error('need context to parse properly');
|
||||
|
|
@ -42,23 +86,34 @@ exports.default = function parse(path, content, context) {
|
|||
// require the parser relative to the main module (i.e., ESLint)
|
||||
const parser = moduleRequire(parserPath);
|
||||
|
||||
// replicate bom strip and hashbang transform of ESLint
|
||||
// https://github.com/eslint/eslint/blob/b93af98b3c417225a027cabc964c38e779adb945/lib/linter/linter.js#L779
|
||||
content = transformHashbang(stripUnicodeBOM(String(content)));
|
||||
|
||||
if (typeof parser.parseForESLint === 'function') {
|
||||
let ast;
|
||||
try {
|
||||
ast = parser.parseForESLint(content, parserOptions).ast;
|
||||
const parserRaw = parser.parseForESLint(content, parserOptions);
|
||||
ast = parserRaw.ast;
|
||||
return makeParseReturn(ast, keysFromParser(parserPath, parser, parserRaw));
|
||||
} catch (e) {
|
||||
console.warn();
|
||||
console.warn('Error while parsing ' + parserOptions.filePath);
|
||||
console.warn('Line ' + e.lineNumber + ', column ' + e.column + ': ' + e.message);
|
||||
}
|
||||
if (!ast || typeof ast !== 'object') {
|
||||
console.warn('`parseForESLint` from parser `' + parserPath + '` is invalid and will just be ignored');
|
||||
console.warn(
|
||||
'`parseForESLint` from parser `' +
|
||||
parserPath +
|
||||
'` is invalid and will just be ignored'
|
||||
);
|
||||
} else {
|
||||
return ast;
|
||||
return makeParseReturn(ast, keysFromParser(parserPath, parser, undefined));
|
||||
}
|
||||
}
|
||||
|
||||
return parser.parse(content, parserOptions);
|
||||
const ast = parser.parse(content, parserOptions);
|
||||
return makeParseReturn(ast, keysFromParser(parserPath, parser, undefined));
|
||||
};
|
||||
|
||||
function getParserPath(path, context) {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue