Skip to content

cartant/eslint-plugin-etc

Folders and files

NameName
Last commit message
Last commit date
Nov 9, 2019
Oct 23, 2020
Apr 5, 2021
May 27, 2021
Oct 4, 2023
Jan 22, 2022
Jan 22, 2022
Apr 19, 2019
Sep 25, 2020
Feb 24, 2019
May 10, 2023
Feb 24, 2019
Feb 10, 2021
May 27, 2021
Aug 15, 2020
May 10, 2023
Mar 2, 2019
Mar 19, 2021
Oct 4, 2023

Repository files navigation

eslint-plugin-etc

GitHub License NPM version Downloads Build status dependency status devDependency Status peerDependency Status

This package contains a bunch of general-purpose, TypeScript-related ESLint rules. Essentially, it's a re-implementation of the rules that are in the tslint-etc package.

Some of the rules are rather opinionated and are not included in the recommended configuration. Developers can decide for themselves whether they want to enable opinionated rules.

Install

Install the ESLint TypeScript parser using npm:

npm install @typescript-eslint/parser --save-dev

Install the package using npm:

npm install eslint-plugin-etc --save-dev

Configure the parser and the parserOptions for ESLint. Here, I use a .eslintrc.js file for the configuration:

const { join } = require("path");
module.exports = {
  parser: "@typescript-eslint/parser",
  parserOptions: {
    ecmaVersion: 2019,
    project: join(__dirname, "./tsconfig.json"),
    sourceType: "module"
  },
  plugins: ["etc"],
  extends: [],
  rules: {
    "etc/no-t": "error"
  }
};

Or, using the recommended configuration:

const { join } = require("path");
module.exports = {
  parser: "@typescript-eslint/parser",
  parserOptions: {
    ecmaVersion: 2019,
    project: join(__dirname, "./tsconfig.json"),
    sourceType: "module"
  },
  extends: ["plugin:etc/recommended"],
};

Rules

The package includes the following rules.

Rules marked with βœ… are recommended and rules marked with πŸ”§ have fixers.

Rule Description
no-assign-mutated-array Forbids the assignment of returned, mutated arrays. βœ…
no-commented-out-code Forbids commented-out code.
no-const-enum Forbids the use of const enum. Constant enums are not compatible with isolated modules.
no-deprecated Forbids the use of deprecated APIs. βœ…
no-enum Forbids the use of enum.
no-implicit-any-catch Like the no-implicit-any-catch rule in @typescript-eslint/eslint-plugin, but for Promise rejections instead of catch clauses. βœ… πŸ”§
no-internal Forbids the use of internal APIs. βœ…
no-misused-generics Forbids type parameters without inference sites and type parameters that don't add type safety to declarations. This is an ESLint port of Wotan's no-misused-generics rule. See also "The Golden Rule of Generics".
no-t Forbids single-character type parameters.
prefer-interface Forbids type aliases where interfaces can be used. πŸ”§
prefer-less-than Forbids greater-than comparisons. (Yes, this is the rule for Ben Lesh comparisons.) πŸ”§
throw-error Forbids throwing - or rejecting with - non-Error values.
underscore-internal Forbids internal APIs that are not prefixed with underscores.