Skip to content

Instantly share code, notes, and snippets.

@caweidmann
Last active August 15, 2025 08:27
Show Gist options
  • Save caweidmann/e3c586cb105e8864308b to your computer and use it in GitHub Desktop.
Save caweidmann/e3c586cb105e8864308b to your computer and use it in GitHub Desktop.
The "C-Dawg linter" annotation.
/*
**
** kyco.eslintrc
** =============
**
** Based on http://eslint.org/docs/rules/
**
** All rules specified in this file are taken from the URL above. We have
** included every single rule except for rules posted under the "Removed"
** section.
**
** For the most part we are using eslint recommended settings (especially
** for the sections "Possible Errors" and "Best Practises"). For rules
** where we are not using recommended settings the default/recommended
** setting is provided in a comment on the same line as the rule.
**
** Note: This is the annotated version. A version without comments can be
** found here: https://gist.github.com/Corhero/856c9612ce61d22bf100
**
** Brought to you by
** https://www.kycosoftware.com
**
** Copyright 2015 Cornelius Weidmann
**
** Distributed under the GPL
**
*/
{
"env": {
"browser": true,
},
"globals": {
"jQuery": false,
"$": false,
"_": false,
},
"rules": {
/*
** STRICT MODE
** These rules relate to using strict mode.
*/
"strict": [2, "global"], // `[2, "function"]` is default, optionally set `[2, "never"]`
/*
** VARIABLES
** These rules have to do with variable declarations.
*/
"init-declarations": 0, // `[2, "always"]` is default
"no-catch-shadow": 0, // `2` is default
"no-delete-var": 1, // `2` is default
"no-label-var": 2,
"no-shadow-restricted-names": 2,
"no-shadow": [2, {"builtinGlobals": false, "hoist": "all"}], // `[2, {"builtinGlobals": false, "hoist": "functions"}]` is default
"no-undef-init": 1, // `2` is default
"no-undef": 2,
"no-undefined": 2,
"no-unused-vars": [1, {"vars": "all", "args": "all"}], // `[2, {"vars": "all", "args": "after-used"}]` is default, optionally set `[2, {"vars": "all", "args": "after-used", "varsIgnorePattern": "<regex>", "argsIgnorePattern": "<regex>"}]`
"no-use-before-define": 1,
/*
** POSSIBLE ERRORS
** The following rules point out areas where you might
** have made mistakes.
*/
"comma-dangle": [2, "never"],
"no-cond-assign": [2, "except-parens"],
"no-console": 1, // `2` is default. Set to `0` when developing with node
"no-constant-condition": 2,
"no-control-regex": 2,
"no-debugger": 2,
"no-dupe-args": 2,
"no-dupe-keys": 2,
"no-duplicate-case": 2,
"no-empty-character-class": 2,
"no-empty": 2,
"no-ex-assign": 2,
"no-extra-boolean-cast": 2,
"no-extra-parens": [1, "all"], // `[2, "all"]` is default
"no-extra-semi": 1, // `2` is default
"no-func-assign": 2,
"no-inner-declarations": [2, "both"], // `[2, "functions"]` is default
"no-invalid-regexp": 2,
"no-irregular-whitespace": 2,
"no-negated-in-lhs": 2,
"no-obj-calls": 2,
"no-regex-spaces": 2,
"no-sparse-arrays": 2,
"no-unreachable": 2,
"use-isnan": 2,
"valid-jsdoc": 0, // `2` is default
"valid-typeof": 2,
"no-unexpected-multiline": 2,
/*
** BEST PRACTICES
** These are rules designed to prevent you from making mistakes.
** They either prescribe a better way of doing something or help
** you avoid footguns.
*/
"accessor-pairs": [2, {"getWithoutSet": false, "setWithoutGet": true}],
"block-scoped-var": 2,
"complexity": [1, 10], // `[2, 2]` is recommended
"consistent-return": 2,
"curly": [2, "all"],
"default-case": 2,
"dot-notation": [2, {"allowKeywords": true, "allowPattern": ""}],
"dot-location": [2, "property"], // `[2, "object"]` is recommended
"eqeqeq": 2, // `2` is recommended, optionally set `[2, "smart"]` or `[2, "allow-null"]`
"guard-for-in": 2,
"no-alert": 1, // `2` is recommended
"no-caller": 2,
"no-div-regex": 2,
"no-else-return": 2,
"no-empty-label": 2,
"no-eq-null": 2,
"no-eval": 2,
"no-extend-native": 2, // `2` is recommended, optionally set `[2, {"exceptions": ["Object"]}]`
"no-extra-bind": 2,
"no-fallthrough": 1, // `2` is recommended
"no-floating-decimal": 1, // `2` is recommended
"no-implicit-coercion": [1, {"boolean": false, "number": true, "string": false}], // `[2, {"boolean": true, "number": true, "string": true}],` is recommended
"no-implied-eval": 2,
"no-invalid-this": 0, // `2` is recommended
"no-iterator": 2,
"no-labels": 2,
"no-lone-blocks": 2,
"no-loop-func": 2,
"no-multi-spaces": [2, {"exceptions": {"VariableDeclarator": true, "ImportDeclaration": true, "AssignmentExpression": true, "ObjectExpression": true}}], // `2` is recommended
"no-multi-str": 2,
"no-native-reassign": 2, // `2` is recommended, optionally set `[2, {"exceptions": ["Object"]}]`
"no-new-func": 2,
"no-new-wrappers": 2,
"no-new": 2,
"no-octal-escape": 2,
"no-octal": 2,
"no-param-reassign": 1, // `2` is recommended and actually defaults to `[2, {"props": false}]`
"no-process-env": 1, // `2` is recommended
"no-proto": 2,
"no-redeclare": [2, {"builtinGlobals": true}], // `2` is recommended and actually defaults to `[2, {"builtinGlobals": false}]`
"no-return-assign": [2, "except-parens"],
"no-script-url": 2,
"no-self-compare": 2,
"no-sequences": 2,
"no-throw-literal": 2,
"no-unused-expressions": 2, // `2` is recommended and actually defaults to `[2, {"allowShortCircuit": false, "allowTernary": false}]`
"no-useless-call": 1, // `2` is recommended
"no-useless-concat": 2,
"no-void": 2,
"no-warning-comments": [1, {"terms": ["todo", "fixme"], "location": "start"}], // `[0, { "terms": ["todo", "fixme", "xxx"], "location": "start" }]` is recommended
"no-with": 2,
"radix": 1, // `2` is recommended
"vars-on-top": 1, // `2` is recommended
"wrap-iife": [2, "inside"], // `[2, "outside"]` is recommended
"yoda": [1, "never"], // `[2, "never"]` is recommended, optionally set `[2, "never", {"exceptRange": true, "onlyEquality": false}]
/*
** STYLISTIC ISSUES
** These rules are purely matters of style and are
** quite subjective.
*/
"array-bracket-spacing": [1, "never"], // optionally set `[2, "never", {"singleValue": true, "objectsInArrays": true, "arraysInArrays": true}]`
"block-spacing": [1, "always"],
"brace-style": [1, "1tbs", {"allowSingleLine": false}],
"camelcase": [1, {"properties": "always"}],
"comma-spacing": [1, {"before": false, "after": true}],
"comma-style": [1, "last"], // optionally set `[2, "first", {"exceptions": {"ArrayExpression": true, "ObjectExpression": true}}]`
"computed-property-spacing": [1, "never"],
"consistent-this": [1, "self"],
"eol-last": 1,
"func-names": 0,
"func-style": 0, // optionally set `[2, "expression"]`
"id-length": 0, // optionally set `[2, {"min": 3, "max": 10, "properties": "never", "exceptions": ["x"]}]`
"id-match": 0, // optionally set `[2, "^[a-z]+([A-Z][a-z]+)*$", {"properties": false}]`
"indent": [1, 2, {"SwitchCase": 1, "VariableDeclarator": 2}], // optionally set `[2, 2, {"SwitchCase": 1, "VariableDeclarator": {"var": 2, "let": 2, "const": 3}}]`
"jsx-quotes": [1, "prefer-double"],
"key-spacing": [1, {"beforeColon": false, "afterColon": true, "mode": "minimum"}], // optionally set `[2, {"beforeColon": false, "afterColon": true, "mode": "strict", "align": "colon"}]`
"lines-around-comment": 0, // optionally set `[2, {"beforeBlockComment": true, "beforeLineComment": true, "allowBlockStart": true}]`
"linebreak-style": 0, // optionally set `[1, "unix"]`
"max-nested-callbacks": [1, 3],
"new-cap": [1, {"newIsCap": true, "capIsNew": true}], // optionally set `[2, {"capIsNewExceptions": ["Person"]}]`
"new-parens": 1,
"newline-after-var": [1, "always"],
"no-array-constructor": 1,
"no-continue": 1,
"no-inline-comments": 0,
"no-lonely-if": 1,
"no-mixed-spaces-and-tabs": 1, // optionally set `[2, "smart-tabs"]`
"no-multiple-empty-lines": [1, {"max": 1}],
"no-nested-ternary": 1,
"no-new-object": 1,
"no-restricted-syntax": 0, // optionally set `[2, "FunctionExpression", "WithStatement"]`
"no-spaced-func": 1,
"no-ternary": 0,
"no-trailing-spaces": [1, {"skipBlankLines": false}],
"no-underscore-dangle": 0,
"no-unneeded-ternary": [1, {"defaultAssignment": true}],
"object-curly-spacing": [1, "never"], // optionally set `[2, "always", {"objectsInObjects": false, "arraysInObjects": false}]`
"one-var": [1, {"uninitialized": "always", "initialized": "never"}], // optionally set `[2, {"var": "always", "let": "never", "const": "never"}]`
"operator-assignment": 0, // optionally set `[2, "always"]`
"operator-linebreak": [1, "after"], // optionally set `[2, "before", {"overrides": {"?": "after"}}]`
"padded-blocks": [1, "never"],
"quote-props": [1, "as-needed", {"keywords": false, "unnecessary": false, "numbers": true}],
"quotes": [1, "single", "avoid-escape"],
"require-jsdoc": 0,
"semi-spacing": [1, {"before": false, "after": true}],
"semi": [1, "always"],
"sort-vars": 0, // optaionlly set `[2, {"ignoreCase": true}]`
"space-after-keywords": [1, "always"],
"space-before-keywords": [1, "always"],
"space-before-blocks": [1, "always"], // optionally set `[2, {"functions": "never", "keywords": "always"}]`
"space-before-function-paren": [1, "never"], // optionally set `[2, {"anonymous": "always", "named": "never"}]`
"space-in-parens": [1, "never"], // optionally set `[2, "always", {"exceptions": ["empty"]}]`
"space-infix-ops": [1, {"int32Hint": false}],
"space-return-throw-case": 1,
"space-unary-ops": [1, {"words": true, "nonwords": false}],
"spaced-comment": [1, "always", {"exceptions": ["/"]}], // optionally set `[2, "always", {"exceptions": ["-", "+"], "markers": ["/"]}]`
"wrap-regex": 1,
/*
** ECMASCRIPT 6
** These rules are only relevant to ES6 environments.
*/
"arrow-parens": [2, "always"],
"arrow-spacing": [2, {"before": true, "after": true}],
"constructor-super": 2,
"generator-star-spacing": [2, {"before": false, "after": true}],
"no-class-assign": 2,
"no-const-assign": 2,
"no-dupe-class-members": 0, // `2` is default, only use on ES6+ environments
"no-this-before-super": 2,
"no-var": 0, // `2` is default, only use on ES6+ environments - when using this set `"blockBindings": true` in `ecmaFeatures` object
"object-shorthand": 0, // `[2, "always"]` is default
"prefer-arrow-callback": 0, // `2` is default, only use on ES6+ environments
"prefer-const": 1, // `2` is default
"prefer-spread": 0, // `2` is default, only use on ES6+ environments
"prefer-reflect": 0, // `2` is default, only use on ES6+ environments, optionally set `[2, {exceptions: ["apply", "call"]}]`
"prefer-template": 0, // `2` is default, only use on ES6+ environments
"require-yield": 2,
/*
** NODE.JS AND COMMONJS
** These rules are specific to JavaScript running on Node.js or
** using CommonJS in the browser.
*/
"callback-return": 0, // `2` is default, optionally set `[2, ["callback", "cb", "next"]]`
"global-require": 0, // `2` is default
"handle-callback-err": 0, // `2` is default, optionally set `[2, "^(err|error)$"]`
"no-mixed-requires": 0, // [2, false] is default
"no-new-require": 0, // `2` is default
"no-path-concat": 0, // `2` is default
"no-process-exit": 0, // `2` is default
"no-restricted-modules": 0, // no default, optionally set `[2, "fs", "os"]`
"no-sync": 0, // `2` is default
/*
** LEGACY
** The following rules are included for compatibility with JSHint and
** JSLint. While the names of the rules may not match up with the
** JSHint/JSLint counterpart, the functionality is the same.
*/
"max-depth": 0, // `[2, 4]` is default
"max-len": 0, // `[2, 80, 4]` is default, optionally set `[2, 80, 4, {"ignoreComments": true, "ignoreUrls": true}]`
"max-params": 0, // no default, optionally set `[2, 3]`
"max-statements": 0, // no default, optionally set `[2, 2]`
"no-bitwise": 1, // `2` is default
"no-plusplus": 0, // `2` is default
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment