summaryrefslogtreecommitdiff
path: root/tools/eslint-rules/lowercase-name-for-primitive.js
blob: cfe17c06c12535c837e0c32cc279e6ceefb1d889 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/**
 * @fileoverview Check that TypeError[ERR_INVALID_ARG_TYPE] uses
 *               lowercase for primitive types
 * @author Weijia Wang <starkwang@126.com>
 */
'use strict';

//------------------------------------------------------------------------------
// Rule Definition
//------------------------------------------------------------------------------

const astSelector = 'NewExpression[callee.property.name="TypeError"]' +
                    '[arguments.0.value="ERR_INVALID_ARG_TYPE"]';

const primitives = [ 'number', 'string', 'boolean', 'null', 'undefined' ];

module.exports = function(context) {
  function checkNamesArgument(node) {
    const names = node.arguments[2];

    switch (names.type) {
      case 'Literal':
        checkName(names);
        break;
      case 'ArrayExpression':
        names.elements.forEach((name) => {
          checkName(name);
        });
        break;
    }
  }

  function checkName(node) {
    const name = node.value;
    const lowercaseName = name.toLowerCase();
    if (name !== lowercaseName && primitives.includes(lowercaseName)) {
      const msg = `primitive should use lowercase: ${name}`;
      context.report({
        node,
        message: msg,
        fix: (fixer) => {
          return fixer.replaceText(
            node,
            `'${lowercaseName}'`
          );
        }
      });
    }

  }

  return {
    [astSelector]: (node) => checkNamesArgument(node)
  };
};