mirror of
https://github.com/zhigang1992/firebase-tools.git
synced 2026-04-30 21:02:13 +08:00
Linter had a typo in the rule name. it's "returns" not "return" per https://github.com/gajus/eslint-plugin-jsdoc/blob/master/.README/rules/require-returns.md
117 lines
5.4 KiB
JavaScript
117 lines
5.4 KiB
JavaScript
module.exports = {
|
|
env: {
|
|
es6: true,
|
|
node: true,
|
|
},
|
|
extends: [
|
|
"eslint:recommended",
|
|
"plugin:@typescript-eslint/recommended",
|
|
"plugin:@typescript-eslint/recommended-requiring-type-checking",
|
|
"plugin:jsdoc/recommended",
|
|
"google",
|
|
"prettier",
|
|
"prettier/@typescript-eslint",
|
|
],
|
|
rules: {
|
|
"jsdoc/newline-after-description": "off",
|
|
"jsdoc/require-jsdoc": ["warn", { publicOnly: true }],
|
|
"no-restricted-globals": ["error", "name", "length"],
|
|
"prefer-arrow-callback": "error",
|
|
"prettier/prettier": "error",
|
|
"require-atomic-updates": "off", // This rule is so noisy and isn't useful: https://github.com/eslint/eslint/issues/11899
|
|
"require-jsdoc": "off", // This rule is deprecated and superseded by jsdoc/require-jsdoc.
|
|
"valid-jsdoc": "off", // This is deprecated but included in recommended configs.
|
|
|
|
"no-prototype-builtins": "warn", // TODO(bkendall): remove, allow to error.
|
|
"no-useless-escape": "warn", // TODO(bkendall): remove, allow to error.
|
|
"prefer-promise-reject-errors": "warn", // TODO(bkendall): remove, allow to error.
|
|
},
|
|
overrides: [
|
|
{
|
|
files: ["*.ts"],
|
|
rules: {
|
|
"jsdoc/require-param-type": "off",
|
|
"jsdoc/require-returns-type": "off",
|
|
|
|
// Google style guide allows us to omit trivial parameters and returns
|
|
"jsdoc/require-param": "off",
|
|
"jsdoc/require-returns": "off",
|
|
|
|
"no-invalid-this": "off", // Turned off in favor of @typescript-eslint/no-invalid-this.
|
|
"@typescript-eslint/no-invalid-this": ["error"],
|
|
|
|
"@typescript-eslint/ban-types": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/explicit-function-return-type": ["warn", { allowExpressions: true }], // TODO(bkendall): SET to error.
|
|
"@typescript-eslint/no-extra-non-null-assertion": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/no-floating-promises": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/no-inferrable-types": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/no-misused-promises": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/no-unnecessary-type-assertion": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/no-unsafe-assignment": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/no-unsafe-call": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/no-unsafe-member-access": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/no-unsafe-return": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/no-use-before-define": ["warn", { functions: false, typedefs: false }], // TODO(bkendall): change to error.
|
|
"@typescript-eslint/no-var-requires": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/prefer-includes": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/prefer-regexp-exec": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/prefer-string-starts-ends-with": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/restrict-plus-operands": "warn", // TODO(bkendall): remove, allow to error.
|
|
"@typescript-eslint/restrict-template-expressions": "warn", // TODO(bkendall): remove, allow to error.
|
|
"no-case-declarations": "warn", // TODO(bkendall): remove, allow to error.
|
|
"no-constant-condition": "warn", // TODO(bkendall): remove, allow to error.
|
|
"no-fallthrough": "warn", // TODO(bkendall): remove, allow to error.
|
|
"no-unused-vars": "warn", // TODO(bkendall): remove, allow to error.
|
|
camelcase: ["warn", { ignoreDestructuring: true }], // TODO(bkendall): remove, allow to error.
|
|
},
|
|
},
|
|
{
|
|
files: ["*.js"],
|
|
rules: {
|
|
"@typescript-eslint/explicit-function-return-type": "off",
|
|
"@typescript-eslint/no-empty-function": "off",
|
|
"@typescript-eslint/no-floating-promises": "off",
|
|
"@typescript-eslint/no-misused-promises": "off",
|
|
"@typescript-eslint/no-this-alias": "off",
|
|
"@typescript-eslint/no-unsafe-assignment": "off",
|
|
"@typescript-eslint/no-unsafe-call": "off",
|
|
"@typescript-eslint/no-unsafe-member-access": "off",
|
|
"@typescript-eslint/no-unsafe-return": "off",
|
|
"@typescript-eslint/no-use-before-define": "off",
|
|
"@typescript-eslint/no-var-requires": "off",
|
|
"@typescript-eslint/prefer-includes": "off",
|
|
"@typescript-eslint/prefer-regexp-exec": "off",
|
|
"@typescript-eslint/restrict-plus-operands": "off",
|
|
"@typescript-eslint/restrict-template-expressions": "off",
|
|
"@typescript-eslint/unbound-method": "off",
|
|
|
|
"no-var": "off", // TODO(bkendall): remove, allow to error.
|
|
"prefer-arrow-callback": "off", // TODO(bkendall): remove, allow to error.
|
|
},
|
|
},
|
|
{
|
|
files: ["*.spec.*"],
|
|
env: {
|
|
mocha: true,
|
|
},
|
|
rules: {},
|
|
},
|
|
],
|
|
globals: {},
|
|
parserOptions: {
|
|
ecmaVersion: "2017",
|
|
project: ["tsconfig.json", "tsconfig.dev.json"],
|
|
sourceType: "module",
|
|
warnOnUnsupportedTypeScriptVersion: false,
|
|
},
|
|
plugins: ["prettier", "@typescript-eslint", "jsdoc"],
|
|
settings: {
|
|
jsdoc: {
|
|
tagNamePreference: {
|
|
returns: "return",
|
|
},
|
|
},
|
|
},
|
|
parser: "@typescript-eslint/parser",
|
|
};
|