Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(deps): bump eslint-plugin-compat from 3.13.0 to 4.0.0 #1008

Merged
merged 1 commit into from
Nov 19, 2021

Conversation

dependabot[bot]
Copy link
Contributor

@dependabot dependabot bot commented on behalf of github Nov 19, 2021

Bumps eslint-plugin-compat from 3.13.0 to 4.0.0.

Release notes

Sourced from eslint-plugin-compat's releases.

v4.0.0

  • Add version 8 to the peer dependencies for ESLint (#495) 0bf4751
  • chore: migrate to npm (#494) 286b9b6

amilajack/eslint-plugin-compat@v4.0.0-0...v4.0.0

v4.0.0-0

  • feat: eslint@8 support (#489) b1b9306
  • chore(dev-deps): add eslint-plugin-eslint-plugin (#491) 372fd9b

amilajack/eslint-plugin-compat@v3.13.0...v4.0.0-0

Changelog

Sourced from eslint-plugin-compat's changelog.

v3.8.0

Added

  • Support for feature detection of APIs (#327)
  • Implement expected behavior when defining targets in eslintrc and browserslist (this might be deprecated in the future)

Internal

  • Migrated from Flow to Typescript
  • Created performance benchmarks of popular repositories
  • Create E2E linting tests
  • Internal refactors

v3.7.0

Updates

  • Allow ESLint peerDependency version 7.0.0

Fixed

  • Fixed many bugs reporting incorrect linter errors

v3.6.0

Fixed

  • Update dependencies
  • Remove fixable and add meta.type (305)

v3.5.1

Fixed

  • Support Safari TP as a target (#285)

v3.5.0

Fixed

  • Allow targets not caniuse db (#280
  • Added missing browser mapping and default fallback (#272)
  • Support Node >=8 (#281)

Added

  • Bump all deps to latest semver

v3.4.0

Added

  • Add schema to support browserlist as a second paramenter in eslintrc (#265)
  • Bumped all dependencies to latest semver

v3.3.0

... (truncated)

Commits

Dependabot compatibility score

Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.


Dependabot commands and options

You can trigger Dependabot actions by commenting on this PR:

  • @dependabot rebase will rebase this PR
  • @dependabot recreate will recreate this PR, overwriting any edits that have been made to it
  • @dependabot merge will merge this PR after your CI passes on it
  • @dependabot squash and merge will squash and merge this PR after your CI passes on it
  • @dependabot cancel merge will cancel a previously requested merge and block automerging
  • @dependabot reopen will reopen this PR if it is closed
  • @dependabot close will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually
  • @dependabot ignore this major version will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)
  • @dependabot ignore this minor version will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)
  • @dependabot ignore this dependency will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)

@dependabot dependabot bot added dependencies Pull requests that update a dependency file javascript Pull requests that update Javascript code labels Nov 19, 2021
@dependabot dependabot bot force-pushed the dependabot/npm_and_yarn/eslint-plugin-compat-4.0.0 branch 3 times, most recently from 08c6535 to 772ac17 Compare November 19, 2021 16:00
@ybiquitous ybiquitous self-assigned this Nov 19, 2021
Bumps [eslint-plugin-compat](https://github.com/amilajack/eslint-plugin-compat) from 3.13.0 to 4.0.0.
- [Release notes](https://github.com/amilajack/eslint-plugin-compat/releases)
- [Changelog](https://github.com/amilajack/eslint-plugin-compat/blob/main/CHANGELOG.md)
- [Commits](amilajack/eslint-plugin-compat@v3.13.0...v4.0.0)

---
updated-dependencies:
- dependency-name: eslint-plugin-compat
  dependency-type: direct:production
  update-type: version-update:semver-major
...

Signed-off-by: dependabot[bot] <support@github.com>
@ybiquitous
Copy link
Owner

@dependabot rebase

@dependabot dependabot bot force-pushed the dependabot/npm_and_yarn/eslint-plugin-compat-4.0.0 branch from 772ac17 to 7145bd4 Compare November 19, 2021 16:19
@dependabot @github
Copy link
Contributor Author

dependabot bot commented on behalf of github Nov 19, 2021

Looks like this PR is already up-to-date with main! If you'd still like to recreate it from scratch, overwriting any edits, you can request @dependabot recreate.

@github-actions
Copy link
Contributor

npm diff --diff=eslint-plugin-compat@3.13.0 --diff=eslint-plugin-compat@4.0.0 --diff-unified=2
diff --git a/CHANGELOG.md b/CHANGELOG.md
deleted file mode 100644
index v3.13.0..v4.0.0 
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,154 +0,0 @@
-# v3.8.0
-
-### Added
-- Support for feature detection of APIs ([#327](https://github.com/amilajack/eslint-plugin-compat/pull/327))
-- Implement expected behavior when defining targets in `eslintrc` and `browserslist` (this might be deprecated in the future)
-
-### Internal
-- Migrated from Flow to Typescript
-- Created performance benchmarks of popular repositories
-- Create E2E linting tests
-- Internal refactors
-
-# v3.7.0
-
-### Updates
-
-- Allow ESLint `peerDependency` version `7.0.0`
-
-### Fixed
-- Fixed many bugs reporting incorrect linter errors
-
-# v3.6.0
-
-### Fixed
-- Update dependencies
-- Remove `fixable` and add `meta.type` ([305](https://github.com/amilajack/eslint-plugin-compat/pull/305))
-
-# v3.5.1
-
-### Fixed
-- Support Safari TP as a target ([#285](https://github.com/amilajack/eslint-plugin-compat/pull/285))
-
-# v3.5.0
-
-### Fixed
-- Allow targets not caniuse db ([#280](https://github.com/amilajack/eslint-plugin-compat/pull/280)
-- Added missing browser mapping and default fallback ([#272](https://github.com/amilajack/eslint-plugin-compat/pull/272))
-- Support Node >=8 ([#281](https://github.com/amilajack/eslint-plugin-compat/pull/281))
-
-### Added
-- Bump all deps to latest semver
-
-# v3.4.0
-
-### Added
-- Add schema to support browserlist as a second paramenter in eslintrc ([#265](https://github.com/amilajack/eslint-plugin-compat/pull/265))
-- Bumped all dependencies to latest semver
-
-# v3.3.0
-
-### Performance
-- Filter and sort rules before node traversal ([https://github.com/amilajack/eslint-plugin-compat/pull/246](https://github.com/amilajack/eslint-plugin-compat/pull/246))
-- Optimize core loop to run ~50% faster ([https://github.com/amilajack/eslint-plugin-compat/pull/245](https://github.com/amilajack/eslint-plugin-compat/pull/245))
-
-# v3.2.0
-
-### Added
-- Support for `eslint@6`
-
-# v3.1.2
-
-### Fixed
-- Remove npm restriction from engines
-
-# v3.1.1
-
-### Fixed
-- Resolving browserslist config correctly despite being called from a cwd that is not the root of the project. (#217)
-
-# v3.1.0
-
-### Added
-- Support detecting locally defined polyfills (#207)  bb3be6e
-
-# v3.0.2
-
-### Fixed
-- Handle entire API polyfill case (#190)  e784b3d
-
-# v3.0.1
-
-### Fixed
-- Bug when returning unsupported when mdn compat data has null record
-
-# v3.0.0
-
-### Added
-- Support for ~4000 JS API's using [ast-metadata-inferer](https://github.com/amilajack/ast-metadata-inferer)
-
-### Deprecated
-- Using caniuse id's for polyfills is no longer supported
-
-# v2.7.0
-
-### Added
-- `Object.values()` support
-
-# v2.6.1
-
-### Fixed
-- Removed `console.log` statement
-
-# v2.4.0
-
-### Updated
-- Updated all deps to latest semver
-### Fixed
-- Fixed recommendation config
-
-# v2.3.0
-
-### Updated
-- Updated browserslist
-
-# v2.2.0
-
-### Updated
-- Bumped all dependencies to latest semver
-
-# v2.1.0
-
-### Added
-- Promise support
-
-# v2.0.1
-
-### Fixed
-- Corrected incorrect babel exports config that prevented plugin from being loaded
-
-# v2.0.0
-
-### Updated
-- Bumped all dependencies to latest semver
-
-### Infra
-- Removed boilerplate from `.eslintrc`
-- Run CI against node 8
-- Removed flow-typed definitions
-- Updated tests to reflect dependency changes
-
-# v1.0.4
-
-### Fixed
-- Required `peerDependency` of `eslint>=4.0.0`
-
-# v1.0.3
-
-### Updated
-- Bumped all dependencies to latest semver
-
-# v1.0.2
-
-### Added
-- Range implementation
\ No newline at end of file
diff --git a/README.md b/README.md
index v3.13.0..v4.0.0 100644
--- a/README.md
+++ b/README.md
@@ -2,8 +2,9 @@
 =====================
 [![Build Status](https://dev.azure.com/amilajack/amilajack/_apis/build/status/amilajack.eslint-plugin-compat?branchName=master)](https://dev.azure.com/amilajack/amilajack/_build/latest?definitionId=7&branchName=master)
-[![Financial Contributors on Open Collective](https://opencollective.com/eslint-plugin-compat/all/badge.svg?label=financial+contributors)](https://opencollective.com/eslint-plugin-compat) [![NPM version](https://badge.fury.io/js/eslint-plugin-compat.svg)](http://badge.fury.io/js/eslint-plugin-compat)
-[![Dependency Status](https://img.shields.io/david/amilajack/eslint-plugin-compat.svg)](https://david-dm.org/amilajack/eslint-plugin-compat)
+[![Financial Contributors on Open Collective](https://opencollective.com/eslint-plugin-compat/all/badge.svg?label=financial+contributors)](https://opencollective.com/eslint-plugin-compat)
+[![NPM version](https://badge.fury.io/js/eslint-plugin-compat.svg)](http://badge.fury.io/js/eslint-plugin-compat)
 [![npm](https://img.shields.io/npm/dm/eslint-plugin-compat.svg)](https://npm-stat.com/charts.html?package=eslint-plugin-compat)
-[![Backers on Open Collective](https://opencollective.com/eslint-plugin-compat/backers/badge.svg)](#backers) [![Sponsors on Open Collective](https://opencollective.com/eslint-plugin-compat/sponsors/badge.svg)](#sponsors)
+[![Backers on Open Collective](https://opencollective.com/eslint-plugin-compat/backers/badge.svg)](#backers)
+[![Sponsors on Open Collective](https://opencollective.com/eslint-plugin-compat/sponsors/badge.svg)](#sponsors)
 
 Lint the browser compatibility of your code
diff --git a/package.json b/package.json
index v3.13.0..v4.0.0 100644
--- a/package.json
+++ b/package.json
@@ -1,126 +1,127 @@
 {
-    "name": "eslint-plugin-compat",
-    "version": "3.13.0",
-    "description": "Lint browser compatibility of API used",
-    "main": "lib/index.js",
-    "repository": {
-        "type": "git",
-        "url": "git+https://github.com/amilajack/eslint-plugin-compat.git"
-    },
-    "keywords": [
-        "eslint",
-        "browser",
-        "support",
-        "api",
-        "lint",
-        "caniuse",
-        "kangax"
-    ],
-    "author": "Amila Welihinda",
-    "contributors": [
-        "Amila Welihinda <amilajack@gmail.com> (https://github.com/amilajack)",
-        "John Tran <jptran318@gmail.com> (https://github.com/jooohhn)"
-    ],
-    "license": "MIT",
-    "bugs": {
-        "url": "https://github.com/amilajack/eslint-plugin-compat/issues"
-    },
-    "files": [
-        "lib"
-    ],
-    "homepage": "https://github.com/amilajack/eslint-plugin-compat#readme",
-    "scripts": {
-        "benchmarks": "ts-node-transpile-only test/benchmarks.ts",
-        "build": "rm -rf lib && babel src --out-dir lib --source-maps inline --extensions '.ts'",
-        "lint": "eslint --ignore-path .gitignore --ext .js,.ts .",
-        "spec": "jest --testPathIgnorePatterns test/e2e-repo.spec.ts /benchmarks-tmp",
-        "spec:e2e": "jest test/e2e-repo.spec.ts",
-        "test": "yarn lint && yarn build && yarn spec",
-        "tsc": "tsc",
-        "version": "yarn build"
-    },
-    "jest": {
-        "testEnvironment": "node",
-        "testPathIgnorePatterns": [
-            "/benchmarks-tmp/"
-        ]
-    },
-    "devDependencies": {
-        "@babel/cli": "^7.14.8",
-        "@babel/core": "^7.15.0",
-        "@babel/preset-env": "^7.15.0",
-        "@babel/preset-typescript": "^7.15.0",
-        "@semantic-release/changelog": "^5.0.1",
-        "@semantic-release/git": "^9.0.0",
-        "@types/benchmark": "^2.1.1",
-        "@types/browserslist": "^4.15.0",
-        "@types/caniuse-lite": "^1.0.1",
-        "@types/eslint": "^7.28.0",
-        "@types/jest": "^27.0.1",
-        "@types/lodash.memoize": "^4.1.6",
-        "@types/semver": "^7.3.8",
-        "@typescript-eslint/eslint-plugin": "^4.29.2",
-        "@typescript-eslint/parser": "^4.29.2",
-        "benchmark": "^2.1.4",
-        "browserslist-config-erb": "^0.0.1",
-        "electron": "^13.2.1",
-        "eslint": "^7.32.0",
-        "eslint-config-airbnb-typescript": "^12.3.1",
-        "eslint-config-bliss": "^5.0.0",
-        "eslint-config-prettier": "^8.3.0",
-        "eslint-plugin-import": "^2.24.0",
-        "eslint-plugin-prettier": "^3.4.0",
-        "jest": "^27.0.6",
-        "prettier": "^2.3.2",
-        "semantic-release": "^17.4.5",
-        "simple-git": "^2.44.0",
-        "ts-node": "^10.2.1",
-        "typescript": "^4.3.5"
-    },
-    "prettier": {
-        "trailingComma": "es5",
-        "tabWidth": 2,
-        "semi": true
-    },
-    "dependencies": {
-        "@mdn/browser-compat-data": "^3.3.14",
-        "ast-metadata-inferer": "^0.7.0",
-        "browserslist": "^4.16.8",
-        "caniuse-lite": "^1.0.30001251",
-        "core-js": "^3.16.2",
-        "find-up": "^5.0.0",
-        "lodash.memoize": "4.1.2",
-        "semver": "7.3.5"
-    },
-    "peerDependencies": {
-        "eslint": "^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0"
-    },
-    "engines": {
-        "node": ">=9.x"
-    },
-    "collective": {
-        "type": "opencollective",
-        "url": "https://opencollective.com/eslint-plugin-compat",
-        "logo": "https://opencollective.com/opencollective/logo.txt"
-    },
-    "babel": {
-        "presets": [
-            [
-                "@babel/preset-env",
-                {
-                    "useBuiltIns": "usage",
-                    "corejs": 3,
-                    "targets": {
-                        "node": 10
-                    }
-                }
-            ],
-            "@babel/preset-typescript"
-        ]
-    },
-    "renovate": {
-        "extends": [
-            "bliss"
-        ]
-    }
+  "name": "eslint-plugin-compat",
+  "version": "4.0.0",
+  "description": "Lint browser compatibility of API used",
+  "main": "lib/index.js",
+  "repository": {
+    "type": "git",
+    "url": "git+https://github.com/amilajack/eslint-plugin-compat.git"
+  },
+  "keywords": [
+    "eslint",
+    "browser",
+    "support",
+    "api",
+    "lint",
+    "caniuse",
+    "kangax"
+  ],
+  "author": "Amila Welihinda",
+  "contributors": [
+    "Amila Welihinda <amilajack@gmail.com> (https://github.com/amilajack)",
+    "John Tran <jptran318@gmail.com> (https://github.com/jooohhn)"
+  ],
+  "license": "MIT",
+  "bugs": {
+    "url": "https://github.com/amilajack/eslint-plugin-compat/issues"
+  },
+  "files": [
+    "lib"
+  ],
+  "homepage": "https://github.com/amilajack/eslint-plugin-compat#readme",
+  "scripts": {
+    "benchmarks": "ts-node-transpile-only test/benchmarks.ts",
+    "build": "rm -rf lib && babel src --out-dir lib --source-maps inline --extensions '.ts'",
+    "lint": "eslint --ignore-path .gitignore --ext .js,.ts .",
+    "spec": "jest --testPathIgnorePatterns test/e2e-repo.spec.ts /benchmarks-tmp",
+    "spec:e2e": "jest test/e2e-repo.spec.ts",
+    "test": "yarn lint && yarn build && yarn spec",
+    "tsc": "tsc",
+    "version": "yarn build"
+  },
+  "jest": {
+    "testEnvironment": "node",
+    "testPathIgnorePatterns": [
+      "/benchmarks-tmp/"
+    ]
+  },
+  "devDependencies": {
+    "@babel/cli": "^7.14.8",
+    "@babel/core": "^7.15.0",
+    "@babel/preset-env": "^7.15.0",
+    "@babel/preset-typescript": "^7.15.0",
+    "@semantic-release/changelog": "^5.0.1",
+    "@semantic-release/git": "^9.0.0",
+    "@types/benchmark": "^2.1.1",
+    "@types/browserslist": "^4.15.0",
+    "@types/caniuse-lite": "^1.0.1",
+    "@types/eslint": "^7.28.0",
+    "@types/jest": "^27.0.1",
+    "@types/lodash.memoize": "^4.1.6",
+    "@types/semver": "^7.3.8",
+    "@typescript-eslint/eslint-plugin": "^4.29.2",
+    "@typescript-eslint/parser": "^4.29.2",
+    "benchmark": "^2.1.4",
+    "browserslist-config-erb": "^0.0.1",
+    "electron": "^13.x.x",
+    "eslint": "^7.32.0",
+    "eslint-config-airbnb-typescript": "^12.3.1",
+    "eslint-config-bliss": "^5.0.0",
+    "eslint-config-prettier": "^8.3.0",
+    "eslint-plugin-eslint-plugin": "^4.0.1",
+    "eslint-plugin-import": "^2.24.0",
+    "eslint-plugin-prettier": "^3.4.0",
+    "jest": "^27.0.6",
+    "prettier": "^2.3.2",
+    "semantic-release": "^17.4.5",
+    "simple-git": "^2.44.0",
+    "ts-node": "^10.2.1",
+    "typescript": "^4.3.5"
+  },
+  "prettier": {
+    "trailingComma": "es5",
+    "tabWidth": 2,
+    "semi": true
+  },
+  "dependencies": {
+    "@mdn/browser-compat-data": "^3.3.14",
+    "ast-metadata-inferer": "^0.7.0",
+    "browserslist": "^4.16.8",
+    "caniuse-lite": "^1.0.30001267",
+    "core-js": "^3.16.2",
+    "find-up": "^5.0.0",
+    "lodash.memoize": "4.1.2",
+    "semver": "7.3.5"
+  },
+  "peerDependencies": {
+    "eslint": "^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0"
+  },
+  "engines": {
+    "node": ">=9.x"
+  },
+  "collective": {
+    "type": "opencollective",
+    "url": "https://opencollective.com/eslint-plugin-compat",
+    "logo": "https://opencollective.com/opencollective/logo.txt"
+  },
+  "babel": {
+    "presets": [
+      [
+        "@babel/preset-env",
+        {
+          "useBuiltIns": "usage",
+          "corejs": 3,
+          "targets": {
+            "node": 10
+          }
+        }
+      ],
+      "@babel/preset-typescript"
+    ]
+  },
+  "renovate": {
+    "extends": [
+      "bliss"
+    ]
+  }
 }
diff --git a/lib/constants.js b/lib/constants.js
index v3.13.0..v4.0.0 100644
--- a/lib/constants.js
+++ b/lib/constants.js
@@ -4,5 +4,5 @@
   value: true
 });
-exports.AstNodeTypes = exports.STANDARD_TARGET_NAME_MAPPING = void 0;
+exports.STANDARD_TARGET_NAME_MAPPING = exports.AstNodeTypes = void 0;
 
 /* eslint import/prefer-default-export: off */
diff --git a/lib/helpers.js b/lib/helpers.js
index v3.13.0..v4.0.0 100644
--- a/lib/helpers.js
+++ b/lib/helpers.js
@@ -4,11 +4,11 @@
   value: true
 });
+exports.determineTargetsFromConfig = determineTargetsFromConfig;
 exports.lintCallExpression = lintCallExpression;
-exports.lintNewExpression = lintNewExpression;
 exports.lintExpressionStatement = lintExpressionStatement;
 exports.lintMemberExpression = lintMemberExpression;
+exports.lintNewExpression = lintNewExpression;
+exports.parseBrowsersListVersion = parseBrowsersListVersion;
 exports.reverseTargetMappings = reverseTargetMappings;
-exports.determineTargetsFromConfig = determineTargetsFromConfig;
-exports.parseBrowsersListVersion = parseBrowsersListVersion;
 
 require("core-js/modules/es.object.from-entries.js");
diff --git a/lib/index.js b/lib/index.js
index v3.13.0..v4.0.0 100644
--- a/lib/index.js
+++ b/lib/index.js
@@ -4,5 +4,5 @@
   value: true
 });
-exports.rules = exports.config = exports.configs = void 0;
+exports.rules = exports.configs = exports.config = void 0;
 
 var _recommended = _interopRequireDefault(require("./config/recommended"));
diff --git a/lib/providers/caniuse-provider.js b/lib/providers/caniuse-provider.js
index v3.13.0..v4.0.0 100644
--- a/lib/providers/caniuse-provider.js
+++ b/lib/providers/caniuse-provider.js
@@ -4,6 +4,6 @@
   value: true
 });
+exports.default = void 0;
 exports.getUnsupportedTargets = getUnsupportedTargets;
-exports.default = void 0;
 
 var lite = _interopRequireWildcard(require("caniuse-lite"));
diff --git a/lib/providers/mdn-provider.js b/lib/providers/mdn-provider.js
index v3.13.0..v4.0.0 100644
--- a/lib/providers/mdn-provider.js
+++ b/lib/providers/mdn-provider.js
@@ -4,7 +4,7 @@
   value: true
 });
+exports.default = void 0;
+exports.getUnsupportedTargets = getUnsupportedTargets;
 exports.isSupportedByMDN = isSupportedByMDN;
-exports.getUnsupportedTargets = getUnsupportedTargets;
-exports.default = void 0;
 
 require("core-js/modules/es.array.flat.js");
diff --git a/lib/rules/compat.js b/lib/rules/compat.js
index v3.13.0..v4.0.0 100644
--- a/lib/rules/compat.js
+++ b/lib/rules/compat.js
@@ -129,5 +129,6 @@
     // package.json config section. Use config from eslintrc for testing purposes
     const browserslistConfig = ((_context$settings2 = context.settings) === null || _context$settings2 === void 0 ? void 0 : _context$settings2.browsers) || ((_context$settings3 = context.settings) === null || _context$settings3 === void 0 ? void 0 : _context$settings3.targets) || context.options[0];
-    const lintAllEsApis = ((_context$settings4 = context.settings) === null || _context$settings4 === void 0 ? void 0 : _context$settings4.lintAllEsApis) === true || !((_context$settings5 = context.settings) !== null && _context$settings5 !== void 0 && (_context$settings5$po = _context$settings5.polyfills) !== null && _context$settings5$po !== void 0 && _context$settings5$po.includes("es:all")) && !isUsingTranspiler(context);
+    const lintAllEsApis = ((_context$settings4 = context.settings) === null || _context$settings4 === void 0 ? void 0 : _context$settings4.lintAllEsApis) === true || // Attempt to infer polyfilling of ES APIs from ts or babel config
+    !((_context$settings5 = context.settings) !== null && _context$settings5 !== void 0 && (_context$settings5$po = _context$settings5.polyfills) !== null && _context$settings5$po !== void 0 && _context$settings5$po.includes("es:all")) && !isUsingTranspiler(context);
     const browserslistTargets = (0, _helpers.parseBrowsersListVersion)((0, _helpers.determineTargetsFromConfig)(context.getFilename(), browserslistConfig));
 
@@ -204,3 +205,3 @@
 };
 exports.default = _default;
-//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/rules/compat.ts"],"names":["getName","node","type","callee","name","object","expression","Error","generateErrorName","rule","property","getPolyfillSet","polyfillArrayJSON","Set","JSON","parse","isPolyfilled","context","settings","polyfills","stringify","has","id","protoChainId","protoChain","items","isUsingTranspiler","parserOptions","tsconfigRootDir","dir","getFilename","configPath","findUp","sync","cwd","pkgPath","pkg","fs","readFileSync","toString","babel","meta","docs","description","category","url","recommended","schema","create","browserslistConfig","browsers","targets","options","lintAllEsApis","includes","browserslistTargets","getRulesForTargets","targetsJSON","result","CallExpression","NewExpression","MemberExpression","ExpressionStatement","nodes","filter","kind","forEach","getUnsupportedTargets","length","astNodeType","push","targetedRules","errors","handleFailingRule","eslintNode","message","join","identifiers","lintCallExpression","bind","lintNewExpression","lintExpressionStatement","lintMemberExpression","Identifier","parent","add","error","report"],"mappings":"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","sourcesContent":["/*\n * Step 2) Logic that handles AST traversal\n * Does not handle looking up the API\n * Handles checking what kinds of eslint nodes should be linted\n *   Tells eslint to lint certain nodes  (lintCallExpression, lintMemberExpression, lintNewExpression)\n *   Gets protochain for the ESLint nodes the plugin is interested in\n */\nimport fs from \"fs\";\nimport findUp from \"find-up\";\nimport memoize from \"lodash.memoize\";\nimport {\n  lintCallExpression,\n  lintMemberExpression,\n  lintNewExpression,\n  lintExpressionStatement,\n  parseBrowsersListVersion,\n  determineTargetsFromConfig,\n} from \"../helpers\"; // will be deprecated and introduced to this file\nimport {\n  ESLintNode,\n  AstMetadataApiWithTargetsResolver,\n  BrowserListConfig,\n  HandleFailingRule,\n  Context,\n} from \"../types\";\nimport { nodes } from \"../providers\";\n\ntype ESLint = {\n  [astNodeTypeName: string]: (node: ESLintNode) => void;\n};\n\nfunction getName(node: ESLintNode): string {\n  switch (node.type) {\n    case \"NewExpression\": {\n      return node.callee.name;\n    }\n    case \"MemberExpression\": {\n      return node.object.name;\n    }\n    case \"ExpressionStatement\": {\n      return node.expression.name;\n    }\n    case \"CallExpression\": {\n      return node.callee.name;\n    }\n    default:\n      throw new Error(\"not found\");\n  }\n}\n\nfunction generateErrorName(rule: AstMetadataApiWithTargetsResolver): string {\n  if (rule.name) return rule.name;\n  if (rule.property) return `${rule.object}.${rule.property}()`;\n  return rule.object;\n}\n\nconst getPolyfillSet = memoize(\n  (polyfillArrayJSON: string): Set<String> =>\n    new Set(JSON.parse(polyfillArrayJSON))\n);\n\nfunction isPolyfilled(\n  context: Context,\n  rule: AstMetadataApiWithTargetsResolver\n): boolean {\n  if (!context.settings?.polyfills) return false;\n  const polyfills = getPolyfillSet(JSON.stringify(context.settings.polyfills));\n  return (\n    // v2 allowed users to select polyfills based off their caniuseId. This is\n    polyfills.has(rule.id) || // no longer supported. Keeping this here to avoid breaking changes.\n    polyfills.has(rule.protoChainId) || // Check if polyfill is provided (ex. `Promise.all`)\n    polyfills.has(rule.protoChain[0]) // Check if entire API is polyfilled (ex. `Promise`)\n  );\n}\n\nconst items = [\n  // Babel configs\n  \"babel.config.json\",\n  \"babel.config.js\",\n  \".babelrc\",\n  \".babelrc.json\",\n  \".babelrc.js\",\n  // TS configs\n  \"tsconfig.json\",\n];\n\n/**\n * Determine if a user has a TS or babel config. This is used to infer if a user is transpiling their code.\n * If transpiling code, do not lint ES APIs. We assume that all transpiled code is polyfilled.\n * @TODO Use @babel/core to find config. See https://github.com/babel/babel/discussions/11602\n * @param dir @\n */\nfunction isUsingTranspiler(context: Context): boolean {\n  // If tsconfig config exists in parser options, assume transpilation\n  if (context.parserOptions?.tsconfigRootDir === true) return true;\n  const dir = context.getFilename();\n  const configPath = findUp.sync(items, {\n    cwd: dir,\n  });\n  if (configPath) return true;\n  const pkgPath = findUp.sync(\"package.json\", {\n    cwd: dir,\n  });\n  // Check if babel property exists\n  if (pkgPath) {\n    const pkg = JSON.parse(fs.readFileSync(pkgPath).toString());\n    return !!pkg.babel;\n  }\n  return false;\n}\n\nexport default {\n  meta: {\n    docs: {\n      description: \"Ensure cross-browser API compatibility\",\n      category: \"Compatibility\",\n      url: \"https://github.com/amilajack/eslint-plugin-compat/blob/master/docs/rules/compat.md\",\n      recommended: true,\n    },\n    type: \"problem\",\n    schema: [{ type: \"string\" }],\n  },\n  create(context: Context): ESLint {\n    // Determine lowest targets from browserslist config, which reads user's\n    // package.json config section. Use config from eslintrc for testing purposes\n    const browserslistConfig: BrowserListConfig =\n      context.settings?.browsers ||\n      context.settings?.targets ||\n      context.options[0];\n\n    const lintAllEsApis: boolean =\n      context.settings?.lintAllEsApis === true ||\n      // Attempt to infer polyfilling of ES APIs from ts or babel config\n      (!context.settings?.polyfills?.includes(\"es:all\") &&\n        !isUsingTranspiler(context));\n    const browserslistTargets = parseBrowsersListVersion(\n      determineTargetsFromConfig(context.getFilename(), browserslistConfig)\n    );\n\n    type RulesFilteredByTargets = {\n      CallExpression: AstMetadataApiWithTargetsResolver[];\n      NewExpression: AstMetadataApiWithTargetsResolver[];\n      MemberExpression: AstMetadataApiWithTargetsResolver[];\n      ExpressionStatement: AstMetadataApiWithTargetsResolver[];\n    };\n\n    /**\n     * A small optimization that only lints APIs that are not supported by targeted browsers.\n     * For example, if the user is targeting chrome 50, which supports the fetch API, it is\n     * wasteful to lint calls to fetch.\n     */\n    const getRulesForTargets = memoize(\n      (targetsJSON: string): RulesFilteredByTargets => {\n        const result = {\n          CallExpression: [],\n          NewExpression: [],\n          MemberExpression: [],\n          ExpressionStatement: [],\n        };\n        const targets = JSON.parse(targetsJSON);\n\n        nodes\n          .filter((node) => {\n            return lintAllEsApis ? true : node.kind !== \"es\";\n          })\n          .forEach((node) => {\n            if (!node.getUnsupportedTargets(node, targets).length) return;\n            result[node.astNodeType as keyof RulesFilteredByTargets].push(node);\n          });\n\n        return result;\n      }\n    );\n\n    // Stringify to support memoization; browserslistConfig is always an array of new objects.\n    const targetedRules = getRulesForTargets(\n      JSON.stringify(browserslistTargets)\n    );\n\n    type Error = {\n      message: string;\n      node: ESLintNode;\n    };\n\n    const errors: Error[] = [];\n\n    const handleFailingRule: HandleFailingRule = (\n      node: AstMetadataApiWithTargetsResolver,\n      eslintNode: ESLintNode\n    ) => {\n      if (isPolyfilled(context, node)) return;\n      errors.push({\n        node: eslintNode,\n        message: [\n          generateErrorName(node),\n          \"is not supported in\",\n          node.getUnsupportedTargets(node, browserslistTargets).join(\", \"),\n        ].join(\" \"),\n      });\n    };\n\n    const identifiers = new Set();\n\n    return {\n      CallExpression: lintCallExpression.bind(\n        null,\n        context,\n        handleFailingRule,\n        targetedRules.CallExpression\n      ),\n      NewExpression: lintNewExpression.bind(\n        null,\n        context,\n        handleFailingRule,\n        targetedRules.NewExpression\n      ),\n      ExpressionStatement: lintExpressionStatement.bind(\n        null,\n        context,\n        handleFailingRule,\n        [...targetedRules.MemberExpression, ...targetedRules.CallExpression]\n      ),\n      MemberExpression: lintMemberExpression.bind(\n        null,\n        context,\n        handleFailingRule,\n        [\n          ...targetedRules.MemberExpression,\n          ...targetedRules.CallExpression,\n          ...targetedRules.NewExpression,\n        ]\n      ),\n      // Keep track of all the defined variables. Do not report errors for nodes that are not defined\n      Identifier(node: ESLintNode) {\n        if (node.parent) {\n          const { type } = node.parent;\n          if (\n            type === \"Property\" || // ex. const { Set } = require('immutable');\n            type === \"FunctionDeclaration\" || // ex. function Set() {}\n            type === \"VariableDeclarator\" || // ex. const Set = () => {}\n            type === \"ClassDeclaration\" || // ex. class Set {}\n            type === \"ImportDefaultSpecifier\" || // ex. import Set from 'set';\n            type === \"ImportSpecifier\" || // ex. import {Set} from 'set';\n            type === \"ImportDeclaration\" // ex. import {Set} from 'set';\n          ) {\n            identifiers.add(node.name);\n          }\n        }\n      },\n      \"Program:exit\": () => {\n        // Get a map of all the variables defined in the root scope (not the global scope)\n        // const variablesMap = context.getScope().childScopes.map(e => e.set)[0];\n        errors\n          .filter((error) => !identifiers.has(getName(error.node)))\n          .forEach((node) => context.report(node));\n      },\n    };\n  },\n};\n"]}
\ No newline at end of file
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/rules/compat.ts"],"names":["getName","node","type","callee","name","object","expression","Error","generateErrorName","rule","property","getPolyfillSet","polyfillArrayJSON","Set","JSON","parse","isPolyfilled","context","settings","polyfills","stringify","has","id","protoChainId","protoChain","items","isUsingTranspiler","parserOptions","tsconfigRootDir","dir","getFilename","configPath","findUp","sync","cwd","pkgPath","pkg","fs","readFileSync","toString","babel","meta","docs","description","category","url","recommended","schema","create","browserslistConfig","browsers","targets","options","lintAllEsApis","includes","browserslistTargets","getRulesForTargets","targetsJSON","result","CallExpression","NewExpression","MemberExpression","ExpressionStatement","nodes","filter","kind","forEach","getUnsupportedTargets","length","astNodeType","push","targetedRules","errors","handleFailingRule","eslintNode","message","join","identifiers","lintCallExpression","bind","lintNewExpression","lintExpressionStatement","lintMemberExpression","Identifier","parent","add","error","report"],"mappings":"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","sourcesContent":["/*\n * Step 2) Logic that handles AST traversal\n * Does not handle looking up the API\n * Handles checking what kinds of eslint nodes should be linted\n *   Tells eslint to lint certain nodes  (lintCallExpression, lintMemberExpression, lintNewExpression)\n *   Gets protochain for the ESLint nodes the plugin is interested in\n */\nimport fs from \"fs\";\nimport findUp from \"find-up\";\nimport memoize from \"lodash.memoize\";\nimport {\n  lintCallExpression,\n  lintMemberExpression,\n  lintNewExpression,\n  lintExpressionStatement,\n  parseBrowsersListVersion,\n  determineTargetsFromConfig,\n} from \"../helpers\"; // will be deprecated and introduced to this file\nimport {\n  ESLintNode,\n  AstMetadataApiWithTargetsResolver,\n  BrowserListConfig,\n  HandleFailingRule,\n  Context,\n} from \"../types\";\nimport { nodes } from \"../providers\";\n\ntype ESLint = {\n  [astNodeTypeName: string]: (node: ESLintNode) => void;\n};\n\nfunction getName(node: ESLintNode): string {\n  switch (node.type) {\n    case \"NewExpression\": {\n      return node.callee.name;\n    }\n    case \"MemberExpression\": {\n      return node.object.name;\n    }\n    case \"ExpressionStatement\": {\n      return node.expression.name;\n    }\n    case \"CallExpression\": {\n      return node.callee.name;\n    }\n    default:\n      throw new Error(\"not found\");\n  }\n}\n\nfunction generateErrorName(rule: AstMetadataApiWithTargetsResolver): string {\n  if (rule.name) return rule.name;\n  if (rule.property) return `${rule.object}.${rule.property}()`;\n  return rule.object;\n}\n\nconst getPolyfillSet = memoize(\n  (polyfillArrayJSON: string): Set<String> =>\n    new Set(JSON.parse(polyfillArrayJSON))\n);\n\nfunction isPolyfilled(\n  context: Context,\n  rule: AstMetadataApiWithTargetsResolver\n): boolean {\n  if (!context.settings?.polyfills) return false;\n  const polyfills = getPolyfillSet(JSON.stringify(context.settings.polyfills));\n  return (\n    // v2 allowed users to select polyfills based off their caniuseId. This is\n    polyfills.has(rule.id) || // no longer supported. Keeping this here to avoid breaking changes.\n    polyfills.has(rule.protoChainId) || // Check if polyfill is provided (ex. `Promise.all`)\n    polyfills.has(rule.protoChain[0]) // Check if entire API is polyfilled (ex. `Promise`)\n  );\n}\n\nconst items = [\n  // Babel configs\n  \"babel.config.json\",\n  \"babel.config.js\",\n  \".babelrc\",\n  \".babelrc.json\",\n  \".babelrc.js\",\n  // TS configs\n  \"tsconfig.json\",\n];\n\n/**\n * Determine if a user has a TS or babel config. This is used to infer if a user is transpiling their code.\n * If transpiling code, do not lint ES APIs. We assume that all transpiled code is polyfilled.\n * @TODO Use @babel/core to find config. See https://github.com/babel/babel/discussions/11602\n * @param dir @\n */\nfunction isUsingTranspiler(context: Context): boolean {\n  // If tsconfig config exists in parser options, assume transpilation\n  if (context.parserOptions?.tsconfigRootDir === true) return true;\n  const dir = context.getFilename();\n  const configPath = findUp.sync(items, {\n    cwd: dir,\n  });\n  if (configPath) return true;\n  const pkgPath = findUp.sync(\"package.json\", {\n    cwd: dir,\n  });\n  // Check if babel property exists\n  if (pkgPath) {\n    const pkg = JSON.parse(fs.readFileSync(pkgPath).toString());\n    return !!pkg.babel;\n  }\n  return false;\n}\n\nexport default {\n  meta: {\n    docs: {\n      description: \"Ensure cross-browser API compatibility\",\n      category: \"Compatibility\",\n      url: \"https://github.com/amilajack/eslint-plugin-compat/blob/master/docs/rules/compat.md\",\n      recommended: true,\n    },\n    type: \"problem\",\n    schema: [{ type: \"string\" }],\n  },\n  create(context: Context): ESLint {\n    // Determine lowest targets from browserslist config, which reads user's\n    // package.json config section. Use config from eslintrc for testing purposes\n    const browserslistConfig: BrowserListConfig =\n      context.settings?.browsers ||\n      context.settings?.targets ||\n      context.options[0];\n\n    const lintAllEsApis: boolean =\n      context.settings?.lintAllEsApis === true ||\n      // Attempt to infer polyfilling of ES APIs from ts or babel config\n      (!context.settings?.polyfills?.includes(\"es:all\") &&\n        !isUsingTranspiler(context));\n    const browserslistTargets = parseBrowsersListVersion(\n      determineTargetsFromConfig(context.getFilename(), browserslistConfig)\n    );\n\n    type RulesFilteredByTargets = {\n      CallExpression: AstMetadataApiWithTargetsResolver[];\n      NewExpression: AstMetadataApiWithTargetsResolver[];\n      MemberExpression: AstMetadataApiWithTargetsResolver[];\n      ExpressionStatement: AstMetadataApiWithTargetsResolver[];\n    };\n\n    /**\n     * A small optimization that only lints APIs that are not supported by targeted browsers.\n     * For example, if the user is targeting chrome 50, which supports the fetch API, it is\n     * wasteful to lint calls to fetch.\n     */\n    const getRulesForTargets = memoize(\n      (targetsJSON: string): RulesFilteredByTargets => {\n        const result = {\n          CallExpression: [],\n          NewExpression: [],\n          MemberExpression: [],\n          ExpressionStatement: [],\n        };\n        const targets = JSON.parse(targetsJSON);\n\n        nodes\n          .filter((node) => {\n            return lintAllEsApis ? true : node.kind !== \"es\";\n          })\n          .forEach((node) => {\n            if (!node.getUnsupportedTargets(node, targets).length) return;\n            result[node.astNodeType as keyof RulesFilteredByTargets].push(node);\n          });\n\n        return result;\n      }\n    );\n\n    // Stringify to support memoization; browserslistConfig is always an array of new objects.\n    const targetedRules = getRulesForTargets(\n      JSON.stringify(browserslistTargets)\n    );\n\n    type Error = {\n      message: string;\n      node: ESLintNode;\n    };\n\n    const errors: Error[] = [];\n\n    const handleFailingRule: HandleFailingRule = (\n      node: AstMetadataApiWithTargetsResolver,\n      eslintNode: ESLintNode\n    ) => {\n      if (isPolyfilled(context, node)) return;\n      errors.push({\n        node: eslintNode,\n        message: [\n          generateErrorName(node),\n          \"is not supported in\",\n          node.getUnsupportedTargets(node, browserslistTargets).join(\", \"),\n        ].join(\" \"),\n      });\n    };\n\n    const identifiers = new Set();\n\n    return {\n      CallExpression: lintCallExpression.bind(\n        null,\n        context,\n        handleFailingRule,\n        targetedRules.CallExpression\n      ),\n      NewExpression: lintNewExpression.bind(\n        null,\n        context,\n        handleFailingRule,\n        targetedRules.NewExpression\n      ),\n      ExpressionStatement: lintExpressionStatement.bind(\n        null,\n        context,\n        handleFailingRule,\n        [...targetedRules.MemberExpression, ...targetedRules.CallExpression]\n      ),\n      MemberExpression: lintMemberExpression.bind(\n        null,\n        context,\n        handleFailingRule,\n        [\n          ...targetedRules.MemberExpression,\n          ...targetedRules.CallExpression,\n          ...targetedRules.NewExpression,\n        ]\n      ),\n      // Keep track of all the defined variables. Do not report errors for nodes that are not defined\n      Identifier(node: ESLintNode) {\n        if (node.parent) {\n          const { type } = node.parent;\n          if (\n            type === \"Property\" || // ex. const { Set } = require('immutable');\n            type === \"FunctionDeclaration\" || // ex. function Set() {}\n            type === \"VariableDeclarator\" || // ex. const Set = () => {}\n            type === \"ClassDeclaration\" || // ex. class Set {}\n            type === \"ImportDefaultSpecifier\" || // ex. import Set from 'set';\n            type === \"ImportSpecifier\" || // ex. import {Set} from 'set';\n            type === \"ImportDeclaration\" // ex. import {Set} from 'set';\n          ) {\n            identifiers.add(node.name);\n          }\n        }\n      },\n      \"Program:exit\": () => {\n        // Get a map of all the variables defined in the root scope (not the global scope)\n        // const variablesMap = context.getScope().childScopes.map(e => e.set)[0];\n        errors\n          .filter((error) => !identifiers.has(getName(error.node)))\n          .forEach((node) => context.report(node));\n      },\n    };\n  },\n};\n"]}
\ No newline at end of file
  • Size: 118.6 KB → 114.9 KB (-3.7 KB)
  • Files: 18 → 12 (-6)

Posted by ybiquitous/npm-diff-action

@ybiquitous ybiquitous changed the title build(deps): bump eslint-plugin-compat from 3.13.0 to 4.0.0 fix(deps): bump eslint-plugin-compat from 3.13.0 to 4.0.0 Nov 19, 2021
@ybiquitous ybiquitous merged commit e4ad27b into main Nov 19, 2021
@ybiquitous ybiquitous deleted the dependabot/npm_and_yarn/eslint-plugin-compat-4.0.0 branch November 19, 2021 16:23
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
dependencies Pull requests that update a dependency file javascript Pull requests that update Javascript code
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant