From 3d46e64f39da9e9ef36c60abb5e57186817a638d Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Mon, 1 Nov 2021 00:32:18 +0100 Subject: [PATCH 01/23] refactor: update source to ES modules Update the source code from CommonJS to ES modules style. This consists of changing `require`s to `import from` statements, `module.exports` to `export` statements, and in some cases the structure of imports and exports as well. Notably when the old `require` statement also contained some additional logic, which is not possible with import statements. --- bin/cli.js | 21 +++++++++++---------- package.json | 1 + src/cli/components/linting.js | 10 +++++----- src/cli/components/log.js | 6 +++--- src/cli/components/separator.js | 4 ++-- src/cli/components/spinner.js | 2 +- src/cli/components/summary.js | 6 +++--- src/cli/config.js | 6 +++--- src/cli/gui.js | 14 +++++++------- src/cli/util.js | 6 +++--- src/lib/linting.js | 14 +++++++------- src/lib/logger.js | 19 ++++++++++--------- src/lib/parse.js | 8 ++++---- src/lib/reporter.js | 8 ++++---- src/lib/rule-loader.js | 4 ++-- src/rules/attr.js | 5 +++-- src/rules/custom.js | 5 +++-- src/rules/elm.js | 5 +++-- src/rules/examples/async.js | 5 +++-- src/rules/examples/elms.js | 5 +++-- src/rules/examples/identity.js | 5 +++-- src/rules/examples/throws.js | 5 +++-- src/rules/valid.js | 7 ++++--- src/svglint.js | 11 ++++++----- 24 files changed, 97 insertions(+), 85 deletions(-) diff --git a/bin/cli.js b/bin/cli.js index fe9b182..6094e29 100755 --- a/bin/cli.js +++ b/bin/cli.js @@ -3,16 +3,18 @@ * @fileoverview The CLI that is executed from a terminal. * Acts as an interface to the JS API */ -const path = require("path"); -const GUI = new (require("../src/cli/gui")); -const Logger = require("../src/lib/logger"); -const SVGLint = require("../src/svglint"); +import path from "path"; +import gui from "../src/cli/gui.js"; +import Logger from "../src/lib/logger.js"; +import SVGLint from "../src/svglint.js"; // @ts-ignore -const meta = require("../package.json"); -const { getConfigurationFile } = require("../src/cli/config"); -const meow = require("meow"); -const chalk = require("chalk"); -const glob = require("glob"); +import config from "../src/cli/config.js"; +import meow from "meow"; +import chalk from "chalk"; +import glob from "glob"; + +const GUI = new gui(); +const { getConfigurationFile } = config; const logger = Logger(""); // Pretty logs all errors, then exits @@ -62,7 +64,6 @@ process.on("exit", () => { try { const configFile = await getConfigurationFile(cli.flags.config); if (configFile) { - configObj = require(configFile); } else { logger.debug("No configuration file found") if (cli.flags.config) { diff --git a/package.json b/package.json index 9a83d99..63e974a 100644 --- a/package.json +++ b/package.json @@ -2,6 +2,7 @@ "name": "svglint", "version": "1.0.5", "description": "Linter for SVGs", + "type": "module", "main": "src/svglint.js", "bin": { "svglint": "./bin/cli.js" diff --git a/src/cli/components/linting.js b/src/cli/components/linting.js index 70864c7..05c72f3 100644 --- a/src/cli/components/linting.js +++ b/src/cli/components/linting.js @@ -1,8 +1,8 @@ -const chalk = require("chalk"); -const { chunkString, MSG_META, COLUMNS } = require("../util"); -const stripAnsi = require("strip-ansi"); +import chalk from "chalk"; +import { chunkString, MSG_META, COLUMNS } from "../util.js"; +import stripAnsi from "strip-ansi"; -const Spinner = require("./spinner"); +import Spinner from "./spinner.js"; /** @typedef {import("../../lib/reporter.js")} Reporter */ /** @typedef {import("../../lib/linting.js")} Linting */ @@ -29,7 +29,7 @@ function flattenReporters(results) { /** * A display for a single linting. */ -module.exports = class LintingDisplay { +export default class LintingDisplay { /** @param {Linting} linting */ constructor(linting) { this.linting = linting; diff --git a/src/cli/components/log.js b/src/cli/components/log.js index a760aac..b0112cc 100644 --- a/src/cli/components/log.js +++ b/src/cli/components/log.js @@ -1,5 +1,5 @@ -const nodeUtil = require("util"); -const { MSG_META } = require("../util"); +import nodeUtil from "util"; +import { MSG_META } from "../util.js"; /** @typedef {import("../../lib/logger.js").CliConsole} CliHistory */ @@ -20,7 +20,7 @@ function stringifyArgs(args=[]) { /** * A display for a log history. */ -module.exports = class Log { +export default class Log { /** @param {CliHistory} logHistory */ constructor(logHistory) { this.logs = logHistory; } toString() { diff --git a/src/cli/components/separator.js b/src/cli/components/separator.js index 29396d8..86d0cd8 100644 --- a/src/cli/components/separator.js +++ b/src/cli/components/separator.js @@ -1,11 +1,11 @@ -const chalk = require("chalk"); +import chalk from "chalk"; const columns = process.stdout.columns || 80; /** * A separator between sections. * Optionally includes a title which will be displayed centered in the separator. */ -module.exports = class Separator { +export default class Separator { constructor(title="") { this.title = title; } toString() { const padding = chalk.gray.dim("-".repeat( diff --git a/src/cli/components/spinner.js b/src/cli/components/spinner.js index f3571b6..50a786a 100644 --- a/src/cli/components/spinner.js +++ b/src/cli/components/spinner.js @@ -2,7 +2,7 @@ * A spinner which renders a small animation. * Used to indicate a loading state (e.g. an active linting). */ -module.exports = class Spinner { +export default class Spinner { constructor() { this.i = 0; //this.frames = ["---", "=--", "==-", "===", "-==", "--=", "---"]; diff --git a/src/cli/components/summary.js b/src/cli/components/summary.js index 11cefa8..f76817e 100644 --- a/src/cli/components/summary.js +++ b/src/cli/components/summary.js @@ -1,12 +1,12 @@ -const chalk = require("chalk"); -const { MSG_META } = require("../util"); +import chalk from "chalk"; +import { MSG_META } from "../util.js"; /** @typedef {import("../../lib/linting.js")} Linting */ /** * A summary of all lintings. */ -module.exports = class Summary { +export default class Summary { constructor() { this.lintings = []; } diff --git a/src/cli/config.js b/src/cli/config.js index b144ff3..172b3f8 100644 --- a/src/cli/config.js +++ b/src/cli/config.js @@ -1,5 +1,5 @@ -const path = require("path"); -const fs = require("fs"); +import path from "path"; +import fs from "fs"; /** * Gets the configuration file to use @@ -31,6 +31,6 @@ function getConfigurationFile(filename=".svglintrc.js", folder=process.cwd()) { }); } -module.exports = { +export default { getConfigurationFile, }; diff --git a/src/cli/gui.js b/src/cli/gui.js index 56330a4..0794eb5 100644 --- a/src/cli/gui.js +++ b/src/cli/gui.js @@ -3,18 +3,18 @@ * Handles formatting the state of a (multifile) linting in a human-friendly way. * Expects a terminal to be present as process.stdout. */ -const logUpdate = require("log-update"); -const Logger = require("../lib/logger"); +import logUpdate from "log-update"; +import Logger from "../lib/logger.js"; const logHistory = Logger.cliConsole; -const Separator = require("./components/separator"); -const Log = require("./components/log"); -const LintingDisplay = require("./components/linting"); -const Summary = require("./components/summary"); +import Separator from "./components/separator.js"; +import Log from "./components/log.js"; +import LintingDisplay from "./components/linting.js"; +import Summary from "./components/summary.js"; /** @typedef {import("../lib/linting.js")} Linting */ -module.exports = class GUI { +export default class GUI { constructor() { // subscribe to global logs Logger.setCLI(true); diff --git a/src/cli/util.js b/src/cli/util.js index 5b51902..e47eede 100644 --- a/src/cli/util.js +++ b/src/cli/util.js @@ -1,8 +1,8 @@ /** * @fileoverview Utilities for the CLI. */ -const chalk = require("chalk"); -const ansiRegex = require("ansi-regex"); +import chalk from "chalk"; +import ansiRegex from "ansi-regex"; const COLUMNS = process.stdout.columns || 80; const MSG_META = Object.freeze({ @@ -39,7 +39,7 @@ const MSG_META = Object.freeze({ }), }); -module.exports = { +export { chunkString, MSG_META, COLUMNS, diff --git a/src/lib/linting.js b/src/lib/linting.js index be19db2..479691e 100644 --- a/src/lib/linting.js +++ b/src/lib/linting.js @@ -6,12 +6,12 @@ * It receives the parsed AST and rules from ../svglint.js, and then runs each * rule and gathers the results. */ -const EventEmitter = require("events").EventEmitter; -const path = require("path"); -const cheerio = require("cheerio"); -const parse = require("./parse"); -const Reporter = require("./reporter"); -const Logger = require("./logger"); +import { EventEmitter } from "events"; +import path from "path"; +import cheerio from "cheerio"; +import parse from "./parse.js"; +import Reporter from "./reporter.js"; +import Logger from "./logger.js"; /** @typedef {import("./parse.js").AST} AST */ /** @typedef {import("./parse.js").Node} Node */ @@ -206,4 +206,4 @@ class Linting extends EventEmitter { } Linting.STATES = Linting.prototype.STATES = STATES; -module.exports = Linting; +export default Linting; diff --git a/src/lib/logger.js b/src/lib/logger.js index 10e2fd9..4d65699 100644 --- a/src/lib/logger.js +++ b/src/lib/logger.js @@ -3,9 +3,9 @@ * If called using the JS API, this will be `console` with prefixes. * If called using the CLI, this will be our own custom logger. */ -const chalk = require("chalk"); -const inspect = require("util").inspect; -const EventEmitter = require("events").EventEmitter; +import chalk from "chalk"; +import { inspect } from "util"; +import { EventEmitter } from "events"; const CONSOLE_COLORS = Object.freeze({ debug: chalk.dim.gray, @@ -60,7 +60,7 @@ class CliConsole extends EventEmitter { CliConsole.prototype.EVENTS = METHODS; const cliConsole = new CliConsole(); -module.exports = function(prefix) { +const Logger = function(prefix) { prefix = "SVGLint" + (prefix ? " " + prefix : ""); const logger = {}; METHODS.forEach(method => { @@ -75,8 +75,9 @@ module.exports = function(prefix) { }); return logger; }; -module.exports.cliConsole = cliConsole; -module.exports.setCLI = value => { isCLI = value; }; -module.exports.setLevel = value => { level = value; }; -module.exports.LEVELS = LEVELS; -module.exports.colorize = value => inspect(value, true, 2, true); +Logger.cliConsole = cliConsole; +Logger.setCLI = value => { isCLI = value; }; +Logger.setLevel = value => { level = value; }; +Logger.LEVELS = LEVELS; +Logger.colorize = value => inspect(value, true, 2, true); +export default Logger; \ No newline at end of file diff --git a/src/lib/parse.js b/src/lib/parse.js index 9300722..53e9870 100644 --- a/src/lib/parse.js +++ b/src/lib/parse.js @@ -4,11 +4,11 @@ * It uses htmlparser2 to parse the source, which it gathers from either * a string or a file. */ -const Parser = require("htmlparser2"); -const fs = require("fs"); -const path = require("path"); +import Parser from "htmlparser2"; +import fs from "fs"; +import path from "path"; -module.exports = { +export default { /** * Clones an AST by re-parsing it's source * @param {AST} ast The AST to clone diff --git a/src/lib/reporter.js b/src/lib/reporter.js index 091c749..f514f42 100644 --- a/src/lib/reporter.js +++ b/src/lib/reporter.js @@ -1,9 +1,9 @@ /** * @fileoverview The object that rules use to report errors, warnings and messages. */ -const EventEmitter = require("events").EventEmitter; -const chalk = require("chalk"); -const Logger = require("./logger"); +import { EventEmitter } from "events"; +import chalk from "chalk"; +import Logger from "./logger.js"; /** @typedef {import("./parse.js").AST} AST */ /** @typedef {import("./parse.js").Node} Node */ @@ -102,4 +102,4 @@ class Reporter extends EventEmitter { this.messages.push(result); } } -module.exports = Reporter; +export default Reporter; diff --git a/src/lib/rule-loader.js b/src/lib/rule-loader.js index bfeaa0b..774c17c 100644 --- a/src/lib/rule-loader.js +++ b/src/lib/rule-loader.js @@ -4,7 +4,7 @@ * loading a rule. * Currently NodeJS' import cache is just fine. */ -const path = require("path"); +import path from "path"; /** * @typedef RuleModule @@ -30,4 +30,4 @@ function ruleLoader(ruleName, dir="../rules") { ? "svglint-plugin-" + ruleName : path.join(dir, fileName)); } -module.exports = ruleLoader; +export default ruleLoader; diff --git a/src/rules/attr.js b/src/rules/attr.js index eb212c4..5872f4a 100644 --- a/src/rules/attr.js +++ b/src/rules/attr.js @@ -1,4 +1,5 @@ -const logger = require("../lib/logger")("rule:attr"); +import Logger from "../lib/logger.js"; +const logger = Logger("rule:attr"); /** @typedef {import("../lib/reporter.js")} Reporter */ /** @typedef {import("../lib/parse.js").AST} AST */ @@ -144,7 +145,7 @@ function executeOnElm($elm, config, reporter, ast) { } } -module.exports = { +export default { /** * Generates a linting function from a config * @param {AttrConfig} config diff --git a/src/rules/custom.js b/src/rules/custom.js index 1b48eb4..25ba168 100644 --- a/src/rules/custom.js +++ b/src/rules/custom.js @@ -1,4 +1,5 @@ -const logger = require("../lib/logger")("rule:elm"); +import Logger from "../lib/logger.js"; +const logger = Logger("rule:elm"); /** @typedef {import("../lib/reporter.js")} Reporter */ /** @typedef {import("../lib/parse.js").AST} AST */ @@ -15,7 +16,7 @@ const logger = require("../lib/logger")("rule:elm"); * The function will be executed as if though it was a rule. */ -module.exports = { +export default { /** * Generates a linting function from a config * @param {CustomConfig} config diff --git a/src/rules/elm.js b/src/rules/elm.js index b46d893..ddd5ef3 100644 --- a/src/rules/elm.js +++ b/src/rules/elm.js @@ -1,4 +1,5 @@ -const logger = require("../lib/logger")("rule:elm"); +import Logger from "../lib/logger.js"; +const logger = Logger("rule:elm"); /** @typedef {import("../lib/reporter.js")} Reporter */ /** @typedef {import("../lib/parse.js").AST} AST */ @@ -113,7 +114,7 @@ function executeRule(selector, config, $) { return outp; } -module.exports = { +export default { /** * Generates a linting function from a config * @param {ElmConfig} config diff --git a/src/rules/examples/async.js b/src/rules/examples/async.js index 368074c..0e303b3 100644 --- a/src/rules/examples/async.js +++ b/src/rules/examples/async.js @@ -1,4 +1,5 @@ -const logger = require("../lib/logger")("rule:async"); +import Logger from "../lib/logger.js"; +const logger = Logger("rule:async"); /** * @typedef AsyncConfig @@ -7,7 +8,7 @@ const logger = require("../lib/logger")("rule:async"); * @property {Number} wait The number of seconds to wait */ -module.exports = { +export default { /** * Generates a linting function from a config * @param {AsyncConfig} config diff --git a/src/rules/examples/elms.js b/src/rules/examples/elms.js index 51fd46b..16e070e 100644 --- a/src/rules/examples/elms.js +++ b/src/rules/examples/elms.js @@ -1,4 +1,5 @@ -const logger = require("../lib/logger")("rule:elms"); +import Logger from "../lib/logger.js"; +const logger = Logger("rule:elms"); /** * @typedef ElmsConfig @@ -8,7 +9,7 @@ const logger = require("../lib/logger")("rule:elms"); * The first of all matching elements will be used. */ -module.exports = { +export default { /** * Generates a linting function from a config * @param {ElmsConfig} config diff --git a/src/rules/examples/identity.js b/src/rules/examples/identity.js index 23a9e64..d2b97cd 100644 --- a/src/rules/examples/identity.js +++ b/src/rules/examples/identity.js @@ -1,4 +1,5 @@ -const logger = require("../lib/logger")("rule:identity"); +import Logger from "../lib/logger.js"; +const logger = Logger("rule:identity"); /** * @typedef IdentityConfig @@ -6,7 +7,7 @@ const logger = require("../lib/logger")("rule:identity"); * @property {String} message The message to warn/error with */ -module.exports = { +export default { /** * Generates a linting function from a config * @param {IdentityConfig} config diff --git a/src/rules/examples/throws.js b/src/rules/examples/throws.js index a3888dc..e59b347 100644 --- a/src/rules/examples/throws.js +++ b/src/rules/examples/throws.js @@ -1,11 +1,12 @@ -const logger = require("../lib/logger")("rule:throws"); +import Logger from "../lib/logger.js"; +const logger = Logger("rule:throws"); /** * @typedef ThrowsConfig * @property {String} message The message to throw */ -module.exports = { +export default { /** * Generates a linting function from a config * @param {ThrowsConfig} config diff --git a/src/rules/valid.js b/src/rules/valid.js index 939d091..270b6ac 100644 --- a/src/rules/valid.js +++ b/src/rules/valid.js @@ -1,5 +1,6 @@ -const logger = require("../lib/logger")("rule:valid"); -const xmlParser = require("fast-xml-parser"); +import Logger from "../lib/logger.js"; +import xmlParser from "fast-xml-parser"; +const logger = Logger("rule:valid"); /** @typedef {import("../lib/reporter.js")} Reporter */ /** @typedef {import("../lib/parse.js").AST} AST */ @@ -11,7 +12,7 @@ const xmlParser = require("fast-xml-parser"); * 2. If the SVG is not valid, report an error */ -module.exports = { +export default { /** * Generates a linting function from a config * @param {Boolean} config diff --git a/src/svglint.js b/src/svglint.js index 9475d77..0b01ea0 100644 --- a/src/svglint.js +++ b/src/svglint.js @@ -5,10 +5,11 @@ * Main responsibility is handling the consumer<->Linting communication, * and converting the user-provided config into an object of rules. */ -const Linting = require("./lib/linting"); -const parse = require("./lib/parse"); -const loadRule = require("./lib/rule-loader"); -const logger = require("./lib/logger.js")(""); +import Linting from "./lib/linting.js"; +import parse from "./lib/parse.js"; +import loadRule from "./lib/rule-loader.js"; +import Logger from "./lib/logger.js"; +const logger = Logger(""); /** @typedef {import("./lib/parse.js").AST} AST */ /** @typedef {import("./lib/rule-loader.js").RuleModule} RuleModule */ @@ -123,7 +124,7 @@ ${ast.source}`); return new Linting(file, ast, conf.rules); } -module.exports = { +export default { /** * Lints a single SVG string. * The function returns before the Linting is finished. From 933cf72d08714a50feb3c03e48edb953d3548cbe Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Mon, 1 Nov 2021 00:34:35 +0100 Subject: [PATCH 02/23] chore(deps): update meow from ^3.7.0 to ^10.1.1 Update the meow dependency to ^10.1.1 - which is the latest version - and update how it is used in accordance with breaking changes. --- bin/cli.js | 8 +- package-lock.json | 534 ++++++++++++++++++++++++---------------------- package.json | 2 +- 3 files changed, 287 insertions(+), 257 deletions(-) diff --git a/bin/cli.js b/bin/cli.js index 6094e29..1cbcff5 100755 --- a/bin/cli.js +++ b/bin/cli.js @@ -25,10 +25,7 @@ process.on("uncaughtException", err => { }); // Generates the CLI binding using meow -const cli = meow({ - description: meta.description, - version: meta.version, - help: ` +const cli = meow(` ${chalk.yellow("Usage:")} ${chalk.bold("svglint")} [--config config.js] [--ci] [--debug] ${chalk.bold("file1.svg file2.svg")} @@ -37,7 +34,8 @@ const cli = meow({ ${chalk.bold("--version")} Show the current SVGLint version ${chalk.bold("--config, -c")} Specify the config file. Defaults to '.svglintrc.js' ${chalk.bold("--debug, -d")} Show debug logs - ${chalk.bold("--ci, -C")} Only output to stdout once, when linting is finished`, + ${chalk.bold("--ci, -C")} Only output to stdout once, when linting is finished`, { + importMeta: import.meta, flags: { config: { type: "string", alias: "c", }, debug: { type: "boolean", alias: "d" }, diff --git a/package-lock.json b/package-lock.json index 316863d..5f116ab 100644 --- a/package-lock.json +++ b/package-lock.json @@ -8,7 +8,6 @@ "version": "7.0.0", "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.0.0.tgz", "integrity": "sha512-OfC2uemaknXr87bdLUkWog7nYuliM9Ij5HUcajsVcMCpQrcLmtxRbVFTIqmcSkSeYRBFBRxs2FiUqFJDLdiebA==", - "dev": true, "requires": { "@babel/highlight": "^7.0.0" } @@ -17,7 +16,6 @@ "version": "7.0.0", "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.0.0.tgz", "integrity": "sha512-UFMC4ZeFC48Tpvj7C8UgLvtkaUuovQX+5xNWrsIoMG8o2z+XFKjKaN9iVmS84dPwVN00W4wPmqvYoZF3EGAsfw==", - "dev": true, "requires": { "chalk": "^2.0.0", "esutils": "^2.0.2", @@ -147,6 +145,16 @@ "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", "dev": true }, + "@types/minimist": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/@types/minimist/-/minimist-1.2.2.tgz", + "integrity": "sha512-jhuKLIRrhvCPLqwPcx6INqmKeiA5EWrsCOPhrlFSrbrmU4ZMPjj5Ul/oLCMDO98XRUIwVm78xICz4EPCektzeQ==" + }, + "@types/normalize-package-data": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/@types/normalize-package-data/-/normalize-package-data-2.4.1.tgz", + "integrity": "sha512-Gj7cI7z+98M282Tqmp2K5EIsoouUEzbBJhQQzDE3jSIRk6r9gsz0oUokqIUR4u1R3dMHo0pDHM7sNOHyhulypw==" + }, "@types/parse-json": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz", @@ -221,11 +229,6 @@ "sprintf-js": "~1.0.2" } }, - "array-find-index": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/array-find-index/-/array-find-index-1.0.2.tgz", - "integrity": "sha1-3wEKoSh+Fku9pvlyOwqWoexBh6E=" - }, "array.prototype.map": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/array.prototype.map/-/array.prototype.map-1.0.2.tgz", @@ -330,6 +333,11 @@ } } }, + "arrify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", + "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=" + }, "astral-regex": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", @@ -376,11 +384,6 @@ "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", "dev": true }, - "builtin-modules": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", - "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=" - }, "cachedir": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/cachedir/-/cachedir-2.2.0.tgz", @@ -394,17 +397,19 @@ "dev": true }, "camelcase": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-2.1.1.tgz", - "integrity": "sha1-fB0W1nmhu+WcoCys7PsBHiAfWh8=" + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.0.tgz", + "integrity": "sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg==" }, "camelcase-keys": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-2.1.0.tgz", - "integrity": "sha1-MIvur/3ygRkFHvodkyITyRuPkuc=", + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-7.0.1.tgz", + "integrity": "sha512-P331lEls98pW8JLyodNWfzuz91BEDVA4VpW2/SwXnyv2K495tq1N777xzDbFgnEigfA7UIY0xa6PwR/H9jijjA==", "requires": { - "camelcase": "^2.0.0", - "map-obj": "^1.0.0" + "camelcase": "^6.2.0", + "map-obj": "^4.1.0", + "quick-lru": "^5.1.1", + "type-fest": "^1.2.1" } }, "chalk": { @@ -760,9 +765,9 @@ "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" }, "cosmiconfig": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.0.0.tgz", - "integrity": "sha512-pondGvTuVYDk++upghXJabWzL6Kxu6f26ljFw64Swq9v6sQPUL3EUlVDV56diOjpCayKihL6hVe8exIACU4XcA==", + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.0.1.tgz", + "integrity": "sha512-a1YWNUV2HwGimB7dU2s1wUMurNKjpx60HxBB6xUM8Re+2s1g1IIfJvFR0/iCF+XHdE0GMTKTuLR32UQff4TEyQ==", "dev": true, "optional": true, "requires": { @@ -774,35 +779,15 @@ }, "dependencies": { "import-fresh": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", - "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", "dev": true, "optional": true, "requires": { "parent-module": "^1.0.0", "resolve-from": "^4.0.0" } - }, - "parse-json": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.1.0.tgz", - "integrity": "sha512-+mi/lmVVNKFNVyLXV31ERiy2CY5E1/F6QtJFEzoChPRwwngMNXRDQ9GJ5WdE2Z2P4AujsOi0/+2qHID68KwfIQ==", - "dev": true, - "optional": true, - "requires": { - "@babel/code-frame": "^7.0.0", - "error-ex": "^1.3.1", - "json-parse-even-better-errors": "^2.3.0", - "lines-and-columns": "^1.1.6" - } - }, - "path-type": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", - "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", - "dev": true, - "optional": true } } }, @@ -884,14 +869,6 @@ "resolved": "https://registry.npmjs.org/css-what/-/css-what-5.0.1.tgz", "integrity": "sha512-FYDTSHb/7KXsWICVsxdmiExPjCfRC4qRFBdVwv7Ax9hMnvMmEjP9RfxTEZ3qPZGmADDn2vAKSo9UcN1jKVYscg==" }, - "currently-unhandled": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/currently-unhandled/-/currently-unhandled-0.4.1.tgz", - "integrity": "sha1-mI3zP+qxke95mmE2nddsF635V+o=", - "requires": { - "array-find-index": "^1.0.1" - } - }, "cz-conventional-changelog": { "version": "3.3.0", "resolved": "https://registry.npmjs.org/cz-conventional-changelog/-/cz-conventional-changelog-3.3.0.tgz", @@ -929,6 +906,22 @@ "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" }, + "decamelize-keys": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/decamelize-keys/-/decamelize-keys-1.1.0.tgz", + "integrity": "sha1-0XGoeTMlKAfrPLYdwcFEXQeN8tk=", + "requires": { + "decamelize": "^1.1.0", + "map-obj": "^1.0.0" + }, + "dependencies": { + "map-obj": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-1.0.1.tgz", + "integrity": "sha1-2TPOuSBdgr3PSIb2dCvcK03qFG0=" + } + } + }, "dedent": { "version": "0.7.0", "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", @@ -1028,9 +1021,9 @@ "integrity": "sha1-blwtClYhtdra7O+AuQ7ftc13cvA=" }, "error-ex": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.1.tgz", - "integrity": "sha1-+FWobOYa3E6GIcPNoh56dhLDqNw=", + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", "requires": { "is-arrayish": "^0.2.1" } @@ -1316,8 +1309,7 @@ "esutils": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", - "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", - "dev": true + "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=" }, "expand-tilde": { "version": "2.0.2", @@ -1424,12 +1416,12 @@ "dev": true }, "find-up": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", - "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", + "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", "requires": { - "path-exists": "^2.0.0", - "pinkie-promise": "^2.0.0" + "locate-path": "^6.0.0", + "path-exists": "^4.0.0" } }, "findup-sync": { @@ -1533,11 +1525,6 @@ "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", "dev": true }, - "get-stdin": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-4.0.1.tgz", - "integrity": "sha1-uWjGsKBDhDJJAui/Gl3zJXmkUP4=" - }, "glob": { "version": "7.1.2", "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", @@ -1603,7 +1590,9 @@ "graceful-fs": { "version": "4.1.11", "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", - "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=" + "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", + "dev": true, + "optional": true }, "growl": { "version": "1.10.5", @@ -1611,6 +1600,11 @@ "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", "dev": true }, + "hard-rejection": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/hard-rejection/-/hard-rejection-2.1.0.tgz", + "integrity": "sha512-VIZB+ibDhx7ObhAe7OVtoEbuP4h/MuOTHJ+J8h/eBXotJYl0fBgR72xDFCKgIh22OJZIOVNxBMWuhAr10r8HdA==" + }, "has": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/has/-/has-1.0.1.tgz", @@ -1647,9 +1641,12 @@ } }, "hosted-git-info": { - "version": "2.8.9", - "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.9.tgz", - "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==" + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-4.0.2.tgz", + "integrity": "sha512-c9OGXbZ3guC/xOlCg1Ci/VgWlwsqDv1yMQL1CWqXDL0hDjXuNcq0zuR4xqPSuasI3kqFDhqSyTjREz5gzq0fXg==", + "requires": { + "lru-cache": "^6.0.0" + } }, "htmlparser2": { "version": "3.9.2", @@ -1696,12 +1693,9 @@ "dev": true }, "indent-string": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-2.1.0.tgz", - "integrity": "sha1-ji1INIdCEhtKghi3oTfppSBJ3IA=", - "requires": { - "repeating": "^2.0.0" - } + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-5.0.0.tgz", + "integrity": "sha512-m6FAo/spmsW2Ab2fU35JTYwtOKa2yAwXSwgjSv1TJzh4Mh7mC3lzAOVLBprb72XsTrgkEIsl7YrFNAiDiRhIGg==" }, "inflight": { "version": "1.0.6", @@ -1813,20 +1807,35 @@ "integrity": "sha1-mPiygDBoQhmpXzdc+9iM40Bd/5M=", "dev": true }, - "is-builtin-module": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz", - "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=", - "requires": { - "builtin-modules": "^1.0.0" - } - }, "is-callable": { "version": "1.1.3", "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.3.tgz", "integrity": "sha1-hut1OSgF3cM69xySoO7fdO52BLI=", "dev": true }, + "is-core-module": { + "version": "2.8.0", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.0.tgz", + "integrity": "sha512-vd15qHsaqrRL7dtH6QNuy0ndJmRDrS9HAM1CAiSifNUFv4x1a0CCVsj18hJ1mShxIG6T2i1sO78MkP56r0nYRw==", + "requires": { + "has": "^1.0.3" + }, + "dependencies": { + "function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" + }, + "has": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", + "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", + "requires": { + "function-bind": "^1.1.1" + } + } + } + }, "is-date-object": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", @@ -1858,14 +1867,6 @@ "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", "dev": true }, - "is-finite": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/is-finite/-/is-finite-1.0.2.tgz", - "integrity": "sha1-zGZ3aVYCvlUO8R6LSqYwU0K20Ko=", - "requires": { - "number-is-nan": "^1.0.0" - } - }, "is-fullwidth-code-point": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", @@ -1907,8 +1908,7 @@ "is-plain-obj": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz", - "integrity": "sha1-caUMhCnfync8kqOQpKA7OfzVHT4=", - "dev": true + "integrity": "sha1-caUMhCnfync8kqOQpKA7OfzVHT4=" }, "is-promise": { "version": "2.1.0", @@ -1946,7 +1946,8 @@ "is-utf8": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz", - "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI=" + "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI=", + "dev": true }, "is-windows": { "version": "1.0.2", @@ -1984,8 +1985,7 @@ "js-tokens": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", - "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", - "dev": true + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" }, "js-yaml": { "version": "3.13.1", @@ -2000,9 +2000,7 @@ "json-parse-even-better-errors": { "version": "2.3.1", "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", - "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", - "dev": true, - "optional": true + "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==" }, "json-schema-traverse": { "version": "0.4.1", @@ -2025,6 +2023,11 @@ "graceful-fs": "^4.1.6" } }, + "kind-of": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", + "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==" + }, "levn": { "version": "0.3.0", "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", @@ -2038,20 +2041,14 @@ "lines-and-columns": { "version": "1.1.6", "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.1.6.tgz", - "integrity": "sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA=", - "dev": true, - "optional": true + "integrity": "sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA=" }, - "load-json-file": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-1.1.0.tgz", - "integrity": "sha1-lWkFcI1YtLq0wiYbBPWfMcmTdMA=", + "locate-path": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", + "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", "requires": { - "graceful-fs": "^4.1.2", - "parse-json": "^2.2.0", - "pify": "^2.0.0", - "pinkie-promise": "^2.0.0", - "strip-bom": "^2.0.0" + "p-locate": "^5.0.0" } }, "lodash": { @@ -2143,35 +2140,43 @@ "integrity": "sha1-eB4YMpaqlPbU2RbcM10NF676I/g=", "dev": true }, - "loud-rejection": { - "version": "1.6.0", - "resolved": "https://registry.npmjs.org/loud-rejection/-/loud-rejection-1.6.0.tgz", - "integrity": "sha1-W0b4AUft7leIcPCG0Eghz5mOVR8=", + "lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", "requires": { - "currently-unhandled": "^0.4.1", - "signal-exit": "^3.0.0" + "yallist": "^4.0.0" } }, "map-obj": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-1.0.1.tgz", - "integrity": "sha1-2TPOuSBdgr3PSIb2dCvcK03qFG0=" + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-4.3.0.tgz", + "integrity": "sha512-hdN1wVrZbb29eBGiGjJbeP8JbKjq1urkHJ/LIP/NY48MZ1QVXUsQBV1G1zvYFHn1XE06cwjBsOI2K3Ulnj1YXQ==" }, "meow": { - "version": "3.7.0", - "resolved": "https://registry.npmjs.org/meow/-/meow-3.7.0.tgz", - "integrity": "sha1-cstmi0JSKCkKu/qFaJJYcwioAfs=", - "requires": { - "camelcase-keys": "^2.0.0", - "decamelize": "^1.1.2", - "loud-rejection": "^1.0.0", - "map-obj": "^1.0.1", - "minimist": "^1.1.3", - "normalize-package-data": "^2.3.4", - "object-assign": "^4.0.1", - "read-pkg-up": "^1.0.1", - "redent": "^1.0.0", - "trim-newlines": "^1.0.0" + "version": "10.1.1", + "resolved": "https://registry.npmjs.org/meow/-/meow-10.1.1.tgz", + "integrity": "sha512-uzOAEBTGujHAD6bVzIQQk5kDTgatxmpVmr1pj9QhwsHLEG2AiB+9F08/wmjrZIk4h5pWxERd7+jqGZywYx3ZFw==", + "requires": { + "@types/minimist": "^1.2.2", + "camelcase-keys": "^7.0.0", + "decamelize": "^5.0.0", + "decamelize-keys": "^1.1.0", + "hard-rejection": "^2.1.0", + "minimist-options": "4.1.0", + "normalize-package-data": "^3.0.2", + "read-pkg-up": "^8.0.0", + "redent": "^4.0.0", + "trim-newlines": "^4.0.2", + "type-fest": "^1.2.2", + "yargs-parser": "^20.2.9" + }, + "dependencies": { + "decamelize": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-5.0.1.tgz", + "integrity": "sha512-VfxadyCECXgQlkoEAjeghAr5gY3Hf+IKjKb+X8tGVDtveCjN+USwprd2q3QXBR9T1+x2DG0XZF5/w+7HAtSaXA==" + } } }, "merge": { @@ -2203,6 +2208,11 @@ "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==" }, + "min-indent": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/min-indent/-/min-indent-1.0.1.tgz", + "integrity": "sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==" + }, "minimatch": { "version": "3.0.4", "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", @@ -2214,7 +2224,18 @@ "minimist": { "version": "1.2.5", "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", - "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" + "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", + "dev": true + }, + "minimist-options": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/minimist-options/-/minimist-options-4.1.0.tgz", + "integrity": "sha512-Q4r8ghd80yhO/0j1O3B2BjweX3fiHg9cdOwjJd2J76Q135c+NDxGCqdYKQ1SKBuFfgWbAUzBfvYjPUEeNgqN1A==", + "requires": { + "arrify": "^1.0.1", + "is-plain-obj": "^1.1.0", + "kind-of": "^6.0.3" + } }, "mkdirp": { "version": "0.5.5", @@ -2534,13 +2555,13 @@ } }, "normalize-package-data": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz", - "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==", + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-3.0.3.tgz", + "integrity": "sha512-p2W1sgqij3zMMyRC067Dg16bfzVH+w7hyegmpIvZ4JNjqtGOVAIvLmjBx3yP7YTe9vKJgkoNOPjwQGogDoMXFA==", "requires": { - "hosted-git-info": "^2.1.4", - "is-builtin-module": "^1.0.0", - "semver": "2 || 3 || 4 || 5", + "hosted-git-info": "^4.0.1", + "is-core-module": "^2.5.0", + "semver": "^7.3.4", "validate-npm-package-license": "^3.0.1" } }, @@ -2558,16 +2579,6 @@ "boolbase": "^1.0.0" } }, - "number-is-nan": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", - "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" - }, - "object-assign": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", - "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" - }, "object-inspect": { "version": "1.3.0", "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.3.0.tgz", @@ -2657,6 +2668,24 @@ "p-try": "^2.0.0" } }, + "p-locate": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", + "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "requires": { + "p-limit": "^3.0.2" + }, + "dependencies": { + "p-limit": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", + "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "requires": { + "yocto-queue": "^0.1.0" + } + } + } + }, "p-try": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", @@ -2673,11 +2702,14 @@ } }, "parse-json": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", - "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", + "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", "requires": { - "error-ex": "^1.2.0" + "@babel/code-frame": "^7.0.0", + "error-ex": "^1.3.1", + "json-parse-even-better-errors": "^2.3.0", + "lines-and-columns": "^1.1.6" } }, "parse-passwd": { @@ -2700,12 +2732,9 @@ } }, "path-exists": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", - "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", - "requires": { - "pinkie-promise": "^2.0.0" - } + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==" }, "path-is-absolute": { "version": "1.0.1", @@ -2725,14 +2754,11 @@ "dev": true }, "path-type": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/path-type/-/path-type-1.1.0.tgz", - "integrity": "sha1-WcRPfuSR2nBNpBXaWkBwuk+P5EE=", - "requires": { - "graceful-fs": "^4.1.2", - "pify": "^2.0.0", - "pinkie-promise": "^2.0.0" - } + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", + "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", + "dev": true, + "optional": true }, "picomatch": { "version": "2.2.2", @@ -2740,24 +2766,6 @@ "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", "dev": true }, - "pify": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", - "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=" - }, - "pinkie": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", - "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=" - }, - "pinkie-promise": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", - "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", - "requires": { - "pinkie": "^2.0.0" - } - }, "prelude-ls": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", @@ -2886,6 +2894,11 @@ "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", "dev": true }, + "quick-lru": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/quick-lru/-/quick-lru-5.1.1.tgz", + "integrity": "sha512-WuyALRjWPDGtt/wzJiadO5AXY+8hZ80hVpe6MyivgraREW751X3SbhRvG3eLKOYN+8VEvqLcf3wdnt44Z4S4SA==" + }, "randombytes": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", @@ -2896,22 +2909,24 @@ } }, "read-pkg": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-1.1.0.tgz", - "integrity": "sha1-9f+qXs0pyzHAR0vKfXVra7KePyg=", + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-6.0.0.tgz", + "integrity": "sha512-X1Fu3dPuk/8ZLsMhEj5f4wFAF0DWoK7qhGJvgaijocXxBmSToKfbFtqbxMO7bVjNA1dmE5huAzjXj/ey86iw9Q==", "requires": { - "load-json-file": "^1.0.0", - "normalize-package-data": "^2.3.2", - "path-type": "^1.0.0" + "@types/normalize-package-data": "^2.4.0", + "normalize-package-data": "^3.0.2", + "parse-json": "^5.2.0", + "type-fest": "^1.0.1" } }, "read-pkg-up": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-1.0.1.tgz", - "integrity": "sha1-nWPBMnbAZZGNV/ACpX9AobZD+wI=", + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-8.0.0.tgz", + "integrity": "sha512-snVCqPczksT0HS2EC+SxUndvSzn6LRCwpfSvLrIfR5BKDQQZMaI6jPRC9dYvYFDRAuFEAnkwww8kBBNE/3VvzQ==", "requires": { - "find-up": "^1.0.0", - "read-pkg": "^1.0.0" + "find-up": "^5.0.0", + "read-pkg": "^6.0.0", + "type-fest": "^1.0.1" } }, "readable-stream": { @@ -2938,12 +2953,12 @@ } }, "redent": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/redent/-/redent-1.0.0.tgz", - "integrity": "sha1-z5Fqsf1fHxbfsggi3W7H9zDCr94=", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/redent/-/redent-4.0.0.tgz", + "integrity": "sha512-tYkDkVVtYkSVhuQ4zBgfvciymHaeuel+zFKXShfDnFP5SyVEP7qo70Rf1jTOTCx3vGNAbnEi/xFkcfQVMIBWag==", "requires": { - "indent-string": "^2.1.0", - "strip-indent": "^1.0.1" + "indent-string": "^5.0.0", + "strip-indent": "^4.0.0" } }, "regexpp": { @@ -2952,14 +2967,6 @@ "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", "dev": true }, - "repeating": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/repeating/-/repeating-2.0.1.tgz", - "integrity": "sha1-UhTFOpJtNVJwdSf7q0FdvAjQbdo=", - "requires": { - "is-finite": "^1.0.0" - } - }, "require-directory": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", @@ -3062,9 +3069,12 @@ "dev": true }, "semver": { - "version": "5.4.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.4.1.tgz", - "integrity": "sha512-WfG/X9+oATh81XtllIo/I8gOiY9EXRdv1cQdyykeXK17YcUW3EXUAi2To4pcH6nZtJPr7ZOpM5OMyWJZm+8Rsg==" + "version": "7.3.5", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", + "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", + "requires": { + "lru-cache": "^6.0.0" + } }, "serialize-javascript": { "version": "4.0.0", @@ -3113,22 +3123,32 @@ } }, "spdx-correct": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-1.0.2.tgz", - "integrity": "sha1-SzBz2TP/UfORLwOsVRlJikFQ20A=", + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", + "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", "requires": { - "spdx-license-ids": "^1.0.2" + "spdx-expression-parse": "^3.0.0", + "spdx-license-ids": "^3.0.0" } }, + "spdx-exceptions": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", + "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==" + }, "spdx-expression-parse": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-1.0.4.tgz", - "integrity": "sha1-m98vIOH0DtRH++JzJmGR/O1RYmw=" + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", + "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", + "requires": { + "spdx-exceptions": "^2.1.0", + "spdx-license-ids": "^3.0.0" + } }, "spdx-license-ids": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-1.2.2.tgz", - "integrity": "sha1-yd96NCRZSt5r0RkA1ZZpbcBrrFc=" + "version": "3.0.10", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.10.tgz", + "integrity": "sha512-oie3/+gKf7QtpitB0LYLETe+k8SifzsX4KixvpOsbI6S0kRiRQ5MKOio8eMSAKQ17N06+wdEOXRiId+zOxo0hA==" }, "sprintf-js": { "version": "1.0.3", @@ -3372,20 +3392,12 @@ } } }, - "strip-bom": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-2.0.0.tgz", - "integrity": "sha1-YhmoVhZSBJHzV4i9vxRHqZx+aw4=", - "requires": { - "is-utf8": "^0.2.0" - } - }, "strip-indent": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-1.0.1.tgz", - "integrity": "sha1-DHlipq3vp7vUrDZkYKY4VSrhoKI=", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-4.0.0.tgz", + "integrity": "sha512-mnVSV2l+Zv6BLpSD/8V87CW/y9EmmbYzGCIavsnsI6/nwn26DwffM/yztm30Z/I2DY9wdS3vXVCMnHDgZaVNoA==", "requires": { - "get-stdin": "^4.0.1" + "min-indent": "^1.0.1" } }, "strip-json-comments": { @@ -3479,9 +3491,9 @@ } }, "trim-newlines": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-1.0.0.tgz", - "integrity": "sha1-WIeWa7WCpFA6QetST301ARgVphM=" + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-4.0.2.tgz", + "integrity": "sha512-GJtWyq9InR/2HRiLZgpIKv+ufIKrVrvjQWEj7PxAXNc5dwbNJkqhAUoAGgzRmULAnoOM5EIpveYd3J2VeSAIew==" }, "tslib": { "version": "1.9.3", @@ -3498,6 +3510,11 @@ "prelude-ls": "~1.1.2" } }, + "type-fest": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-1.4.0.tgz", + "integrity": "sha512-yGSza74xk0UG8k+pLh5oeoYirvIiWo5t0/o3zHHAO2tRDiZcxWP7fywNlXhqb6/r6sWvwi+RsyQMWhVLe4BVuA==" + }, "universalify": { "version": "0.1.2", "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", @@ -3519,12 +3536,12 @@ "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" }, "validate-npm-package-license": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.1.tgz", - "integrity": "sha1-KAS6vnEq0zeUWaz74kdGqywwP7w=", + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", + "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", "requires": { - "spdx-correct": "~1.0.0", - "spdx-expression-parse": "~1.0.0" + "spdx-correct": "^3.0.0", + "spdx-expression-parse": "^3.0.0" } }, "which": { @@ -3598,13 +3615,23 @@ "integrity": "sha512-wNcy4NvjMYL8gogWWYAO7ZFWFfHcbdbE57tZO8e4cbpj8tfUcwrwqSl3ad8HxpYWCdXcJUCeKKZS62Av1affwQ==", "dev": true }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" + }, "yaml": { - "version": "1.10.0", - "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.0.tgz", - "integrity": "sha512-yr2icI4glYaNG+KWONODapy2/jDdMSDnrONSjblABjD9B4Z5LgiircSt8m8sRZFNi08kG9Sm0uSHtEmP3zaEGg==", + "version": "1.10.2", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz", + "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==", "dev": true, "optional": true }, + "yargs-parser": { + "version": "20.2.9", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", + "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==" + }, "yargs-unparser": { "version": "1.6.1", "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-1.6.1.tgz", @@ -3736,6 +3763,11 @@ } } } + }, + "yocto-queue": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", + "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==" } } } diff --git a/package.json b/package.json index 63e974a..ee1b55d 100644 --- a/package.json +++ b/package.json @@ -28,7 +28,7 @@ "glob": "^7.1.2", "htmlparser2": "^3.9.1", "log-update": "^2.3.0", - "meow": "^3.7.0", + "meow": "^10.1.1", "strip-ansi": "^4.0.0" }, "devDependencies": { From 9754f5ae429adeaeec61e833abecdc7e5e0716dd Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Mon, 1 Nov 2021 00:37:12 +0100 Subject: [PATCH 03/23] chore(deps): add cosmiconfig to load configuration files The migration to ES modules makes it more complicated to import config files. Most notably, config files can no longer just be `require`d. So, to read and parse config files, and to support ES modules and CommonJS config files, cosmiconfig was added to load config files. --- bin/cli.js | 3 +++ package-lock.json | 23 +++++------------------ package.json | 1 + 3 files changed, 9 insertions(+), 18 deletions(-) diff --git a/bin/cli.js b/bin/cli.js index 1cbcff5..d605e5a 100755 --- a/bin/cli.js +++ b/bin/cli.js @@ -10,11 +10,13 @@ import SVGLint from "../src/svglint.js"; // @ts-ignore import config from "../src/cli/config.js"; import meow from "meow"; +import { cosmiconfig } from "cosmiconfig"; import chalk from "chalk"; import glob from "glob"; const GUI = new gui(); const { getConfigurationFile } = config; +const configExplorer = cosmiconfig("svglint"); const logger = Logger(""); // Pretty logs all errors, then exits @@ -62,6 +64,7 @@ process.on("exit", () => { try { const configFile = await getConfigurationFile(cli.flags.config); if (configFile) { + configObj = await configExplorer.load(configFile); } else { logger.debug("No configuration file found") if (cli.flags.config) { diff --git a/package-lock.json b/package-lock.json index 5f116ab..4fb0d2f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -158,9 +158,7 @@ "@types/parse-json": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz", - "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==", - "dev": true, - "optional": true + "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==" }, "acorn": { "version": "6.4.1", @@ -393,8 +391,7 @@ "callsites": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.0.0.tgz", - "integrity": "sha512-tWnkwu9YEq2uzlBDI4RcLn8jrFvF9AOi8PxDNU3hZZjJcjkcRAq3vCI+vZcg1SuxISDYe86k9VZFwAxDiJGoAw==", - "dev": true + "integrity": "sha512-tWnkwu9YEq2uzlBDI4RcLn8jrFvF9AOi8PxDNU3hZZjJcjkcRAq3vCI+vZcg1SuxISDYe86k9VZFwAxDiJGoAw==" }, "camelcase": { "version": "6.2.0", @@ -768,8 +765,6 @@ "version": "7.0.1", "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.0.1.tgz", "integrity": "sha512-a1YWNUV2HwGimB7dU2s1wUMurNKjpx60HxBB6xUM8Re+2s1g1IIfJvFR0/iCF+XHdE0GMTKTuLR32UQff4TEyQ==", - "dev": true, - "optional": true, "requires": { "@types/parse-json": "^4.0.0", "import-fresh": "^3.2.1", @@ -782,8 +777,6 @@ "version": "3.3.0", "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", - "dev": true, - "optional": true, "requires": { "parent-module": "^1.0.0", "resolve-from": "^4.0.0" @@ -2696,7 +2689,6 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.0.tgz", "integrity": "sha512-8Mf5juOMmiE4FcmzYc4IaiS9L3+9paz2KOiXzkRviCP6aDmN49Hz6EMWz0lGNp9pX80GvvAuLADtyGfW/Em3TA==", - "dev": true, "requires": { "callsites": "^3.0.0" } @@ -2756,9 +2748,7 @@ "path-type": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", - "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", - "dev": true, - "optional": true + "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==" }, "picomatch": { "version": "2.2.2", @@ -2992,8 +2982,7 @@ "resolve-from": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", - "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", - "dev": true + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==" }, "resolve-global": { "version": "1.0.0", @@ -3623,9 +3612,7 @@ "yaml": { "version": "1.10.2", "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz", - "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==", - "dev": true, - "optional": true + "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==" }, "yargs-parser": { "version": "20.2.9", diff --git a/package.json b/package.json index ee1b55d..4cdab00 100644 --- a/package.json +++ b/package.json @@ -24,6 +24,7 @@ "ansi-regex": "^5.0.1", "chalk": "^2.4.1", "cheerio": "^1.0.0-rc.6", + "cosmiconfig": "^7.0.1", "fast-xml-parser": "^3.12.13", "glob": "^7.1.2", "htmlparser2": "^3.9.1", From 85a26d49103e0300cb8e109792c192c0cec54fcb Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Wed, 3 Nov 2021 23:52:28 +0100 Subject: [PATCH 04/23] refactor: update tests to ES modules --- test/api.spec.js | 66 ++++++++++++++++++++++++++------------------- test/attr.spec.js | 15 ++++++----- test/custom.spec.js | 15 ++++++----- test/elm.spec.js | 15 ++++++----- test/valid.spec.js | 15 ++++++----- 5 files changed, 71 insertions(+), 55 deletions(-) diff --git a/test/api.spec.js b/test/api.spec.js index eda0c1b..31fdded 100644 --- a/test/api.spec.js +++ b/test/api.spec.js @@ -1,6 +1,11 @@ -const expect = require("expect"); -const path = require("path"); -const SVGLint = require("../src/svglint"); +import expect from "expect"; +import * as path from "path"; +import * as url from "url"; + +import SVGLint from "../src/svglint.js"; + +const currentFilePath = url.fileURLToPath(import.meta.url); +const __dirname = path.dirname(currentFilePath); process.on("unhandledRejection", error => { console.error(error); // eslint-disable-line no-console @@ -10,41 +15,48 @@ const svg = ""; describe(".lintSource()", function() { it("should succeed without config", function(done) { - const result = SVGLint.lintSource(svg); - result.on("done", () => { - expect(result.state).toBe(result.STATES.success); - done(); - }); + SVGLint.lintSource(svg) + .then(result => { + result.on("done", () => { + expect(result.state).toBe(result.STATES.success); + done(); + }); + }); }); it("should succeed with empty config", function(done) { - const result = SVGLint.lintSource(svg, {}); - result.on("done", () => { - expect(result.state).toBe(result.STATES.success); - done(); - }); + SVGLint.lintSource(svg, {}) + .then(result => { + result.on("done", () => { + expect(result.state).toBe(result.STATES.success); + done(); + }); + }); }); it("should succeed with empty SVG", function(done) { - const result = SVGLint.lintSource(svg, {}); - result.on("done", () => { - expect(result.state).toBe(result.STATES.success); - done(); - }); + SVGLint.lintSource(svg, {}) + .then(result => { + result.on("done", () => { + expect(result.state).toBe(result.STATES.success); + done(); + }); + }); }); it("should succeed with empty first line", function(done) { - const result = SVGLint.lintSource("\n" + svg, {}); - result.on("done", () => { - expect(result.state).toBe(result.STATES.success); - done(); - }); + SVGLint.lintSource("\n" + svg, {}) + .then(result => { + result.on("done", () => { + expect(result.state).toBe(result.STATES.success); + done(); + }); + }); }); - it("should throw with malformed SVG", function() { - expect(() => { - SVGLint.lintSource(" done()); }); }); diff --git a/test/attr.spec.js b/test/attr.spec.js index 807a192..3a2fb07 100644 --- a/test/attr.spec.js +++ b/test/attr.spec.js @@ -1,6 +1,7 @@ -const chalk = require("chalk"); -const SVGLint = require("../src/svglint"); -const util = require("util"); +import chalk from "chalk"; +import util from "util"; + +import SVGLint from "../src/svglint.js"; process.on("unhandledRejection", error => { console.error(error); // eslint-disable-line no-console @@ -54,8 +55,8 @@ function testSucceeds(config, svg=testSVG) { const _config = { rules: { attr: config }, }; - return new Promise((res, rej) => { - const linting = SVGLint.lintSource(svg, _config); + return new Promise(async (res, rej) => { + const linting = await SVGLint.lintSource(svg, _config); linting.on("done", () => { if (linting.state === linting.STATES.success) { res(); @@ -76,8 +77,8 @@ function testFails(config, svg=testSVG) { const _config = { rules: { attr: config }, }; - return new Promise((res, rej) => { - const linting = SVGLint.lintSource(svg, _config); + return new Promise(async (res, rej) => { + const linting = await SVGLint.lintSource(svg, _config); linting.on("done", () => { if (linting.state === linting.STATES.error) { res(); diff --git a/test/custom.spec.js b/test/custom.spec.js index 11d87fc..0969b45 100644 --- a/test/custom.spec.js +++ b/test/custom.spec.js @@ -1,6 +1,7 @@ -const chalk = require("chalk"); -const SVGLint = require("../src/svglint"); -const util = require("util"); +import chalk from "chalk"; +import util from "util"; + +import SVGLint from "../src/svglint.js"; process.on("unhandledRejection", error => { console.error(error); // eslint-disable-line no-console @@ -59,8 +60,8 @@ function testSucceeds(config, svg=testSVG) { const _config = { rules: { custom: config }, }; - return new Promise((res, rej) => { - const linting = SVGLint.lintSource(svg, _config); + return new Promise(async (res, rej) => { + const linting = await SVGLint.lintSource(svg, _config); linting.on("done", () => { if (linting.state === linting.STATES.success) { res(); @@ -81,8 +82,8 @@ function testFails(config, svg=testSVG) { const _config = { rules: { custom: config }, }; - return new Promise((res, rej) => { - const linting = SVGLint.lintSource(svg, _config); + return new Promise(async (res, rej) => { + const linting = await SVGLint.lintSource(svg, _config); linting.on("done", () => { if (linting.state === linting.STATES.error) { res(); diff --git a/test/elm.spec.js b/test/elm.spec.js index 28dbba6..49f4064 100644 --- a/test/elm.spec.js +++ b/test/elm.spec.js @@ -1,6 +1,7 @@ -const SVGLint = require("../src/svglint"); -const util = require("util"); -const chalk = require("chalk"); +import chalk from "chalk"; +import util from "util"; + +import SVGLint from "../src/svglint.js"; process.on("unhandledRejection", error => { console.error(error); // eslint-disable-line no-console @@ -49,8 +50,8 @@ function inspect(obj) { * @returns {Promise} Throws if linting fails */ function testSucceeds(config, svg=testSVG) { - return new Promise((res, rej) => { - const linting = SVGLint.lintSource(svg, config); + return new Promise(async (res, rej) => { + const linting = await SVGLint.lintSource(svg, config); linting.on("done", () => { if (linting.state === linting.STATES.success) { res(); @@ -71,8 +72,8 @@ function testFails(config, svg=testSVG) { const _config = { rules: { elm: config }, }; - return new Promise((res, rej) => { - const linting = SVGLint.lintSource(svg, _config); + return new Promise(async (res, rej) => { + const linting = await SVGLint.lintSource(svg, _config); linting.on("done", () => { if (linting.state === linting.STATES.error) { res(); diff --git a/test/valid.spec.js b/test/valid.spec.js index c31ac61..4e75706 100644 --- a/test/valid.spec.js +++ b/test/valid.spec.js @@ -1,6 +1,7 @@ -const chalk = require("chalk"); -const SVGLint = require("../src/svglint"); -const util = require("util"); +import chalk from "chalk"; +import util from "util"; + +import SVGLint from "../src/svglint.js"; process.on("unhandledRejection", error => { console.error(error); // eslint-disable-line no-console @@ -23,8 +24,8 @@ function inspect(obj) { * @returns {Promise} Throws if linting fails */ function testSucceeds(svg, config=undefined) { - return new Promise((res, rej) => { - const linting = SVGLint.lintSource(svg, config); + return new Promise(async (res, rej) => { + const linting = await SVGLint.lintSource(svg, config); linting.on("done", () => { if (linting.state === linting.STATES.success) { res(); @@ -42,8 +43,8 @@ function testSucceeds(svg, config=undefined) { * @returns {Promise} Throws if the linting doesn't fail */ function testFails(svg, config=undefined) { - return new Promise((res, rej) => { - const linting = SVGLint.lintSource(svg, config); + return new Promise(async (res, rej) => { + const linting = await SVGLint.lintSource(svg, config); linting.on("done", () => { if (linting.state === linting.STATES.error) { res(); From 033d7db98348fab795cff983c9ad5ea6e060990c Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Wed, 3 Nov 2021 23:59:20 +0100 Subject: [PATCH 05/23] fix: broken tests due to ESM mistakes in source Update the source to remove remaining `module.exports` reference (in parse.js). Update the source to be able to load rules as ESM using `await import(...)` (in rule-loader.js), update dependent code accordingly to await that import (see svglint.js). Two tests are now marked as skipped, initial investigation suggests the emitting of the "done" event at linting.js:79 doesn't work well in combination with async/await. --- src/lib/parse.js | 28 +++++++++++++++------------- src/lib/rule-loader.js | 14 ++++++++++---- src/svglint.js | 29 +++++++++++++++-------------- test/valid.spec.js | 4 ++-- 4 files changed, 42 insertions(+), 33 deletions(-) diff --git a/src/lib/parse.js b/src/lib/parse.js index 53e9870..6485124 100644 --- a/src/lib/parse.js +++ b/src/lib/parse.js @@ -8,6 +8,18 @@ import Parser from "htmlparser2"; import fs from "fs"; import path from "path"; +/** + * Parses an SVG source into an AST + * @param {String} source The source to parse + * @returns {AST} The parsed AST + */ +function parseSource(source) { + return normalizeAST( + sourceToAST(source), + source + ); +} + export default { /** * Clones an AST by re-parsing it's source @@ -16,20 +28,10 @@ export default { */ clone(ast) { // @ts-ignore - return module.exports.parseSource(ast.source); + return parseSource(ast.source); }, - /** - * Parses an SVG source into an AST - * @param {String} source The source to parse - * @returns {AST} The parsed AST - */ - parseSource(source) { - return normalizeAST( - sourceToAST(source), - source - ); - }, + parseSource, /** * Parses the content of a file into an AST @@ -48,7 +50,7 @@ export default { if (err) { return rej(err); } - try { return res(module.exports.parseSource(data)); } + try { return res(parseSource(data)); } catch (e) { return rej(e); } } ); diff --git a/src/lib/rule-loader.js b/src/lib/rule-loader.js index 774c17c..2e7a64e 100644 --- a/src/lib/rule-loader.js +++ b/src/lib/rule-loader.js @@ -19,15 +19,21 @@ import path from "path"; * built-in SVGLint rules. * @param {String} ruleName The name of the rule * @param {String} [dir] The dir to load the rules from if not from a package - * @returns {RuleModule} The function exported by the rule if found. + * @returns {Promise} Resolves to the function exported by the rule if found. */ -function ruleLoader(ruleName, dir="../rules") { +async function ruleLoader(ruleName, dir="../rules") { const fileName = ruleName.endsWith(".js") ? ruleName : ruleName + ".js"; const isExternal = ruleName.includes("/"); - return require(isExternal + const importPath = isExternal ? "svglint-plugin-" + ruleName - : path.join(dir, fileName)); + : path.join(dir, fileName); + try { + const module = await import(importPath); + return module.default; + } catch(_) { + return require(importPath); + } } export default ruleLoader; diff --git a/src/svglint.js b/src/svglint.js index 0b01ea0..6f8d842 100644 --- a/src/svglint.js +++ b/src/svglint.js @@ -53,21 +53,21 @@ const DEFAULT_CONFIG = Object.freeze({ * Figures out which rules should be kept, and calls their generator with the * user-provided config. The returned function is the actual linting func. * @param {RulesConfig} rulesConfig The user-provided config - * @returns {NormalizedRules} The normalized rules + * @returns {Promise} Resolves to the normalized rules */ -function normalizeRules(rulesConfig) { +async function normalizeRules(rulesConfig) { /** @type {NormalizedRules} */ const outp = {}; - Object.keys(rulesConfig) + const promises = Object.keys(rulesConfig) // make sure no disabled rules are allowed in .filter(k => rulesConfig[k] !== false) // then convert each rule config into a rule func - .forEach( - ruleName => { + .map( + async (ruleName) => { /** @type {RuleModule} */ let loadedRule; try { - loadedRule = loadRule(ruleName); + loadedRule = await loadRule(ruleName); } catch (e) { logger.warn(`Unknown rule "${ruleName}".`); return; @@ -85,6 +85,7 @@ function normalizeRules(rulesConfig) { } } ); + await Promise.all(promises); return outp; } @@ -92,9 +93,9 @@ function normalizeRules(rulesConfig) { * Normalizes a user-provided config to make sure it has every property we need. * Also handles merging with defaults. * @param {Config} config The user-provided config - * @returns {NormalizedConfig} The normalized config + * @returns {Promise} Resolves to the normalized config */ -function normalizeConfig(config) { +async function normalizeConfig(config) { const defaulted = Object.assign({}, DEFAULT_CONFIG, config, @@ -102,7 +103,7 @@ function normalizeConfig(config) { defaulted.rules = Object.assign({}, DEFAULT_CONFIG.rules, config.rules); /** @type NormalizedConfig */ const outp = { - rules: normalizeRules(defaulted.rules), + rules: await normalizeRules(defaulted.rules), ignore: defaulted.ignore, }; return outp; @@ -113,14 +114,14 @@ function normalizeConfig(config) { * @param {String} file The file we are linting * @param {AST} ast The AST to lint * @param {Config} config The user-provided config to lint by - * @returns {Linting} The linting that represents the result + * @returns {Promise} Resolves to the linting that represents the result */ -function lint(file, ast, config) { +async function lint(file, ast, config) { if (!ast.length && ast.source.trim() !== "") { throw new Error(`Unable to parse SVG from ${file || "API"}: ${ast.source}`); } - const conf = normalizeConfig(config); + const conf = await normalizeConfig(config); return new Linting(file, ast, conf.rules); } @@ -131,9 +132,9 @@ export default { * You should listen to Linting.on("done") to wait for the result. * @param {String} source The SVG to lint * @param {Config} [config={}] The config to lint by - * @return {Linting} The Linting that represents the result + * @return {Promise} Resolves to the Linting that represents the result */ - lintSource(source, config={}) { + async lintSource(source, config={}) { const ast = parse.parseSource(source); return lint(null, ast, config); }, diff --git a/test/valid.spec.js b/test/valid.spec.js index 4e75706..27df074 100644 --- a/test/valid.spec.js +++ b/test/valid.spec.js @@ -89,7 +89,7 @@ describe("Rule: valid", function(){ `, { rules: { valid: true } }); }); - it("should succeed when disabled for a valid SVG", function(){ + it.skip("should succeed when disabled for a valid SVG", function(){ return testSucceeds(` @@ -98,7 +98,7 @@ describe("Rule: valid", function(){ `, { rules: { valid: false } }); }); - it("should succeed when disabled for an invalid SVG", function(){ + it.skip("should succeed when disabled for an invalid SVG", function(){ return testSucceeds(` BadOne icon From 7a8dc5e87482cad231fee442ac8715ca4c915bfc Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Fri, 3 Dec 2021 20:40:38 +0100 Subject: [PATCH 06/23] chore: update ESLint and fix linting errors Update ESLint to the latest major version for easier support of a config file with an `.cjs` extension as well as better support for ESM. Fix all the linting warnings/errors. --- .eslintrc.js => .eslintrc.cjs | 4 + package-lock.json | 670 ++++++++++++++++++---------------- package.json | 2 +- src/cli/gui.js | 2 +- test/attr.spec.js | 34 +- test/custom.spec.js | 36 +- test/elm.spec.js | 34 +- test/valid.spec.js | 34 +- 8 files changed, 407 insertions(+), 409 deletions(-) rename .eslintrc.js => .eslintrc.cjs (83%) diff --git a/.eslintrc.js b/.eslintrc.cjs similarity index 83% rename from .eslintrc.js rename to .eslintrc.cjs index a8f9bcb..6007484 100644 --- a/.eslintrc.js +++ b/.eslintrc.cjs @@ -4,6 +4,10 @@ module.exports = { "es6": true, "jasmine": true }, + "parserOptions": { + "sourceType": "module", + "ecmaVersion": 2020, + }, "extends": "eslint:recommended", "rules": { "indent": ["error", 4, { "SwitchCase": 1 }], diff --git a/package-lock.json b/package-lock.json index 4fb0d2f..a6d0dca 100644 --- a/package-lock.json +++ b/package-lock.json @@ -139,6 +139,61 @@ "dev": true, "optional": true }, + "@eslint/eslintrc": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.0.4.tgz", + "integrity": "sha512-h8Vx6MdxwWI2WM8/zREHMoqdgLNXEL4QX3MWSVMdyNJGvXVOs+6lp+m2hc3FnuMHDc4poxFNI20vCk0OmI4G0Q==", + "dev": true, + "requires": { + "ajv": "^6.12.4", + "debug": "^4.3.2", + "espree": "^9.0.0", + "globals": "^13.9.0", + "ignore": "^4.0.6", + "import-fresh": "^3.2.1", + "js-yaml": "^4.1.0", + "minimatch": "^3.0.4", + "strip-json-comments": "^3.1.1" + }, + "dependencies": { + "debug": { + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", + "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", + "dev": true, + "requires": { + "ms": "2.1.2" + } + }, + "import-fresh": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "requires": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + } + } + } + }, + "@humanwhocodes/config-array": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.6.0.tgz", + "integrity": "sha512-JQlEKbcgEUjBFhLIF4iqM7u/9lwgHRBcpHrmUNCALK0Q3amXN6lxdoXLnF0sm11E9VqTmBALR87IlUg1bZ8A9A==", + "dev": true, + "requires": { + "@humanwhocodes/object-schema": "^1.2.0", + "debug": "^4.1.1", + "minimatch": "^3.0.4" + } + }, + "@humanwhocodes/object-schema": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", + "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", + "dev": true + }, "@types/color-name": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", @@ -161,24 +216,24 @@ "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==" }, "acorn": { - "version": "6.4.1", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.1.tgz", - "integrity": "sha512-ZVA9k326Nwrj3Cj9jlh3wGFutC2ZornPNARZwsNYqQYgN0EsV2d53w5RN/co65Ohn4sUAUtb1rSUAOD6XN9idA==", + "version": "8.6.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.6.0.tgz", + "integrity": "sha512-U1riIR+lBSNi3IbxtaHOIKdH8sLFv3NYfNv8sg7ZsNhcfl4HF2++BfqqrNAxoCLQW1iiylOj76ecnaUxz+z9yw==", "dev": true }, "acorn-jsx": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.1.tgz", - "integrity": "sha512-HJ7CfNHrfJLlNTzIEUTj43LNWGkqpRLxm3YjAlcD0ACydk9XynzYsCBHxut+iqt+1aBXkx9UP/w/ZqMr13XIzg==", + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", + "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", "dev": true }, "ajv": { - "version": "6.9.2", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.9.2.tgz", - "integrity": "sha512-4UFy0/LgDo7Oa/+wOAlj44tp9K78u38E5/359eSrqEp1Z5PdVfimCcs7SluXMP755RUQu6d2b4AvF0R1C9RZjg==", + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", "dev": true, "requires": { - "fast-deep-equal": "^2.0.1", + "fast-deep-equal": "^3.1.1", "fast-json-stable-stringify": "^2.0.0", "json-schema-traverse": "^0.4.1", "uri-js": "^4.2.2" @@ -336,12 +391,6 @@ "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=" }, - "astral-regex": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", - "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", - "dev": true - }, "balanced-match": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", @@ -785,23 +834,24 @@ } }, "cross-spawn": { - "version": "6.0.5", - "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", - "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", "dev": true, "requires": { - "nice-try": "^1.0.4", - "path-key": "^2.0.1", - "semver": "^5.5.0", - "shebang-command": "^1.2.0", - "which": "^1.2.9" + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" }, "dependencies": { - "semver": { - "version": "5.6.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz", - "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg==", - "dev": true + "which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } } } }, @@ -922,9 +972,9 @@ "dev": true }, "deep-is": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", - "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", + "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", "dev": true }, "define-properties": { @@ -1008,6 +1058,15 @@ "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", "dev": true }, + "enquirer": { + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", + "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", + "dev": true, + "requires": { + "ansi-colors": "^4.1.1" + } + }, "entities": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/entities/-/entities-1.1.1.tgz", @@ -1167,106 +1226,188 @@ "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" }, "eslint": { - "version": "5.14.1", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.14.1.tgz", - "integrity": "sha512-CyUMbmsjxedx8B0mr79mNOqetvkbij/zrXnFeK2zc3pGRn3/tibjiNAv/3UxFEyfMDjh+ZqTrJrEGBFiGfD5Og==", + "version": "8.3.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.3.0.tgz", + "integrity": "sha512-aIay56Ph6RxOTC7xyr59Kt3ewX185SaGnAr8eWukoPLeriCrvGjvAubxuvaXOfsxhtwV5g0uBOsyhAom4qJdww==", "dev": true, "requires": { - "@babel/code-frame": "^7.0.0", - "ajv": "^6.9.1", - "chalk": "^2.1.0", - "cross-spawn": "^6.0.5", - "debug": "^4.0.1", + "@eslint/eslintrc": "^1.0.4", + "@humanwhocodes/config-array": "^0.6.0", + "ajv": "^6.10.0", + "chalk": "^4.0.0", + "cross-spawn": "^7.0.2", + "debug": "^4.3.2", "doctrine": "^3.0.0", - "eslint-scope": "^4.0.0", - "eslint-utils": "^1.3.1", - "eslint-visitor-keys": "^1.0.0", - "espree": "^5.0.1", - "esquery": "^1.0.1", + "enquirer": "^2.3.5", + "escape-string-regexp": "^4.0.0", + "eslint-scope": "^7.1.0", + "eslint-utils": "^3.0.0", + "eslint-visitor-keys": "^3.1.0", + "espree": "^9.1.0", + "esquery": "^1.4.0", "esutils": "^2.0.2", - "file-entry-cache": "^5.0.1", + "fast-deep-equal": "^3.1.3", + "file-entry-cache": "^6.0.1", "functional-red-black-tree": "^1.0.1", - "glob": "^7.1.2", - "globals": "^11.7.0", + "glob-parent": "^6.0.1", + "globals": "^13.6.0", "ignore": "^4.0.6", "import-fresh": "^3.0.0", "imurmurhash": "^0.1.4", - "inquirer": "^6.2.2", - "js-yaml": "^3.12.0", + "is-glob": "^4.0.0", + "js-yaml": "^4.1.0", "json-stable-stringify-without-jsonify": "^1.0.1", - "levn": "^0.3.0", - "lodash": "^4.17.11", + "levn": "^0.4.1", + "lodash.merge": "^4.6.2", "minimatch": "^3.0.4", - "mkdirp": "^0.5.1", "natural-compare": "^1.4.0", - "optionator": "^0.8.2", - "path-is-inside": "^1.0.2", + "optionator": "^0.9.1", "progress": "^2.0.0", - "regexpp": "^2.0.1", - "semver": "^5.5.1", - "strip-ansi": "^4.0.0", - "strip-json-comments": "^2.0.1", - "table": "^5.2.3", - "text-table": "^0.2.0" + "regexpp": "^3.2.0", + "semver": "^7.2.1", + "strip-ansi": "^6.0.1", + "strip-json-comments": "^3.1.0", + "text-table": "^0.2.0", + "v8-compile-cache": "^2.0.3" }, "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, "debug": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", - "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", + "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", "dev": true, "requires": { - "ms": "^2.1.1" + "ms": "2.1.2" } }, - "ms": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", - "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", + "escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", "dev": true }, - "semver": { - "version": "5.6.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz", - "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg==", + "glob-parent": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", + "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", + "dev": true, + "requires": { + "is-glob": "^4.0.3" + }, + "dependencies": { + "is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "requires": { + "is-extglob": "^2.1.1" + } + } + } + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", "dev": true + }, + "strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.1" + } + }, + "supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } } } }, "eslint-scope": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.0.tgz", - "integrity": "sha512-1G6UTDi7Jc1ELFwnR58HV4fK9OQK4S6N985f166xqXxpjU6plxFISJa2Ba9KCQuFa8RCnj/lSFJbHo7UFDBnUA==", + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.0.tgz", + "integrity": "sha512-aWwkhnS0qAXqNOgKOK0dJ2nvzEbhEvpy8OlJ9kZ0FeZnA6zpjv1/Vei+puGFFX7zkPCkHHXb7IDX3A+7yPrRWg==", "dev": true, "requires": { - "esrecurse": "^4.1.0", - "estraverse": "^4.1.1" + "esrecurse": "^4.3.0", + "estraverse": "^5.2.0" } }, "eslint-utils": { - "version": "1.4.2", - "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.2.tgz", - "integrity": "sha512-eAZS2sEUMlIeCjBeubdj45dmBHQwPHWyBcT1VSYB7o9x9WRRqKxyUoiXlRjyAwzN7YEzHJlYg0NmzDRWx6GP4Q==", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", + "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", "dev": true, "requires": { - "eslint-visitor-keys": "^1.0.0" + "eslint-visitor-keys": "^2.0.0" + }, + "dependencies": { + "eslint-visitor-keys": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", + "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", + "dev": true + } } }, "eslint-visitor-keys": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", - "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.1.0.tgz", + "integrity": "sha512-yWJFpu4DtjsWKkt5GeNBBuZMlNcYVs6vRCLoCVEJrTjaSB6LC98gFipNK/erM2Heg/E8mIK+hXG/pJMLK+eRZA==", "dev": true }, "espree": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.1.tgz", - "integrity": "sha512-qWAZcWh4XE/RwzLJejfcofscgMc9CamR6Tn1+XRXNzrvUSSbiAjGOI/fggztjIi7y9VLPqnICMIPiGyr8JaZ0A==", + "version": "9.1.0", + "resolved": "https://registry.npmjs.org/espree/-/espree-9.1.0.tgz", + "integrity": "sha512-ZgYLvCS1wxOczBYGcQT9DDWgicXwJ4dbocr9uYN+/eresBAUuBu+O4WzB21ufQ/JqQT8gyp7hJ3z8SHii32mTQ==", "dev": true, "requires": { - "acorn": "^6.0.7", - "acorn-jsx": "^5.0.0", - "eslint-visitor-keys": "^1.0.0" + "acorn": "^8.6.0", + "acorn-jsx": "^5.3.1", + "eslint-visitor-keys": "^3.1.0" } }, "esprima": { @@ -1276,27 +1417,27 @@ "dev": true }, "esquery": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", - "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", + "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", "dev": true, "requires": { - "estraverse": "^4.0.0" + "estraverse": "^5.1.0" } }, "esrecurse": { - "version": "4.2.1", - "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", - "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", + "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", "dev": true, "requires": { - "estraverse": "^4.1.0" + "estraverse": "^5.2.0" } }, "estraverse": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", - "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", "dev": true }, "esutils": { @@ -1340,15 +1481,15 @@ } }, "fast-deep-equal": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", - "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", "dev": true }, "fast-json-stable-stringify": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", - "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", "dev": true }, "fast-levenshtein": { @@ -1375,12 +1516,12 @@ } }, "file-entry-cache": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", - "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", + "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", "dev": true, "requires": { - "flat-cache": "^2.0.1" + "flat-cache": "^3.0.4" } }, "fill-range": { @@ -1447,20 +1588,19 @@ } }, "flat-cache": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", - "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", + "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", "dev": true, "requires": { - "flatted": "^2.0.0", - "rimraf": "2.6.3", - "write": "1.0.3" + "flatted": "^3.1.0", + "rimraf": "^3.0.2" } }, "flatted": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.0.tgz", - "integrity": "sha512-R+H8IZclI8AAkSBRQJLVOsxwAoHd6WC40b4QTNWIjzAa6BXOBfQcM587MXDTVPeYaopFNWHUFLx7eNmHDSxMWg==", + "version": "3.2.4", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.4.tgz", + "integrity": "sha512-8/sOawo8tJ4QOBX8YlQBMxL8+RLZfxMQOif9o0KUKTNTjMYElWPE0r/m5VNFxTRd0NSw8qSy8dajrwX4RYI1Hw==", "dev": true }, "foreach": { @@ -1575,10 +1715,21 @@ } }, "globals": { - "version": "11.11.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-11.11.0.tgz", - "integrity": "sha512-WHq43gS+6ufNOEqlrDBxVEbb8ntfXrfAUU2ZOpCxrBdGKW3gyv8mCxAfIBD0DroPKGrJ2eSsXsLtY9MPntsyTw==", - "dev": true + "version": "13.12.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.12.0.tgz", + "integrity": "sha512-uS8X6lSKN2JumVoXrbUz+uG4BYG+eiawqm3qFcT7ammfbUHeCBoJMlHcec/S3krSk73/AE/f0szYFmgAA3kYZg==", + "dev": true, + "requires": { + "type-fest": "^0.20.2" + }, + "dependencies": { + "type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true + } + } }, "graceful-fs": { "version": "4.1.11", @@ -1710,61 +1861,6 @@ "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==", "dev": true }, - "inquirer": { - "version": "6.2.2", - "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.2.2.tgz", - "integrity": "sha512-Z2rREiXA6cHRR9KBOarR3WuLlFzlIfAEIiB45ll5SSadMg7WqOh1MKEjjndfuH5ewXdixWCxqnVfGOQzPeiztA==", - "dev": true, - "requires": { - "ansi-escapes": "^3.2.0", - "chalk": "^2.4.2", - "cli-cursor": "^2.1.0", - "cli-width": "^2.0.0", - "external-editor": "^3.0.3", - "figures": "^2.0.0", - "lodash": "^4.17.11", - "mute-stream": "0.0.7", - "run-async": "^2.2.0", - "rxjs": "^6.4.0", - "string-width": "^2.1.0", - "strip-ansi": "^5.0.0", - "through": "^2.3.6" - }, - "dependencies": { - "ansi-escapes": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", - "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==", - "dev": true - }, - "ansi-regex": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.0.0.tgz", - "integrity": "sha512-iB5Dda8t/UqpPI/IjsejXu5jOGDrzn41wJyljwPH65VCIbk6+1BzFIMJGFwTNrYXT1CrD+B4l19U7awiQ8rk7w==", - "dev": true - }, - "chalk": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", - "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - } - }, - "strip-ansi": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.0.0.tgz", - "integrity": "sha512-Uu7gQyZI7J7gn5qLn1Np3G9vcYGTVqB+lFTytnDJv83dd8T22aGH451P3jueT2/QemInJDfxHB5Tde5OzgG1Ow==", - "dev": true, - "requires": { - "ansi-regex": "^4.0.0" - } - } - } - }, "is-arguments": { "version": "1.0.4", "resolved": "https://registry.npmjs.org/is-arguments/-/is-arguments-1.0.4.tgz", @@ -1981,13 +2077,20 @@ "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" }, "js-yaml": { - "version": "3.13.1", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", - "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", + "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", "dev": true, "requires": { - "argparse": "^1.0.7", - "esprima": "^4.0.0" + "argparse": "^2.0.1" + }, + "dependencies": { + "argparse": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "dev": true + } } }, "json-parse-even-better-errors": { @@ -2022,13 +2125,13 @@ "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==" }, "levn": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", - "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", "dev": true, "requires": { - "prelude-ls": "~1.1.2", - "type-check": "~0.3.2" + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" } }, "lines-and-columns": { @@ -2056,6 +2159,12 @@ "integrity": "sha1-dx7Hg540c9nEzeKLGTlMNWL09tM=", "dev": true }, + "lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", + "dev": true + }, "log-symbols": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.0.0.tgz", @@ -2230,15 +2339,6 @@ "kind-of": "^6.0.3" } }, - "mkdirp": { - "version": "0.5.5", - "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", - "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", - "dev": true, - "requires": { - "minimist": "^1.2.5" - } - }, "mocha": { "version": "8.1.3", "resolved": "https://registry.npmjs.org/mocha/-/mocha-8.1.3.tgz", @@ -2510,6 +2610,12 @@ } } }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, "mute-stream": { "version": "0.0.7", "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", @@ -2522,12 +2628,6 @@ "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", "dev": true }, - "nice-try": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", - "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", - "dev": true - }, "nimn-date-parser": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/nimn-date-parser/-/nimn-date-parser-1.0.0.tgz", @@ -2633,17 +2733,17 @@ } }, "optionator": { - "version": "0.8.2", - "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", - "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", + "version": "0.9.1", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", + "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", "dev": true, "requires": { - "deep-is": "~0.1.3", - "fast-levenshtein": "~2.0.4", - "levn": "~0.3.0", - "prelude-ls": "~1.1.2", - "type-check": "~0.3.2", - "wordwrap": "~1.0.0" + "deep-is": "^0.1.3", + "fast-levenshtein": "^2.0.6", + "levn": "^0.4.1", + "prelude-ls": "^1.2.1", + "type-check": "^0.4.0", + "word-wrap": "^1.2.3" } }, "os-tmpdir": { @@ -2733,16 +2833,10 @@ "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" }, - "path-is-inside": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", - "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", - "dev": true - }, "path-key": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", - "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", "dev": true }, "path-type": { @@ -2757,9 +2851,9 @@ "dev": true }, "prelude-ls": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", - "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", "dev": true }, "process-nextick-args": { @@ -2952,9 +3046,9 @@ } }, "regexpp": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", - "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", + "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", "dev": true }, "require-directory": { @@ -3004,18 +3098,18 @@ } }, "rimraf": { - "version": "2.6.3", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", - "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", "dev": true, "requires": { "glob": "^7.1.3" }, "dependencies": { "glob": { - "version": "7.1.3", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", - "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", + "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", "dev": true, "requires": { "fs.realpath": "^1.0.0", @@ -3081,18 +3175,18 @@ "dev": true }, "shebang-command": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", - "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", "dev": true, "requires": { - "shebang-regex": "^1.0.0" + "shebang-regex": "^3.0.0" } }, "shebang-regex": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", - "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", "dev": true }, "signal-exit": { @@ -3100,17 +3194,6 @@ "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" }, - "slice-ansi": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", - "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.0", - "astral-regex": "^1.0.0", - "is-fullwidth-code-point": "^2.0.0" - } - }, "spdx-correct": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", @@ -3390,9 +3473,9 @@ } }, "strip-json-comments": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", - "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", + "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", "dev": true }, "supports-color": { @@ -3403,46 +3486,6 @@ "has-flag": "^3.0.0" } }, - "table": { - "version": "5.2.3", - "resolved": "https://registry.npmjs.org/table/-/table-5.2.3.tgz", - "integrity": "sha512-N2RsDAMvDLvYwFcwbPyF3VmVSSkuF+G1e+8inhBLtHpvwXGw4QRPEZhihQNeEN0i1up6/f6ObCJXNdlRG3YVyQ==", - "dev": true, - "requires": { - "ajv": "^6.9.1", - "lodash": "^4.17.11", - "slice-ansi": "^2.1.0", - "string-width": "^3.0.0" - }, - "dependencies": { - "ansi-regex": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.0.0.tgz", - "integrity": "sha512-iB5Dda8t/UqpPI/IjsejXu5jOGDrzn41wJyljwPH65VCIbk6+1BzFIMJGFwTNrYXT1CrD+B4l19U7awiQ8rk7w==", - "dev": true - }, - "string-width": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.0.0.tgz", - "integrity": "sha512-rr8CUxBbvOZDUvc5lNIJ+OC1nPVpz+Siw9VBtUjB9b6jZehZLFt0JMCZzShFHIsI8cbhm0EsNIfWJMFV3cu3Ew==", - "dev": true, - "requires": { - "emoji-regex": "^7.0.1", - "is-fullwidth-code-point": "^2.0.0", - "strip-ansi": "^5.0.0" - } - }, - "strip-ansi": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.0.0.tgz", - "integrity": "sha512-Uu7gQyZI7J7gn5qLn1Np3G9vcYGTVqB+lFTytnDJv83dd8T22aGH451P3jueT2/QemInJDfxHB5Tde5OzgG1Ow==", - "dev": true, - "requires": { - "ansi-regex": "^4.0.0" - } - } - } - }, "text-table": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", @@ -3491,12 +3534,12 @@ "dev": true }, "type-check": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", - "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", "dev": true, "requires": { - "prelude-ls": "~1.1.2" + "prelude-ls": "^1.2.1" } }, "type-fest": { @@ -3511,9 +3554,9 @@ "dev": true }, "uri-js": { - "version": "4.2.2", - "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", - "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", "dev": true, "requires": { "punycode": "^2.1.0" @@ -3524,6 +3567,12 @@ "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" }, + "v8-compile-cache": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", + "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", + "dev": true + }, "validate-npm-package-license": { "version": "3.0.4", "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", @@ -3563,12 +3612,6 @@ "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", "dev": true }, - "wordwrap": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", - "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", - "dev": true - }, "workerpool": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.0.0.tgz", @@ -3589,15 +3632,6 @@ "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" }, - "write": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", - "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", - "dev": true, - "requires": { - "mkdirp": "^0.5.1" - } - }, "y18n": { "version": "4.0.1", "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.1.tgz", diff --git a/package.json b/package.json index 4cdab00..7064b66 100644 --- a/package.json +++ b/package.json @@ -35,7 +35,7 @@ "devDependencies": { "commitizen": "^4.2.4", "cz-conventional-changelog": "^3.3.0", - "eslint": "^5.14.1", + "eslint": "^8.3.0", "expect": "^1.20.2", "mocha": "^8.1.3" }, diff --git a/src/cli/gui.js b/src/cli/gui.js index 0794eb5..de90e48 100644 --- a/src/cli/gui.js +++ b/src/cli/gui.js @@ -142,4 +142,4 @@ export default class GUI { setCI(value) { this.ci = value; } -}; +} diff --git a/test/attr.spec.js b/test/attr.spec.js index f495a00..0ea8313 100644 --- a/test/attr.spec.js +++ b/test/attr.spec.js @@ -52,20 +52,15 @@ function inspect(obj) { * @param {String} [svg=testSVG] The SVG to lint * @returns {Promise} Throws if linting fails */ -function testSucceeds(config, svg=testSVG) { +async function testSucceeds(config, svg=testSVG) { const _config = { rules: { attr: config }, }; - return new Promise(async (res, rej) => { - const linting = await SVGLint.lintSource(svg, _config); - linting.on("done", () => { - if (linting.state === linting.STATES.success) { - res(); - } else { - rej(new Error(`Linting failed (${linting.state}): - ${inspect(config)}`)); - } - }); + const linting = await SVGLint.lintSource(svg, _config); + linting.on("done", () => { + if (linting.state !== linting.STATES.success) { + throw new Error(`Linting failed (${linting.state}): ${inspect(config)}`); + } }); } /** @@ -74,20 +69,15 @@ function testSucceeds(config, svg=testSVG) { * @param {String} svg The SVG to lint * @returns {Promise} Throws if the linting doesn't fail */ -function testFails(config, svg=testSVG) { +async function testFails(config, svg=testSVG) { const _config = { rules: { attr: config }, }; - return new Promise(async (res, rej) => { - const linting = await SVGLint.lintSource(svg, _config); - linting.on("done", () => { - if (linting.state === linting.STATES.error) { - res(); - } else { - rej(new Error(`Linting did not fail (${linting.state}): - ${inspect(_config)}`)); - } - }); + const linting = await SVGLint.lintSource(svg, _config); + linting.on("done", () => { + if (linting.state !== linting.STATES.error) { + throw new Error(`Linting did not fail (${linting.state}): ${inspect(_config)}`); + } }); } diff --git a/test/custom.spec.js b/test/custom.spec.js index 1049780..89c6d9a 100644 --- a/test/custom.spec.js +++ b/test/custom.spec.js @@ -56,20 +56,15 @@ function inspect(obj) { * @param {String} [svg=testSVG] The SVG to lint * @returns {Promise} Throws if linting fails */ -function testSucceeds(config, svg=testSVG) { +async function testSucceeds(config, svg=testSVG) { const _config = { rules: { custom: config }, }; - return new Promise(async (res, rej) => { - const linting = await SVGLint.lintSource(svg, _config); - linting.on("done", () => { - if (linting.state === linting.STATES.success) { - res(); - } else { - rej(new Error(`Linting failed (${linting.state}): - ${inspect(config)}`)); - } - }); + const linting = await SVGLint.lintSource(svg, _config); + linting.on("done", () => { + if (linting.state !== linting.STATES.success) { + throw new Error(`Linting failed (${linting.state}): ${inspect(config)}`); + } }); } /** @@ -78,20 +73,15 @@ function testSucceeds(config, svg=testSVG) { * @param {String} svg The SVG to lint * @returns {Promise} Throws if the linting doesn't fail */ -function testFails(config, svg=testSVG) { +async function testFails(config, svg=testSVG) { const _config = { rules: { custom: config }, }; - return new Promise(async (res, rej) => { - const linting = await SVGLint.lintSource(svg, _config); - linting.on("done", () => { - if (linting.state === linting.STATES.error) { - res(); - } else { - rej(new Error(`Linting did not fail (${linting.state}): - ${inspect(_config)}`)); - } - }); + const linting = await SVGLint.lintSource(svg, _config); + linting.on("done", () => { + if (linting.state !== linting.STATES.error) { + throw new Error(`Linting did not fail (${linting.state}): ${inspect(_config)}`); + } }); } @@ -106,7 +96,7 @@ describe("Rule: custom", function(){ if(!info) { throw new Error("no info provided"); } - if(!info.hasOwnProperty("filepath")) { + if(!Object.prototype.hasOwnProperty.call(info, "filepath")) { throw new Error("no filepath provided on info"); } } diff --git a/test/elm.spec.js b/test/elm.spec.js index 49f4064..edc7a74 100644 --- a/test/elm.spec.js +++ b/test/elm.spec.js @@ -49,17 +49,12 @@ function inspect(obj) { * @param {String} [svg=testSVG] The SVG to lint * @returns {Promise} Throws if linting fails */ -function testSucceeds(config, svg=testSVG) { - return new Promise(async (res, rej) => { - const linting = await SVGLint.lintSource(svg, config); - linting.on("done", () => { - if (linting.state === linting.STATES.success) { - res(); - } else { - rej(new Error(`Linting failed (${linting.state}): - ${inspect(config)}`)); - } - }); +async function testSucceeds(config, svg=testSVG) { + const linting = await SVGLint.lintSource(svg, config); + linting.on("done", () => { + if (linting.state !== linting.STATES.success) { + throw new Error(`Linting failed (${linting.state}): ${inspect(config)}`); + } }); } /** @@ -68,20 +63,15 @@ function testSucceeds(config, svg=testSVG) { * @param {String} svg The SVG to lint * @returns {Promise} Throws if the linting doesn't fail */ -function testFails(config, svg=testSVG) { +async function testFails(config, svg=testSVG) { const _config = { rules: { elm: config }, }; - return new Promise(async (res, rej) => { - const linting = await SVGLint.lintSource(svg, _config); - linting.on("done", () => { - if (linting.state === linting.STATES.error) { - res(); - } else { - rej(new Error(`Linting did not fail (${linting.state}): - ${inspect(_config)}`)); - } - }); + const linting = await SVGLint.lintSource(svg, _config); + linting.on("done", () => { + if (linting.state !== linting.STATES.error) { + throw new Error(`Linting did not fail (${linting.state}): ${inspect(_config)}`); + } }); } diff --git a/test/valid.spec.js b/test/valid.spec.js index 27df074..39a176a 100644 --- a/test/valid.spec.js +++ b/test/valid.spec.js @@ -23,17 +23,12 @@ function inspect(obj) { * @param {Object} [config] The config to test * @returns {Promise} Throws if linting fails */ -function testSucceeds(svg, config=undefined) { - return new Promise(async (res, rej) => { - const linting = await SVGLint.lintSource(svg, config); - linting.on("done", () => { - if (linting.state === linting.STATES.success) { - res(); - } else { - rej(new Error(`Linting failed (${linting.state}),: - ${inspect(config)}`)); - } - }); +async function testSucceeds(svg, config=undefined) { + const linting = await SVGLint.lintSource(svg, config); + linting.on("done", () => { + if (linting.state !== linting.STATES.success) { + throw new Error(`Linting failed (${linting.state}),: ${inspect(config)}`); + } }); } /** @@ -42,17 +37,12 @@ function testSucceeds(svg, config=undefined) { * @param {Object} [config] The config to test * @returns {Promise} Throws if the linting doesn't fail */ -function testFails(svg, config=undefined) { - return new Promise(async (res, rej) => { - const linting = await SVGLint.lintSource(svg, config); - linting.on("done", () => { - if (linting.state === linting.STATES.error) { - res(); - } else { - rej(new Error(`Linting did not fail (${linting.state}): - ${inspect(config)}`)); - } - }); +async function testFails(svg, config=undefined) { + const linting = await SVGLint.lintSource(svg, config); + linting.on("done", () => { + if (linting.state !== linting.STATES.error) { + throw new Error(`Linting did not fail (${linting.state}): ${inspect(config)}`); + } }); } From 35a02af92101bcc5727ab9eedcd904e88731665d Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Fri, 3 Dec 2021 20:43:39 +0100 Subject: [PATCH 07/23] chore: update package manifest for ESM only --- package.json | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/package.json b/package.json index 7064b66..f81cfbe 100644 --- a/package.json +++ b/package.json @@ -3,7 +3,7 @@ "version": "1.0.5", "description": "Linter for SVGs", "type": "module", - "main": "src/svglint.js", + "exports": "./src/svglint.js", "bin": { "svglint": "./bin/cli.js" }, @@ -39,6 +39,9 @@ "expect": "^1.20.2", "mocha": "^8.1.3" }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, "config": { "commitizen": { "path": "./node_modules/cz-conventional-changelog" From 2349787a0b559f7db1ad88fd5a647ee53527a40e Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Fri, 3 Dec 2021 20:44:23 +0100 Subject: [PATCH 08/23] chore: unskip tests --- test/valid.spec.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/test/valid.spec.js b/test/valid.spec.js index 39a176a..94fe0fb 100644 --- a/test/valid.spec.js +++ b/test/valid.spec.js @@ -79,7 +79,7 @@ describe("Rule: valid", function(){ `, { rules: { valid: true } }); }); - it.skip("should succeed when disabled for a valid SVG", function(){ + it("should succeed when disabled for a valid SVG", function(){ return testSucceeds(` @@ -88,7 +88,7 @@ describe("Rule: valid", function(){ `, { rules: { valid: false } }); }); - it.skip("should succeed when disabled for an invalid SVG", function(){ + it("should succeed when disabled for an invalid SVG", function(){ return testSucceeds(` BadOne icon From 71b30f46efa032163cd713b1cc30d9e5e2715675 Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Fri, 3 Dec 2021 20:47:57 +0100 Subject: [PATCH 09/23] docs: update JS API example --- README.md | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 49a7e3f..b03277d 100644 --- a/README.md +++ b/README.md @@ -31,8 +31,9 @@ $ svglint --help The tool can also be used through the JS API. ```javascript -const SVGLint = require("svglint"); -const linting = SVGLint.lintSource("...", { +import SVGLint from "svglint"; + +const linting = await SVGLint.lintSource("...", { // ... config goes here }); linting.on("done", () => { From 1e4eb075c050896486e58d377dd4ed7425087bb2 Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Fri, 3 Dec 2021 21:01:21 +0100 Subject: [PATCH 10/23] fix: support ESM and CJS config files --- bin/cli.js | 8 +++++--- package-lock.json | 23 ++++++++++++++++++----- package.json | 1 - 3 files changed, 23 insertions(+), 9 deletions(-) diff --git a/bin/cli.js b/bin/cli.js index d605e5a..412d118 100755 --- a/bin/cli.js +++ b/bin/cli.js @@ -10,13 +10,11 @@ import SVGLint from "../src/svglint.js"; // @ts-ignore import config from "../src/cli/config.js"; import meow from "meow"; -import { cosmiconfig } from "cosmiconfig"; import chalk from "chalk"; import glob from "glob"; const GUI = new gui(); const { getConfigurationFile } = config; -const configExplorer = cosmiconfig("svglint"); const logger = Logger(""); // Pretty logs all errors, then exits @@ -64,7 +62,11 @@ process.on("exit", () => { try { const configFile = await getConfigurationFile(cli.flags.config); if (configFile) { - configObj = await configExplorer.load(configFile); + try { + configObj = await import(configFile); + } catch(_) { + configObj = require(configFile); + } } else { logger.debug("No configuration file found") if (cli.flags.config) { diff --git a/package-lock.json b/package-lock.json index a6d0dca..ec95a76 100644 --- a/package-lock.json +++ b/package-lock.json @@ -213,7 +213,9 @@ "@types/parse-json": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz", - "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==" + "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==", + "dev": true, + "optional": true }, "acorn": { "version": "8.6.0", @@ -440,7 +442,8 @@ "callsites": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.0.0.tgz", - "integrity": "sha512-tWnkwu9YEq2uzlBDI4RcLn8jrFvF9AOi8PxDNU3hZZjJcjkcRAq3vCI+vZcg1SuxISDYe86k9VZFwAxDiJGoAw==" + "integrity": "sha512-tWnkwu9YEq2uzlBDI4RcLn8jrFvF9AOi8PxDNU3hZZjJcjkcRAq3vCI+vZcg1SuxISDYe86k9VZFwAxDiJGoAw==", + "dev": true }, "camelcase": { "version": "6.2.0", @@ -814,6 +817,8 @@ "version": "7.0.1", "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.0.1.tgz", "integrity": "sha512-a1YWNUV2HwGimB7dU2s1wUMurNKjpx60HxBB6xUM8Re+2s1g1IIfJvFR0/iCF+XHdE0GMTKTuLR32UQff4TEyQ==", + "dev": true, + "optional": true, "requires": { "@types/parse-json": "^4.0.0", "import-fresh": "^3.2.1", @@ -826,6 +831,8 @@ "version": "3.3.0", "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "optional": true, "requires": { "parent-module": "^1.0.0", "resolve-from": "^4.0.0" @@ -2789,6 +2796,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.0.tgz", "integrity": "sha512-8Mf5juOMmiE4FcmzYc4IaiS9L3+9paz2KOiXzkRviCP6aDmN49Hz6EMWz0lGNp9pX80GvvAuLADtyGfW/Em3TA==", + "dev": true, "requires": { "callsites": "^3.0.0" } @@ -2842,7 +2850,9 @@ "path-type": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", - "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==" + "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", + "dev": true, + "optional": true }, "picomatch": { "version": "2.2.2", @@ -3076,7 +3086,8 @@ "resolve-from": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", - "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==" + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true }, "resolve-global": { "version": "1.0.0", @@ -3646,7 +3657,9 @@ "yaml": { "version": "1.10.2", "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz", - "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==" + "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==", + "dev": true, + "optional": true }, "yargs-parser": { "version": "20.2.9", diff --git a/package.json b/package.json index f81cfbe..cad018c 100644 --- a/package.json +++ b/package.json @@ -24,7 +24,6 @@ "ansi-regex": "^5.0.1", "chalk": "^2.4.1", "cheerio": "^1.0.0-rc.6", - "cosmiconfig": "^7.0.1", "fast-xml-parser": "^3.12.13", "glob": "^7.1.2", "htmlparser2": "^3.9.1", From b63a829d48033ebc9794a12cd657db500e74046f Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Fri, 3 Dec 2021 21:32:13 +0100 Subject: [PATCH 11/23] refactor: simplify dynamic imports Change from the approach in 033d7db98348fab795cff983c9ad5ea6e060990c and replace the try-catch technique of importing by just using `await import`. From some local testing it seems only that one is ever used, making the catch branch effectively dead code. Additionally, this fixes a bug introduced in 1e4eb075c050896486e58d377dd4ed7425087bb2 where CJS config files were imported but ignored since CJS is always `import`ed on the default property. --- bin/cli.js | 7 ++----- src/lib/rule-loader.js | 8 ++------ 2 files changed, 4 insertions(+), 11 deletions(-) diff --git a/bin/cli.js b/bin/cli.js index 412d118..79d5d47 100755 --- a/bin/cli.js +++ b/bin/cli.js @@ -62,11 +62,8 @@ process.on("exit", () => { try { const configFile = await getConfigurationFile(cli.flags.config); if (configFile) { - try { - configObj = await import(configFile); - } catch(_) { - configObj = require(configFile); - } + const module = await import(configFile); + configObj = module.default; } else { logger.debug("No configuration file found") if (cli.flags.config) { diff --git a/src/lib/rule-loader.js b/src/lib/rule-loader.js index 2e7a64e..9db3066 100644 --- a/src/lib/rule-loader.js +++ b/src/lib/rule-loader.js @@ -29,11 +29,7 @@ async function ruleLoader(ruleName, dir="../rules") { const importPath = isExternal ? "svglint-plugin-" + ruleName : path.join(dir, fileName); - try { - const module = await import(importPath); - return module.default; - } catch(_) { - return require(importPath); - } + const module = await import(importPath); + return module.default; } export default ruleLoader; From e8db954eeb3fcd72e7de75ce9a14a11d5d375b91 Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Fri, 3 Dec 2021 21:36:41 +0100 Subject: [PATCH 12/23] docs: update config example to use ESM syntax --- README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index b03277d..e3c770c 100644 --- a/README.md +++ b/README.md @@ -51,7 +51,7 @@ If you are using the CLI, this configuration object is read from the file specif This configuration file should export a single object, of the format: ```javascript -module.exports = { +export default { // additional configuration may go here in the future // for now, "rules" is the only useful key rules: { @@ -67,7 +67,7 @@ module.exports = { function() { // config 1 for the "custom" rule } ] } -}; +} ``` For specifics on how the config for each rule should be formatted, see [their specific rule files](https://github.com/birjolaxew/svglint/tree/master/src/rules). From 31d582f8fdf098954cb753bcd7ef16593b4890bb Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Fri, 3 Dec 2021 21:41:26 +0100 Subject: [PATCH 13/23] ci: run tests on Node v12, v14, and v16 --- .github/workflows/test.yml | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index ae62778..f88f45b 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -5,6 +5,9 @@ jobs: test: name: Run tests runs-on: ubuntu-18.04 + strategy: + matrix: + node-version: [12, 14, 16] steps: - name: Checkout uses: actions/checkout@v2 @@ -13,7 +16,7 @@ jobs: - name: Node.js setup uses: actions/setup-node@v1 with: - node-version: 12 + node-version: ${{ matrix.node-version }} - name: Install dependencies run: npm ci - name: Lint From 404fa2c343e724a58864375e41420d52a0780bb7 Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Sat, 4 Dec 2021 12:15:40 +0100 Subject: [PATCH 14/23] chore: adjust minimum v12 version to 12.17.0 As 12.17 is the minimum required version for ESM support. 12.20 is the minimum required version if you want to use the `node:` protocol [1], which this project doesn't at the moment. -- 1. https://nodejs.org/api/esm.html#node-imports --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index cad018c..685eed6 100644 --- a/package.json +++ b/package.json @@ -39,7 +39,7 @@ "mocha": "^8.1.3" }, "engines": { - "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + "node": "^12.17.0 || ^14.13.1 || >=16.0.0" }, "config": { "commitizen": { From 6c8d97fbf2002affdc3f8a711088c176233a61fc Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Sat, 4 Dec 2021 12:18:23 +0100 Subject: [PATCH 15/23] ci: run tests on specific NodeJS versions rather then latest 12/14/16 --- .github/workflows/test.yml | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index f88f45b..30ea81c 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -7,7 +7,10 @@ jobs: runs-on: ubuntu-18.04 strategy: matrix: - node-version: [12, 14, 16] + node-version: + - 12.17.0 + - 14.13.1 + - 16.0.0 steps: - name: Checkout uses: actions/checkout@v2 From 8db814737b06d8d9095fdef5bf1850b50eada4a6 Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Sat, 4 Dec 2021 12:23:28 +0100 Subject: [PATCH 16/23] revert: 404fa2c343e724a58864375e41420d52a0780bb7 --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 685eed6..cad018c 100644 --- a/package.json +++ b/package.json @@ -39,7 +39,7 @@ "mocha": "^8.1.3" }, "engines": { - "node": "^12.17.0 || ^14.13.1 || >=16.0.0" + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" }, "config": { "commitizen": { From 9783e5eab0205691fe12456000c0b30523c6f993 Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Sun, 12 Dec 2021 18:54:23 +0100 Subject: [PATCH 17/23] chore: make svglint config file an ESM --- .svglintrc.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.svglintrc.js b/.svglintrc.js index 53b97f1..23edc41 100644 --- a/.svglintrc.js +++ b/.svglintrc.js @@ -1,4 +1,4 @@ -module.exports = { +export default { rules: { attr: { "rule::selector": "path", From 83149e75afe174c3acfc2ffd8600efc126dde351 Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Sun, 12 Dec 2021 18:54:49 +0100 Subject: [PATCH 18/23] ci: update node-versions --- .github/workflows/test.yml | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 30ea81c..41ea4ec 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -8,9 +8,13 @@ jobs: strategy: matrix: node-version: - - 12.17.0 + - 12.20.0 - 14.13.1 - 16.0.0 + - 12 + - 14 + - 16 + - 17 steps: - name: Checkout uses: actions/checkout@v2 From bf071347c8c5f5e32759671cf1369c53b6c7f10c Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Sun, 12 Dec 2021 20:08:05 +0100 Subject: [PATCH 19/23] chore: remove unnecessary semicolons --- src/cli/components/linting.js | 2 +- src/cli/components/log.js | 2 +- src/cli/components/separator.js | 2 +- src/cli/components/spinner.js | 2 +- src/cli/components/summary.js | 2 +- 5 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/cli/components/linting.js b/src/cli/components/linting.js index 05c72f3..a7dd9e0 100644 --- a/src/cli/components/linting.js +++ b/src/cli/components/linting.js @@ -81,7 +81,7 @@ export default class LintingDisplay { return this.renderHeader() + this.renderReporters(); } -}; +} class ReporterDisplay { constructor(reporter) { diff --git a/src/cli/components/log.js b/src/cli/components/log.js index b0112cc..b203012 100644 --- a/src/cli/components/log.js +++ b/src/cli/components/log.js @@ -34,4 +34,4 @@ export default class Log { + message; }).join("\n"); } -}; +} diff --git a/src/cli/components/separator.js b/src/cli/components/separator.js index 86d0cd8..8b77092 100644 --- a/src/cli/components/separator.js +++ b/src/cli/components/separator.js @@ -13,4 +13,4 @@ export default class Separator { )); return `${padding} ${chalk.bold.underline(this.title)} ${padding}`; } -}; +} diff --git a/src/cli/components/spinner.js b/src/cli/components/spinner.js index 50a786a..a84783f 100644 --- a/src/cli/components/spinner.js +++ b/src/cli/components/spinner.js @@ -12,4 +12,4 @@ export default class Spinner { this.i = (this.i + 1) % this.frames.length; return this.frames[this.i]; } -}; +} diff --git a/src/cli/components/summary.js b/src/cli/components/summary.js index f76817e..edea370 100644 --- a/src/cli/components/summary.js +++ b/src/cli/components/summary.js @@ -40,4 +40,4 @@ export default class Summary { (active + successes + warns + errors) ? null : chalk.gray.dim("- No files linted"), ].filter(v => v).join("\n"); } -}; +} From 6980c10038132824b4000dde4d49d7209ea5f5f0 Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Tue, 14 Dec 2021 21:17:16 +0100 Subject: [PATCH 20/23] fix: loading config files and built-in rules on Windows Use the `"file://"` prefix when loading CLI config and rules to ensure importing always works on Windows. --- bin/cli.js | 2 +- src/lib/rule-loader.js | 4 +++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/bin/cli.js b/bin/cli.js index 79d5d47..c5b2efa 100755 --- a/bin/cli.js +++ b/bin/cli.js @@ -62,7 +62,7 @@ process.on("exit", () => { try { const configFile = await getConfigurationFile(cli.flags.config); if (configFile) { - const module = await import(configFile); + const module = await import(`file://${configFile}`); configObj = module.default; } else { logger.debug("No configuration file found") diff --git a/src/lib/rule-loader.js b/src/lib/rule-loader.js index 9db3066..3b72be3 100644 --- a/src/lib/rule-loader.js +++ b/src/lib/rule-loader.js @@ -5,6 +5,7 @@ * Currently NodeJS' import cache is just fine. */ import path from "path"; +import { fileURLToPath } from "url"; /** * @typedef RuleModule @@ -22,13 +23,14 @@ import path from "path"; * @returns {Promise} Resolves to the function exported by the rule if found. */ async function ruleLoader(ruleName, dir="../rules") { + const __dirname = path.dirname(fileURLToPath(import.meta.url)); const fileName = ruleName.endsWith(".js") ? ruleName : ruleName + ".js"; const isExternal = ruleName.includes("/"); const importPath = isExternal ? "svglint-plugin-" + ruleName - : path.join(dir, fileName); + : `file://${path.resolve(__dirname, dir, fileName)}`; const module = await import(importPath); return module.default; } From b67761bde2599357595f1551c082f60322ef4bd8 Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Tue, 14 Dec 2021 21:23:57 +0100 Subject: [PATCH 21/23] ci: run CLI on various node versions and operating systems --- .github/workflows/test.yml | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 41ea4ec..7ef9850 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -30,3 +30,24 @@ jobs: run: npm run lint - name: Test run: npm test + - name: Run CLI + run: node ./bin/cli.js test/svgs/attr.test.svg + test-cli: + name: Run CLI + runs-on: ${{ matrix.os }} + strategy: + matrix: + os: [macos-latest, ubuntu-latest, windows-latest] + steps: + - name: Checkout + uses: actions/checkout@v2 + with: + fetch-depth: 0 + - name: Node.js setup + uses: actions/setup-node@v1 + with: + node-version: 16 + - name: Install dependencies + run: npm ci + - name: Run CLI + run: node ./bin/cli.js test/svgs/attr.test.svg \ No newline at end of file From f3e91a1069190fd70147707068751924f209b3f0 Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Tue, 14 Dec 2021 22:37:46 +0100 Subject: [PATCH 22/23] feat: add CJS version of Node API Add a CommonJS version of the Node API of SVGLint by building it using Rollup [1]. Update the package manifest to allow for importing/requiring ESM and CJS (resp.) and `.gitignore` to ignore the generated CJS file. One "custom" Rollup plugin (provided by Rollup but not included by default) is used, namely `plugin-dynamic-import-vars` [2]. This plugin ensures that dynamic imports are properly handled as the CJS output generated by Rollup cannot dynamically import ESM rules. To make this work the rule-loader had to be updated as well, unfortunately the requirements of this plugin are quite strict and it is required that the `"../rules"` path is hardcoded into the `import` statement. Furthermore it has trouble detecting things that should be ignored, so errors are disabled to prevent errors due to dynamic imports of external plugins. -- 1. https://rollupjs.org/guide/en/ 2. https://www.npmjs.com/package/@rollup/plugin-dynamic-import-vars --- .gitignore | 1 + package-lock.json | 197 ++++++++++++++++++++++++++++++++++++++++- package.json | 14 ++- rollup.config.js | 27 ++++++ src/lib/rule-loader.js | 16 ++-- 5 files changed, 242 insertions(+), 13 deletions(-) create mode 100644 rollup.config.js diff --git a/.gitignore b/.gitignore index 76efb07..36bb06a 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1,3 @@ node_modules .vscode +src/svglint.cjs diff --git a/package-lock.json b/package-lock.json index ec95a76..98e67f5 100644 --- a/package-lock.json +++ b/package-lock.json @@ -194,12 +194,75 @@ "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", "dev": true }, + "@nodelib/fs.scandir": { + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", + "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", + "dev": true, + "requires": { + "@nodelib/fs.stat": "2.0.5", + "run-parallel": "^1.1.9" + } + }, + "@nodelib/fs.stat": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", + "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", + "dev": true + }, + "@nodelib/fs.walk": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", + "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", + "dev": true, + "requires": { + "@nodelib/fs.scandir": "2.1.5", + "fastq": "^1.6.0" + } + }, + "@rollup/plugin-dynamic-import-vars": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/@rollup/plugin-dynamic-import-vars/-/plugin-dynamic-import-vars-1.4.1.tgz", + "integrity": "sha512-izHpMs9w8U8CLwyHTXE55H4ytGVaf2ZtlKIWxKigghw6ZC6Mx6AXCsixSY6JOchuX9BN4ZkeN8egLRTS+BxO+w==", + "dev": true, + "requires": { + "@rollup/pluginutils": "^3.1.0", + "estree-walker": "^2.0.1", + "globby": "^11.0.1", + "magic-string": "^0.25.7" + } + }, + "@rollup/pluginutils": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-3.1.0.tgz", + "integrity": "sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg==", + "dev": true, + "requires": { + "@types/estree": "0.0.39", + "estree-walker": "^1.0.1", + "picomatch": "^2.2.2" + }, + "dependencies": { + "estree-walker": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-1.0.1.tgz", + "integrity": "sha512-1fMXF3YP4pZZVozF8j/ZLfvnR8NSIljt56UhbZ5PeeDmmGHpgpdwQt7ITlGvYaQukCvuBRMLEiKiYC+oeIg4cg==", + "dev": true + } + } + }, "@types/color-name": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", "dev": true }, + "@types/estree": { + "version": "0.0.39", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", + "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==", + "dev": true + }, "@types/minimist": { "version": "1.2.2", "resolved": "https://registry.npmjs.org/@types/minimist/-/minimist-1.2.2.tgz", @@ -284,6 +347,12 @@ "sprintf-js": "~1.0.2" } }, + "array-union": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", + "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", + "dev": true + }, "array.prototype.map": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/array.prototype.map/-/array.prototype.map-1.0.2.tgz", @@ -1012,6 +1081,15 @@ "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", "dev": true }, + "dir-glob": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", + "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", + "dev": true, + "requires": { + "path-type": "^4.0.0" + } + }, "doctrine": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", @@ -1447,6 +1525,12 @@ "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", "dev": true }, + "estree-walker": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz", + "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==", + "dev": true + }, "esutils": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", @@ -1493,6 +1577,19 @@ "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", "dev": true }, + "fast-glob": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.7.tgz", + "integrity": "sha512-rYGMRwip6lUMvYD3BTScMwT1HtAs2d71SMv66Vrxs0IekGZEjhM0pcMfjQPnknBt2zeCwQMEupiN02ZP4DiT1Q==", + "dev": true, + "requires": { + "@nodelib/fs.stat": "^2.0.2", + "@nodelib/fs.walk": "^1.2.3", + "glob-parent": "^5.1.2", + "merge2": "^1.3.0", + "micromatch": "^4.0.4" + } + }, "fast-json-stable-stringify": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", @@ -1513,6 +1610,15 @@ "nimnjs": "^1.3.2" } }, + "fastq": { + "version": "1.13.0", + "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.13.0.tgz", + "integrity": "sha512-YpkpUnK8od0o1hmeSc7UUs/eB/vIPWJYjKck2QKIzAf71Vm1AAQ3EbuZB3g2JIy+pg+ERD0vqI79KyZiB2e2Nw==", + "dev": true, + "requires": { + "reusify": "^1.0.4" + } + }, "figures": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", @@ -1738,6 +1844,28 @@ } } }, + "globby": { + "version": "11.0.4", + "resolved": "https://registry.npmjs.org/globby/-/globby-11.0.4.tgz", + "integrity": "sha512-9O4MVG9ioZJ08ffbcyVYyLOJLk5JQ688pJ4eMGLpdWLHq/Wr1D9BlriLQyL0E+jbkuePVZXYFj47QM/v093wHg==", + "dev": true, + "requires": { + "array-union": "^2.1.0", + "dir-glob": "^3.0.1", + "fast-glob": "^3.1.1", + "ignore": "^5.1.4", + "merge2": "^1.3.0", + "slash": "^3.0.0" + }, + "dependencies": { + "ignore": { + "version": "5.1.9", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.1.9.tgz", + "integrity": "sha512-2zeMQpbKz5dhZ9IwL0gbxSW5w0NK/MSAMtNuhgIHEPmaU3vPdKPL0UdvUCXs5SS4JAwsBxysK5sFMW8ocFiVjQ==", + "dev": true + } + } + }, "graceful-fs": { "version": "4.1.11", "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", @@ -2257,6 +2385,15 @@ "yallist": "^4.0.0" } }, + "magic-string": { + "version": "0.25.7", + "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.7.tgz", + "integrity": "sha512-4CrMT5DOHTDk4HYDlzmwu4FVCcIYI8gauveasrdCu2IKIFOJ3f0v/8MDGJCDL9oD2ppz/Av1b0Nj345H9M+XIA==", + "dev": true, + "requires": { + "sourcemap-codec": "^1.4.4" + } + }, "map-obj": { "version": "4.3.0", "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-4.3.0.tgz", @@ -2294,6 +2431,12 @@ "integrity": "sha512-jz+Cfrg9GWOZbQAnDQ4hlVnQky+341Yk5ru8bZSe6sIDTCIg8n9i/u7hSQGSVOF3C7lH6mGtqjkiT9G4wFLL0w==", "dev": true }, + "merge2": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", + "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", + "dev": true + }, "micromatch": { "version": "4.0.4", "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", @@ -2851,8 +2994,7 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", - "dev": true, - "optional": true + "dev": true }, "picomatch": { "version": "2.2.2", @@ -2988,6 +3130,12 @@ "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", "dev": true }, + "queue-microtask": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", + "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", + "dev": true + }, "quick-lru": { "version": "5.1.1", "resolved": "https://registry.npmjs.org/quick-lru/-/quick-lru-5.1.1.tgz", @@ -3108,6 +3256,12 @@ "signal-exit": "^3.0.2" } }, + "reusify": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", + "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", + "dev": true + }, "rimraf": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", @@ -3133,6 +3287,24 @@ } } }, + "rollup": { + "version": "2.61.1", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.61.1.tgz", + "integrity": "sha512-BbTXlEvB8d+XFbK/7E5doIcRtxWPRiqr0eb5vQ0+2paMM04Ye4PZY5nHOQef2ix24l/L0SpLd5hwcH15QHPdvA==", + "dev": true, + "requires": { + "fsevents": "~2.3.2" + }, + "dependencies": { + "fsevents": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", + "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", + "dev": true, + "optional": true + } + } + }, "run-async": { "version": "2.3.0", "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", @@ -3142,6 +3314,15 @@ "is-promise": "^2.1.0" } }, + "run-parallel": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", + "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", + "dev": true, + "requires": { + "queue-microtask": "^1.2.2" + } + }, "rxjs": { "version": "6.4.0", "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.4.0.tgz", @@ -3205,6 +3386,18 @@ "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" }, + "slash": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", + "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", + "dev": true + }, + "sourcemap-codec": { + "version": "1.4.8", + "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", + "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", + "dev": true + }, "spdx-correct": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", diff --git a/package.json b/package.json index cad018c..998bf37 100644 --- a/package.json +++ b/package.json @@ -3,7 +3,14 @@ "version": "1.0.5", "description": "Linter for SVGs", "type": "module", - "exports": "./src/svglint.js", + "exports": { + ".": { + "module": "./src/svglint.js", + "import": "./src/svglint.js", + "require": "./src/svglint.cjs", + "default": "./src/svglint.cjs" + } + }, "bin": { "svglint": "./bin/cli.js" }, @@ -18,6 +25,7 @@ "license": "MIT", "scripts": { "lint": "eslint src/**/*.js test/**/*.js", + "prepublishOnly": "rollup -c", "test": "mocha" }, "dependencies": { @@ -32,11 +40,13 @@ "strip-ansi": "^4.0.0" }, "devDependencies": { + "@rollup/plugin-dynamic-import-vars": "^1.4.1", "commitizen": "^4.2.4", "cz-conventional-changelog": "^3.3.0", "eslint": "^8.3.0", "expect": "^1.20.2", - "mocha": "^8.1.3" + "mocha": "^8.1.3", + "rollup": "^2.61.1" }, "engines": { "node": "^12.20.0 || ^14.13.1 || >=16.0.0" diff --git a/rollup.config.js b/rollup.config.js new file mode 100644 index 0000000..05175fb --- /dev/null +++ b/rollup.config.js @@ -0,0 +1,27 @@ +import dynamicImportVars from "@rollup/plugin-dynamic-import-vars"; + +const pkg = require("./package.json"); + +export default { + input: "./src/svglint.js", + output: { + exports: "auto", + file: "./src/svglint.cjs", + format: "cjs", + inlineDynamicImports: true, + }, + external: [ + "events", + "fs", + "path", + "util", + "url", + ...Object.keys(pkg.dependencies || {}), + ...Object.keys(pkg.peerDependencies || {}), + ], + plugins: [ + dynamicImportVars({ + warnOnError: true, // Disables errors caused by dynamic import of plugins + }) + ] +}; diff --git a/src/lib/rule-loader.js b/src/lib/rule-loader.js index 3b72be3..b4ce1d5 100644 --- a/src/lib/rule-loader.js +++ b/src/lib/rule-loader.js @@ -4,8 +4,6 @@ * loading a rule. * Currently NodeJS' import cache is just fine. */ -import path from "path"; -import { fileURLToPath } from "url"; /** * @typedef RuleModule @@ -19,19 +17,19 @@ import { fileURLToPath } from "url"; * If the rule name does not contain a slash then it will be loaded from the * built-in SVGLint rules. * @param {String} ruleName The name of the rule - * @param {String} [dir] The dir to load the rules from if not from a package * @returns {Promise} Resolves to the function exported by the rule if found. */ -async function ruleLoader(ruleName, dir="../rules") { - const __dirname = path.dirname(fileURLToPath(import.meta.url)); +async function ruleLoader(ruleName) { const fileName = ruleName.endsWith(".js") ? ruleName : ruleName + ".js"; const isExternal = ruleName.includes("/"); - const importPath = isExternal - ? "svglint-plugin-" + ruleName - : `file://${path.resolve(__dirname, dir, fileName)}`; - const module = await import(importPath); + let module; + if (isExternal) { + module = await import(`svglint-plugin-${ruleName}`); + } else { + module = await import(`../rules/${fileName.slice(0, -3)}.js`); + } return module.default; } export default ruleLoader; From 047242bed22c8b16c796d3f3eb650e80967bd119 Mon Sep 17 00:00:00 2001 From: Eric Cornelissen Date: Wed, 15 Dec 2021 21:13:03 +0100 Subject: [PATCH 23/23] chore: add .npmrc to enforce `engine-strict` option --- .npmrc | 1 + 1 file changed, 1 insertion(+) create mode 100644 .npmrc diff --git a/.npmrc b/.npmrc new file mode 100644 index 0000000..b6f27f1 --- /dev/null +++ b/.npmrc @@ -0,0 +1 @@ +engine-strict=true