Spaces:
Sleeping
Sleeping
| ; | |
| Object.defineProperty(exports, '__esModule', { value: true }); | |
| var util = require('util'); | |
| var path = require('path'); | |
| var Ajv = require('ajv'); | |
| var globals = require('globals'); | |
| function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } | |
| var util__default = /*#__PURE__*/_interopDefaultLegacy(util); | |
| var path__default = /*#__PURE__*/_interopDefaultLegacy(path); | |
| var Ajv__default = /*#__PURE__*/_interopDefaultLegacy(Ajv); | |
| var globals__default = /*#__PURE__*/_interopDefaultLegacy(globals); | |
| /** | |
| * @fileoverview Config file operations. This file must be usable in the browser, | |
| * so no Node-specific code can be here. | |
| * @author Nicholas C. Zakas | |
| */ | |
| //------------------------------------------------------------------------------ | |
| // Private | |
| //------------------------------------------------------------------------------ | |
| const RULE_SEVERITY_STRINGS = ["off", "warn", "error"], | |
| RULE_SEVERITY = RULE_SEVERITY_STRINGS.reduce((map, value, index) => { | |
| map[value] = index; | |
| return map; | |
| }, {}), | |
| VALID_SEVERITIES = [0, 1, 2, "off", "warn", "error"]; | |
| //------------------------------------------------------------------------------ | |
| // Public Interface | |
| //------------------------------------------------------------------------------ | |
| /** | |
| * Normalizes the severity value of a rule's configuration to a number | |
| * @param {(number|string|[number, ...*]|[string, ...*])} ruleConfig A rule's configuration value, generally | |
| * received from the user. A valid config value is either 0, 1, 2, the string "off" (treated the same as 0), | |
| * the string "warn" (treated the same as 1), the string "error" (treated the same as 2), or an array | |
| * whose first element is one of the above values. Strings are matched case-insensitively. | |
| * @returns {(0|1|2)} The numeric severity value if the config value was valid, otherwise 0. | |
| */ | |
| function getRuleSeverity(ruleConfig) { | |
| const severityValue = Array.isArray(ruleConfig) ? ruleConfig[0] : ruleConfig; | |
| if (severityValue === 0 || severityValue === 1 || severityValue === 2) { | |
| return severityValue; | |
| } | |
| if (typeof severityValue === "string") { | |
| return RULE_SEVERITY[severityValue.toLowerCase()] || 0; | |
| } | |
| return 0; | |
| } | |
| /** | |
| * Converts old-style severity settings (0, 1, 2) into new-style | |
| * severity settings (off, warn, error) for all rules. Assumption is that severity | |
| * values have already been validated as correct. | |
| * @param {Object} config The config object to normalize. | |
| * @returns {void} | |
| */ | |
| function normalizeToStrings(config) { | |
| if (config.rules) { | |
| Object.keys(config.rules).forEach(ruleId => { | |
| const ruleConfig = config.rules[ruleId]; | |
| if (typeof ruleConfig === "number") { | |
| config.rules[ruleId] = RULE_SEVERITY_STRINGS[ruleConfig] || RULE_SEVERITY_STRINGS[0]; | |
| } else if (Array.isArray(ruleConfig) && typeof ruleConfig[0] === "number") { | |
| ruleConfig[0] = RULE_SEVERITY_STRINGS[ruleConfig[0]] || RULE_SEVERITY_STRINGS[0]; | |
| } | |
| }); | |
| } | |
| } | |
| /** | |
| * Determines if the severity for the given rule configuration represents an error. | |
| * @param {int|string|Array} ruleConfig The configuration for an individual rule. | |
| * @returns {boolean} True if the rule represents an error, false if not. | |
| */ | |
| function isErrorSeverity(ruleConfig) { | |
| return getRuleSeverity(ruleConfig) === 2; | |
| } | |
| /** | |
| * Checks whether a given config has valid severity or not. | |
| * @param {number|string|Array} ruleConfig The configuration for an individual rule. | |
| * @returns {boolean} `true` if the configuration has valid severity. | |
| */ | |
| function isValidSeverity(ruleConfig) { | |
| let severity = Array.isArray(ruleConfig) ? ruleConfig[0] : ruleConfig; | |
| if (typeof severity === "string") { | |
| severity = severity.toLowerCase(); | |
| } | |
| return VALID_SEVERITIES.indexOf(severity) !== -1; | |
| } | |
| /** | |
| * Checks whether every rule of a given config has valid severity or not. | |
| * @param {Object} config The configuration for rules. | |
| * @returns {boolean} `true` if the configuration has valid severity. | |
| */ | |
| function isEverySeverityValid(config) { | |
| return Object.keys(config).every(ruleId => isValidSeverity(config[ruleId])); | |
| } | |
| /** | |
| * Normalizes a value for a global in a config | |
| * @param {(boolean|string|null)} configuredValue The value given for a global in configuration or in | |
| * a global directive comment | |
| * @returns {("readable"|"writeable"|"off")} The value normalized as a string | |
| * @throws Error if global value is invalid | |
| */ | |
| function normalizeConfigGlobal(configuredValue) { | |
| switch (configuredValue) { | |
| case "off": | |
| return "off"; | |
| case true: | |
| case "true": | |
| case "writeable": | |
| case "writable": | |
| return "writable"; | |
| case null: | |
| case false: | |
| case "false": | |
| case "readable": | |
| case "readonly": | |
| return "readonly"; | |
| default: | |
| throw new Error(`'${configuredValue}' is not a valid configuration for a global (use 'readonly', 'writable', or 'off')`); | |
| } | |
| } | |
| var ConfigOps = { | |
| __proto__: null, | |
| getRuleSeverity: getRuleSeverity, | |
| normalizeToStrings: normalizeToStrings, | |
| isErrorSeverity: isErrorSeverity, | |
| isValidSeverity: isValidSeverity, | |
| isEverySeverityValid: isEverySeverityValid, | |
| normalizeConfigGlobal: normalizeConfigGlobal | |
| }; | |
| /** | |
| * @fileoverview Provide the function that emits deprecation warnings. | |
| * @author Toru Nagashima <http://github.com/mysticatea> | |
| */ | |
| //------------------------------------------------------------------------------ | |
| // Private | |
| //------------------------------------------------------------------------------ | |
| // Defitions for deprecation warnings. | |
| const deprecationWarningMessages = { | |
| ESLINT_LEGACY_ECMAFEATURES: | |
| "The 'ecmaFeatures' config file property is deprecated and has no effect.", | |
| ESLINT_PERSONAL_CONFIG_LOAD: | |
| "'~/.eslintrc.*' config files have been deprecated. " + | |
| "Please use a config file per project or the '--config' option.", | |
| ESLINT_PERSONAL_CONFIG_SUPPRESS: | |
| "'~/.eslintrc.*' config files have been deprecated. " + | |
| "Please remove it or add 'root:true' to the config files in your " + | |
| "projects in order to avoid loading '~/.eslintrc.*' accidentally." | |
| }; | |
| const sourceFileErrorCache = new Set(); | |
| /** | |
| * Emits a deprecation warning containing a given filepath. A new deprecation warning is emitted | |
| * for each unique file path, but repeated invocations with the same file path have no effect. | |
| * No warnings are emitted if the `--no-deprecation` or `--no-warnings` Node runtime flags are active. | |
| * @param {string} source The name of the configuration source to report the warning for. | |
| * @param {string} errorCode The warning message to show. | |
| * @returns {void} | |
| */ | |
| function emitDeprecationWarning(source, errorCode) { | |
| const cacheKey = JSON.stringify({ source, errorCode }); | |
| if (sourceFileErrorCache.has(cacheKey)) { | |
| return; | |
| } | |
| sourceFileErrorCache.add(cacheKey); | |
| const rel = path__default["default"].relative(process.cwd(), source); | |
| const message = deprecationWarningMessages[errorCode]; | |
| process.emitWarning( | |
| `${message} (found in "${rel}")`, | |
| "DeprecationWarning", | |
| errorCode | |
| ); | |
| } | |
| /** | |
| * @fileoverview The instance of Ajv validator. | |
| * @author Evgeny Poberezkin | |
| */ | |
| //----------------------------------------------------------------------------- | |
| // Helpers | |
| //----------------------------------------------------------------------------- | |
| /* | |
| * Copied from ajv/lib/refs/json-schema-draft-04.json | |
| * The MIT License (MIT) | |
| * Copyright (c) 2015-2017 Evgeny Poberezkin | |
| */ | |
| const metaSchema = { | |
| id: "http://json-schema.org/draft-04/schema#", | |
| $schema: "http://json-schema.org/draft-04/schema#", | |
| description: "Core schema meta-schema", | |
| definitions: { | |
| schemaArray: { | |
| type: "array", | |
| minItems: 1, | |
| items: { $ref: "#" } | |
| }, | |
| positiveInteger: { | |
| type: "integer", | |
| minimum: 0 | |
| }, | |
| positiveIntegerDefault0: { | |
| allOf: [{ $ref: "#/definitions/positiveInteger" }, { default: 0 }] | |
| }, | |
| simpleTypes: { | |
| enum: ["array", "boolean", "integer", "null", "number", "object", "string"] | |
| }, | |
| stringArray: { | |
| type: "array", | |
| items: { type: "string" }, | |
| minItems: 1, | |
| uniqueItems: true | |
| } | |
| }, | |
| type: "object", | |
| properties: { | |
| id: { | |
| type: "string" | |
| }, | |
| $schema: { | |
| type: "string" | |
| }, | |
| title: { | |
| type: "string" | |
| }, | |
| description: { | |
| type: "string" | |
| }, | |
| default: { }, | |
| multipleOf: { | |
| type: "number", | |
| minimum: 0, | |
| exclusiveMinimum: true | |
| }, | |
| maximum: { | |
| type: "number" | |
| }, | |
| exclusiveMaximum: { | |
| type: "boolean", | |
| default: false | |
| }, | |
| minimum: { | |
| type: "number" | |
| }, | |
| exclusiveMinimum: { | |
| type: "boolean", | |
| default: false | |
| }, | |
| maxLength: { $ref: "#/definitions/positiveInteger" }, | |
| minLength: { $ref: "#/definitions/positiveIntegerDefault0" }, | |
| pattern: { | |
| type: "string", | |
| format: "regex" | |
| }, | |
| additionalItems: { | |
| anyOf: [ | |
| { type: "boolean" }, | |
| { $ref: "#" } | |
| ], | |
| default: { } | |
| }, | |
| items: { | |
| anyOf: [ | |
| { $ref: "#" }, | |
| { $ref: "#/definitions/schemaArray" } | |
| ], | |
| default: { } | |
| }, | |
| maxItems: { $ref: "#/definitions/positiveInteger" }, | |
| minItems: { $ref: "#/definitions/positiveIntegerDefault0" }, | |
| uniqueItems: { | |
| type: "boolean", | |
| default: false | |
| }, | |
| maxProperties: { $ref: "#/definitions/positiveInteger" }, | |
| minProperties: { $ref: "#/definitions/positiveIntegerDefault0" }, | |
| required: { $ref: "#/definitions/stringArray" }, | |
| additionalProperties: { | |
| anyOf: [ | |
| { type: "boolean" }, | |
| { $ref: "#" } | |
| ], | |
| default: { } | |
| }, | |
| definitions: { | |
| type: "object", | |
| additionalProperties: { $ref: "#" }, | |
| default: { } | |
| }, | |
| properties: { | |
| type: "object", | |
| additionalProperties: { $ref: "#" }, | |
| default: { } | |
| }, | |
| patternProperties: { | |
| type: "object", | |
| additionalProperties: { $ref: "#" }, | |
| default: { } | |
| }, | |
| dependencies: { | |
| type: "object", | |
| additionalProperties: { | |
| anyOf: [ | |
| { $ref: "#" }, | |
| { $ref: "#/definitions/stringArray" } | |
| ] | |
| } | |
| }, | |
| enum: { | |
| type: "array", | |
| minItems: 1, | |
| uniqueItems: true | |
| }, | |
| type: { | |
| anyOf: [ | |
| { $ref: "#/definitions/simpleTypes" }, | |
| { | |
| type: "array", | |
| items: { $ref: "#/definitions/simpleTypes" }, | |
| minItems: 1, | |
| uniqueItems: true | |
| } | |
| ] | |
| }, | |
| format: { type: "string" }, | |
| allOf: { $ref: "#/definitions/schemaArray" }, | |
| anyOf: { $ref: "#/definitions/schemaArray" }, | |
| oneOf: { $ref: "#/definitions/schemaArray" }, | |
| not: { $ref: "#" } | |
| }, | |
| dependencies: { | |
| exclusiveMaximum: ["maximum"], | |
| exclusiveMinimum: ["minimum"] | |
| }, | |
| default: { } | |
| }; | |
| //------------------------------------------------------------------------------ | |
| // Public Interface | |
| //------------------------------------------------------------------------------ | |
| var ajvOrig = (additionalOptions = {}) => { | |
| const ajv = new Ajv__default["default"]({ | |
| meta: false, | |
| useDefaults: true, | |
| validateSchema: false, | |
| missingRefs: "ignore", | |
| verbose: true, | |
| schemaId: "auto", | |
| ...additionalOptions | |
| }); | |
| ajv.addMetaSchema(metaSchema); | |
| // eslint-disable-next-line no-underscore-dangle | |
| ajv._opts.defaultMeta = metaSchema.id; | |
| return ajv; | |
| }; | |
| /** | |
| * @fileoverview Defines a schema for configs. | |
| * @author Sylvan Mably | |
| */ | |
| const baseConfigProperties = { | |
| $schema: { type: "string" }, | |
| env: { type: "object" }, | |
| extends: { $ref: "#/definitions/stringOrStrings" }, | |
| globals: { type: "object" }, | |
| overrides: { | |
| type: "array", | |
| items: { $ref: "#/definitions/overrideConfig" }, | |
| additionalItems: false | |
| }, | |
| parser: { type: ["string", "null"] }, | |
| parserOptions: { type: "object" }, | |
| plugins: { type: "array" }, | |
| processor: { type: "string" }, | |
| rules: { type: "object" }, | |
| settings: { type: "object" }, | |
| noInlineConfig: { type: "boolean" }, | |
| reportUnusedDisableDirectives: { type: "boolean" }, | |
| ecmaFeatures: { type: "object" } // deprecated; logs a warning when used | |
| }; | |
| const configSchema = { | |
| definitions: { | |
| stringOrStrings: { | |
| oneOf: [ | |
| { type: "string" }, | |
| { | |
| type: "array", | |
| items: { type: "string" }, | |
| additionalItems: false | |
| } | |
| ] | |
| }, | |
| stringOrStringsRequired: { | |
| oneOf: [ | |
| { type: "string" }, | |
| { | |
| type: "array", | |
| items: { type: "string" }, | |
| additionalItems: false, | |
| minItems: 1 | |
| } | |
| ] | |
| }, | |
| // Config at top-level. | |
| objectConfig: { | |
| type: "object", | |
| properties: { | |
| root: { type: "boolean" }, | |
| ignorePatterns: { $ref: "#/definitions/stringOrStrings" }, | |
| ...baseConfigProperties | |
| }, | |
| additionalProperties: false | |
| }, | |
| // Config in `overrides`. | |
| overrideConfig: { | |
| type: "object", | |
| properties: { | |
| excludedFiles: { $ref: "#/definitions/stringOrStrings" }, | |
| files: { $ref: "#/definitions/stringOrStringsRequired" }, | |
| ...baseConfigProperties | |
| }, | |
| required: ["files"], | |
| additionalProperties: false | |
| } | |
| }, | |
| $ref: "#/definitions/objectConfig" | |
| }; | |
| /** | |
| * @fileoverview Defines environment settings and globals. | |
| * @author Elan Shanker | |
| */ | |
| //------------------------------------------------------------------------------ | |
| // Helpers | |
| //------------------------------------------------------------------------------ | |
| /** | |
| * Get the object that has difference. | |
| * @param {Record<string,boolean>} current The newer object. | |
| * @param {Record<string,boolean>} prev The older object. | |
| * @returns {Record<string,boolean>} The difference object. | |
| */ | |
| function getDiff(current, prev) { | |
| const retv = {}; | |
| for (const [key, value] of Object.entries(current)) { | |
| if (!Object.hasOwnProperty.call(prev, key)) { | |
| retv[key] = value; | |
| } | |
| } | |
| return retv; | |
| } | |
| const newGlobals2015 = getDiff(globals__default["default"].es2015, globals__default["default"].es5); // 19 variables such as Promise, Map, ... | |
| const newGlobals2017 = { | |
| Atomics: false, | |
| SharedArrayBuffer: false | |
| }; | |
| const newGlobals2020 = { | |
| BigInt: false, | |
| BigInt64Array: false, | |
| BigUint64Array: false, | |
| globalThis: false | |
| }; | |
| const newGlobals2021 = { | |
| AggregateError: false, | |
| FinalizationRegistry: false, | |
| WeakRef: false | |
| }; | |
| //------------------------------------------------------------------------------ | |
| // Public Interface | |
| //------------------------------------------------------------------------------ | |
| /** @type {Map<string, import("../lib/shared/types").Environment>} */ | |
| var environments = new Map(Object.entries({ | |
| // Language | |
| builtin: { | |
| globals: globals__default["default"].es5 | |
| }, | |
| es6: { | |
| globals: newGlobals2015, | |
| parserOptions: { | |
| ecmaVersion: 6 | |
| } | |
| }, | |
| es2015: { | |
| globals: newGlobals2015, | |
| parserOptions: { | |
| ecmaVersion: 6 | |
| } | |
| }, | |
| es2016: { | |
| globals: newGlobals2015, | |
| parserOptions: { | |
| ecmaVersion: 7 | |
| } | |
| }, | |
| es2017: { | |
| globals: { ...newGlobals2015, ...newGlobals2017 }, | |
| parserOptions: { | |
| ecmaVersion: 8 | |
| } | |
| }, | |
| es2018: { | |
| globals: { ...newGlobals2015, ...newGlobals2017 }, | |
| parserOptions: { | |
| ecmaVersion: 9 | |
| } | |
| }, | |
| es2019: { | |
| globals: { ...newGlobals2015, ...newGlobals2017 }, | |
| parserOptions: { | |
| ecmaVersion: 10 | |
| } | |
| }, | |
| es2020: { | |
| globals: { ...newGlobals2015, ...newGlobals2017, ...newGlobals2020 }, | |
| parserOptions: { | |
| ecmaVersion: 11 | |
| } | |
| }, | |
| es2021: { | |
| globals: { ...newGlobals2015, ...newGlobals2017, ...newGlobals2020, ...newGlobals2021 }, | |
| parserOptions: { | |
| ecmaVersion: 12 | |
| } | |
| }, | |
| es2022: { | |
| globals: { ...newGlobals2015, ...newGlobals2017, ...newGlobals2020, ...newGlobals2021 }, | |
| parserOptions: { | |
| ecmaVersion: 13 | |
| } | |
| }, | |
| es2023: { | |
| globals: { ...newGlobals2015, ...newGlobals2017, ...newGlobals2020, ...newGlobals2021 }, | |
| parserOptions: { | |
| ecmaVersion: 14 | |
| } | |
| }, | |
| es2024: { | |
| globals: { ...newGlobals2015, ...newGlobals2017, ...newGlobals2020, ...newGlobals2021 }, | |
| parserOptions: { | |
| ecmaVersion: 15 | |
| } | |
| }, | |
| // Platforms | |
| browser: { | |
| globals: globals__default["default"].browser | |
| }, | |
| node: { | |
| globals: globals__default["default"].node, | |
| parserOptions: { | |
| ecmaFeatures: { | |
| globalReturn: true | |
| } | |
| } | |
| }, | |
| "shared-node-browser": { | |
| globals: globals__default["default"]["shared-node-browser"] | |
| }, | |
| worker: { | |
| globals: globals__default["default"].worker | |
| }, | |
| serviceworker: { | |
| globals: globals__default["default"].serviceworker | |
| }, | |
| // Frameworks | |
| commonjs: { | |
| globals: globals__default["default"].commonjs, | |
| parserOptions: { | |
| ecmaFeatures: { | |
| globalReturn: true | |
| } | |
| } | |
| }, | |
| amd: { | |
| globals: globals__default["default"].amd | |
| }, | |
| mocha: { | |
| globals: globals__default["default"].mocha | |
| }, | |
| jasmine: { | |
| globals: globals__default["default"].jasmine | |
| }, | |
| jest: { | |
| globals: globals__default["default"].jest | |
| }, | |
| phantomjs: { | |
| globals: globals__default["default"].phantomjs | |
| }, | |
| jquery: { | |
| globals: globals__default["default"].jquery | |
| }, | |
| qunit: { | |
| globals: globals__default["default"].qunit | |
| }, | |
| prototypejs: { | |
| globals: globals__default["default"].prototypejs | |
| }, | |
| shelljs: { | |
| globals: globals__default["default"].shelljs | |
| }, | |
| meteor: { | |
| globals: globals__default["default"].meteor | |
| }, | |
| mongo: { | |
| globals: globals__default["default"].mongo | |
| }, | |
| protractor: { | |
| globals: globals__default["default"].protractor | |
| }, | |
| applescript: { | |
| globals: globals__default["default"].applescript | |
| }, | |
| nashorn: { | |
| globals: globals__default["default"].nashorn | |
| }, | |
| atomtest: { | |
| globals: globals__default["default"].atomtest | |
| }, | |
| embertest: { | |
| globals: globals__default["default"].embertest | |
| }, | |
| webextensions: { | |
| globals: globals__default["default"].webextensions | |
| }, | |
| greasemonkey: { | |
| globals: globals__default["default"].greasemonkey | |
| } | |
| })); | |
| /** | |
| * @fileoverview Validates configs. | |
| * @author Brandon Mills | |
| */ | |
| const ajv = ajvOrig(); | |
| const ruleValidators = new WeakMap(); | |
| const noop = Function.prototype; | |
| //------------------------------------------------------------------------------ | |
| // Private | |
| //------------------------------------------------------------------------------ | |
| let validateSchema; | |
| const severityMap = { | |
| error: 2, | |
| warn: 1, | |
| off: 0 | |
| }; | |
| const validated = new WeakSet(); | |
| //----------------------------------------------------------------------------- | |
| // Exports | |
| //----------------------------------------------------------------------------- | |
| class ConfigValidator { | |
| constructor({ builtInRules = new Map() } = {}) { | |
| this.builtInRules = builtInRules; | |
| } | |
| /** | |
| * Gets a complete options schema for a rule. | |
| * @param {{create: Function, schema: (Array|null)}} rule A new-style rule object | |
| * @returns {Object} JSON Schema for the rule's options. | |
| */ | |
| getRuleOptionsSchema(rule) { | |
| if (!rule) { | |
| return null; | |
| } | |
| const schema = rule.schema || rule.meta && rule.meta.schema; | |
| // Given a tuple of schemas, insert warning level at the beginning | |
| if (Array.isArray(schema)) { | |
| if (schema.length) { | |
| return { | |
| type: "array", | |
| items: schema, | |
| minItems: 0, | |
| maxItems: schema.length | |
| }; | |
| } | |
| return { | |
| type: "array", | |
| minItems: 0, | |
| maxItems: 0 | |
| }; | |
| } | |
| // Given a full schema, leave it alone | |
| return schema || null; | |
| } | |
| /** | |
| * Validates a rule's severity and returns the severity value. Throws an error if the severity is invalid. | |
| * @param {options} options The given options for the rule. | |
| * @returns {number|string} The rule's severity value | |
| */ | |
| validateRuleSeverity(options) { | |
| const severity = Array.isArray(options) ? options[0] : options; | |
| const normSeverity = typeof severity === "string" ? severityMap[severity.toLowerCase()] : severity; | |
| if (normSeverity === 0 || normSeverity === 1 || normSeverity === 2) { | |
| return normSeverity; | |
| } | |
| throw new Error(`\tSeverity should be one of the following: 0 = off, 1 = warn, 2 = error (you passed '${util__default["default"].inspect(severity).replace(/'/gu, "\"").replace(/\n/gu, "")}').\n`); | |
| } | |
| /** | |
| * Validates the non-severity options passed to a rule, based on its schema. | |
| * @param {{create: Function}} rule The rule to validate | |
| * @param {Array} localOptions The options for the rule, excluding severity | |
| * @returns {void} | |
| */ | |
| validateRuleSchema(rule, localOptions) { | |
| if (!ruleValidators.has(rule)) { | |
| const schema = this.getRuleOptionsSchema(rule); | |
| if (schema) { | |
| ruleValidators.set(rule, ajv.compile(schema)); | |
| } | |
| } | |
| const validateRule = ruleValidators.get(rule); | |
| if (validateRule) { | |
| validateRule(localOptions); | |
| if (validateRule.errors) { | |
| throw new Error(validateRule.errors.map( | |
| error => `\tValue ${JSON.stringify(error.data)} ${error.message}.\n` | |
| ).join("")); | |
| } | |
| } | |
| } | |
| /** | |
| * Validates a rule's options against its schema. | |
| * @param {{create: Function}|null} rule The rule that the config is being validated for | |
| * @param {string} ruleId The rule's unique name. | |
| * @param {Array|number} options The given options for the rule. | |
| * @param {string|null} source The name of the configuration source to report in any errors. If null or undefined, | |
| * no source is prepended to the message. | |
| * @returns {void} | |
| */ | |
| validateRuleOptions(rule, ruleId, options, source = null) { | |
| try { | |
| const severity = this.validateRuleSeverity(options); | |
| if (severity !== 0) { | |
| this.validateRuleSchema(rule, Array.isArray(options) ? options.slice(1) : []); | |
| } | |
| } catch (err) { | |
| const enhancedMessage = `Configuration for rule "${ruleId}" is invalid:\n${err.message}`; | |
| if (typeof source === "string") { | |
| throw new Error(`${source}:\n\t${enhancedMessage}`); | |
| } else { | |
| throw new Error(enhancedMessage); | |
| } | |
| } | |
| } | |
| /** | |
| * Validates an environment object | |
| * @param {Object} environment The environment config object to validate. | |
| * @param {string} source The name of the configuration source to report in any errors. | |
| * @param {function(envId:string): Object} [getAdditionalEnv] A map from strings to loaded environments. | |
| * @returns {void} | |
| */ | |
| validateEnvironment( | |
| environment, | |
| source, | |
| getAdditionalEnv = noop | |
| ) { | |
| // not having an environment is ok | |
| if (!environment) { | |
| return; | |
| } | |
| Object.keys(environment).forEach(id => { | |
| const env = getAdditionalEnv(id) || environments.get(id) || null; | |
| if (!env) { | |
| const message = `${source}:\n\tEnvironment key "${id}" is unknown\n`; | |
| throw new Error(message); | |
| } | |
| }); | |
| } | |
| /** | |
| * Validates a rules config object | |
| * @param {Object} rulesConfig The rules config object to validate. | |
| * @param {string} source The name of the configuration source to report in any errors. | |
| * @param {function(ruleId:string): Object} getAdditionalRule A map from strings to loaded rules | |
| * @returns {void} | |
| */ | |
| validateRules( | |
| rulesConfig, | |
| source, | |
| getAdditionalRule = noop | |
| ) { | |
| if (!rulesConfig) { | |
| return; | |
| } | |
| Object.keys(rulesConfig).forEach(id => { | |
| const rule = getAdditionalRule(id) || this.builtInRules.get(id) || null; | |
| this.validateRuleOptions(rule, id, rulesConfig[id], source); | |
| }); | |
| } | |
| /** | |
| * Validates a `globals` section of a config file | |
| * @param {Object} globalsConfig The `globals` section | |
| * @param {string|null} source The name of the configuration source to report in the event of an error. | |
| * @returns {void} | |
| */ | |
| validateGlobals(globalsConfig, source = null) { | |
| if (!globalsConfig) { | |
| return; | |
| } | |
| Object.entries(globalsConfig) | |
| .forEach(([configuredGlobal, configuredValue]) => { | |
| try { | |
| normalizeConfigGlobal(configuredValue); | |
| } catch (err) { | |
| throw new Error(`ESLint configuration of global '${configuredGlobal}' in ${source} is invalid:\n${err.message}`); | |
| } | |
| }); | |
| } | |
| /** | |
| * Validate `processor` configuration. | |
| * @param {string|undefined} processorName The processor name. | |
| * @param {string} source The name of config file. | |
| * @param {function(id:string): Processor} getProcessor The getter of defined processors. | |
| * @returns {void} | |
| */ | |
| validateProcessor(processorName, source, getProcessor) { | |
| if (processorName && !getProcessor(processorName)) { | |
| throw new Error(`ESLint configuration of processor in '${source}' is invalid: '${processorName}' was not found.`); | |
| } | |
| } | |
| /** | |
| * Formats an array of schema validation errors. | |
| * @param {Array} errors An array of error messages to format. | |
| * @returns {string} Formatted error message | |
| */ | |
| formatErrors(errors) { | |
| return errors.map(error => { | |
| if (error.keyword === "additionalProperties") { | |
| const formattedPropertyPath = error.dataPath.length ? `${error.dataPath.slice(1)}.${error.params.additionalProperty}` : error.params.additionalProperty; | |
| return `Unexpected top-level property "${formattedPropertyPath}"`; | |
| } | |
| if (error.keyword === "type") { | |
| const formattedField = error.dataPath.slice(1); | |
| const formattedExpectedType = Array.isArray(error.schema) ? error.schema.join("/") : error.schema; | |
| const formattedValue = JSON.stringify(error.data); | |
| return `Property "${formattedField}" is the wrong type (expected ${formattedExpectedType} but got \`${formattedValue}\`)`; | |
| } | |
| const field = error.dataPath[0] === "." ? error.dataPath.slice(1) : error.dataPath; | |
| return `"${field}" ${error.message}. Value: ${JSON.stringify(error.data)}`; | |
| }).map(message => `\t- ${message}.\n`).join(""); | |
| } | |
| /** | |
| * Validates the top level properties of the config object. | |
| * @param {Object} config The config object to validate. | |
| * @param {string} source The name of the configuration source to report in any errors. | |
| * @returns {void} | |
| */ | |
| validateConfigSchema(config, source = null) { | |
| validateSchema = validateSchema || ajv.compile(configSchema); | |
| if (!validateSchema(config)) { | |
| throw new Error(`ESLint configuration in ${source} is invalid:\n${this.formatErrors(validateSchema.errors)}`); | |
| } | |
| if (Object.hasOwnProperty.call(config, "ecmaFeatures")) { | |
| emitDeprecationWarning(source, "ESLINT_LEGACY_ECMAFEATURES"); | |
| } | |
| } | |
| /** | |
| * Validates an entire config object. | |
| * @param {Object} config The config object to validate. | |
| * @param {string} source The name of the configuration source to report in any errors. | |
| * @param {function(ruleId:string): Object} [getAdditionalRule] A map from strings to loaded rules. | |
| * @param {function(envId:string): Object} [getAdditionalEnv] A map from strings to loaded envs. | |
| * @returns {void} | |
| */ | |
| validate(config, source, getAdditionalRule, getAdditionalEnv) { | |
| this.validateConfigSchema(config, source); | |
| this.validateRules(config.rules, source, getAdditionalRule); | |
| this.validateEnvironment(config.env, source, getAdditionalEnv); | |
| this.validateGlobals(config.globals, source); | |
| for (const override of config.overrides || []) { | |
| this.validateRules(override.rules, source, getAdditionalRule); | |
| this.validateEnvironment(override.env, source, getAdditionalEnv); | |
| this.validateGlobals(config.globals, source); | |
| } | |
| } | |
| /** | |
| * Validate config array object. | |
| * @param {ConfigArray} configArray The config array to validate. | |
| * @returns {void} | |
| */ | |
| validateConfigArray(configArray) { | |
| const getPluginEnv = Map.prototype.get.bind(configArray.pluginEnvironments); | |
| const getPluginProcessor = Map.prototype.get.bind(configArray.pluginProcessors); | |
| const getPluginRule = Map.prototype.get.bind(configArray.pluginRules); | |
| // Validate. | |
| for (const element of configArray) { | |
| if (validated.has(element)) { | |
| continue; | |
| } | |
| validated.add(element); | |
| this.validateEnvironment(element.env, element.name, getPluginEnv); | |
| this.validateGlobals(element.globals, element.name); | |
| this.validateProcessor(element.processor, element.name, getPluginProcessor); | |
| this.validateRules(element.rules, element.name, getPluginRule); | |
| } | |
| } | |
| } | |
| /** | |
| * @fileoverview Common helpers for naming of plugins, formatters and configs | |
| */ | |
| const NAMESPACE_REGEX = /^@.*\//iu; | |
| /** | |
| * Brings package name to correct format based on prefix | |
| * @param {string} name The name of the package. | |
| * @param {string} prefix Can be either "eslint-plugin", "eslint-config" or "eslint-formatter" | |
| * @returns {string} Normalized name of the package | |
| * @private | |
| */ | |
| function normalizePackageName(name, prefix) { | |
| let normalizedName = name; | |
| /** | |
| * On Windows, name can come in with Windows slashes instead of Unix slashes. | |
| * Normalize to Unix first to avoid errors later on. | |
| * https://github.com/eslint/eslint/issues/5644 | |
| */ | |
| if (normalizedName.includes("\\")) { | |
| normalizedName = normalizedName.replace(/\\/gu, "/"); | |
| } | |
| if (normalizedName.charAt(0) === "@") { | |
| /** | |
| * it's a scoped package | |
| * package name is the prefix, or just a username | |
| */ | |
| const scopedPackageShortcutRegex = new RegExp(`^(@[^/]+)(?:/(?:${prefix})?)?$`, "u"), | |
| scopedPackageNameRegex = new RegExp(`^${prefix}(-|$)`, "u"); | |
| if (scopedPackageShortcutRegex.test(normalizedName)) { | |
| normalizedName = normalizedName.replace(scopedPackageShortcutRegex, `$1/${prefix}`); | |
| } else if (!scopedPackageNameRegex.test(normalizedName.split("/")[1])) { | |
| /** | |
| * for scoped packages, insert the prefix after the first / unless | |
| * the path is already @scope/eslint or @scope/eslint-xxx-yyy | |
| */ | |
| normalizedName = normalizedName.replace(/^@([^/]+)\/(.*)$/u, `@$1/${prefix}-$2`); | |
| } | |
| } else if (!normalizedName.startsWith(`${prefix}-`)) { | |
| normalizedName = `${prefix}-${normalizedName}`; | |
| } | |
| return normalizedName; | |
| } | |
| /** | |
| * Removes the prefix from a fullname. | |
| * @param {string} fullname The term which may have the prefix. | |
| * @param {string} prefix The prefix to remove. | |
| * @returns {string} The term without prefix. | |
| */ | |
| function getShorthandName(fullname, prefix) { | |
| if (fullname[0] === "@") { | |
| let matchResult = new RegExp(`^(@[^/]+)/${prefix}$`, "u").exec(fullname); | |
| if (matchResult) { | |
| return matchResult[1]; | |
| } | |
| matchResult = new RegExp(`^(@[^/]+)/${prefix}-(.+)$`, "u").exec(fullname); | |
| if (matchResult) { | |
| return `${matchResult[1]}/${matchResult[2]}`; | |
| } | |
| } else if (fullname.startsWith(`${prefix}-`)) { | |
| return fullname.slice(prefix.length + 1); | |
| } | |
| return fullname; | |
| } | |
| /** | |
| * Gets the scope (namespace) of a term. | |
| * @param {string} term The term which may have the namespace. | |
| * @returns {string} The namespace of the term if it has one. | |
| */ | |
| function getNamespaceFromTerm(term) { | |
| const match = term.match(NAMESPACE_REGEX); | |
| return match ? match[0] : ""; | |
| } | |
| var naming = { | |
| __proto__: null, | |
| normalizePackageName: normalizePackageName, | |
| getShorthandName: getShorthandName, | |
| getNamespaceFromTerm: getNamespaceFromTerm | |
| }; | |
| /** | |
| * @fileoverview Package exports for @eslint/eslintrc | |
| * @author Nicholas C. Zakas | |
| */ | |
| //----------------------------------------------------------------------------- | |
| // Exports | |
| //----------------------------------------------------------------------------- | |
| const Legacy = { | |
| environments, | |
| // shared | |
| ConfigOps, | |
| ConfigValidator, | |
| naming | |
| }; | |
| exports.Legacy = Legacy; | |
| //# sourceMappingURL=eslintrc-universal.cjs.map | |