You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
103 lines
2.5 KiB
103 lines
2.5 KiB
"use strict"; |
|
|
|
Object.defineProperty(exports, "__esModule", { |
|
value: true |
|
}); |
|
exports.getESLintOptions = getESLintOptions; |
|
exports.getOptions = getOptions; |
|
|
|
var _schemaUtils = require("schema-utils"); |
|
|
|
var _options = _interopRequireDefault(require("./options.json")); |
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } |
|
|
|
// @ts-ignore |
|
|
|
/** @typedef {import("eslint").ESLint.Options} ESLintOptions */ |
|
|
|
/** @typedef {import('eslint').ESLint.LintResult} LintResult */ |
|
|
|
/** @typedef {import('eslint').ESLint.LintResultData} LintResultData */ |
|
|
|
/** |
|
* @callback FormatterFunction |
|
* @param {LintResult[]} results |
|
* @param {LintResultData=} data |
|
* @returns {string} |
|
*/ |
|
|
|
/** |
|
* @typedef {Object} OutputReport |
|
* @property {string=} filePath |
|
* @property {string|FormatterFunction=} formatter |
|
*/ |
|
|
|
/** |
|
* @typedef {Object} PluginOptions |
|
* @property {string=} context |
|
* @property {boolean=} emitError |
|
* @property {boolean=} emitWarning |
|
* @property {string=} eslintPath |
|
* @property {string|string[]=} exclude |
|
* @property {string|string[]=} extensions |
|
* @property {boolean=} failOnError |
|
* @property {boolean=} failOnWarning |
|
* @property {string|string[]=} files |
|
* @property {boolean=} fix |
|
* @property {string|FormatterFunction=} formatter |
|
* @property {boolean=} lintDirtyModulesOnly |
|
* @property {boolean=} quiet |
|
* @property {OutputReport=} outputReport |
|
* @property {number|boolean=} threads |
|
*/ |
|
|
|
/** @typedef {PluginOptions & ESLintOptions} Options */ |
|
|
|
/** |
|
* @param {Options} pluginOptions |
|
* @returns {PluginOptions} |
|
*/ |
|
function getOptions(pluginOptions) { |
|
const options = { |
|
extensions: 'js', |
|
emitError: true, |
|
emitWarning: true, |
|
failOnError: true, |
|
...pluginOptions, |
|
...(pluginOptions.quiet ? { |
|
emitError: true, |
|
emitWarning: false |
|
} : {}) |
|
}; // @ts-ignore |
|
|
|
(0, _schemaUtils.validate)(_options.default, options, { |
|
name: 'ESLint Webpack Plugin', |
|
baseDataPath: 'options' |
|
}); |
|
return options; |
|
} |
|
/** |
|
* @param {Options} loaderOptions |
|
* @returns {ESLintOptions} |
|
*/ |
|
|
|
|
|
function getESLintOptions(loaderOptions) { |
|
const eslintOptions = { ...loaderOptions |
|
}; // Keep the fix option because it is common to both the loader and ESLint. |
|
|
|
const { |
|
fix, |
|
extensions, |
|
...eslintOnlyOptions |
|
} = _options.default.properties; // No need to guard the for-in because schema.properties has hardcoded keys. |
|
// eslint-disable-next-line guard-for-in |
|
|
|
for (const option in eslintOnlyOptions) { |
|
// @ts-ignore |
|
delete eslintOptions[option]; |
|
} |
|
|
|
return eslintOptions; |
|
} |