mirror of
https://github.com/zebrajr/node.git
synced 2026-01-15 12:15:26 +00:00
tools: autofixer for lowercase-name-for-primitive
PR-URL: https://github.com/nodejs/node/pull/17715 Refs: https://github.com/nodejs/node/issues/16636 Reviewed-By: Anatoli Papirovski <apapirovski@mac.com> Reviewed-By: Weijia Wang <starkwang@126.com>
This commit is contained in:
committed by
Weijia Wang
parent
8331f571ed
commit
639770c8d6
@@ -22,20 +22,28 @@ new RuleTester().run('lowercase-name-for-primitive', rule, {
|
||||
],
|
||||
invalid: [
|
||||
{
|
||||
code: 'new errors.TypeError("ERR_INVALID_ARG_TYPE", "a", "Number")',
|
||||
errors: [{ message: 'primitive should use lowercase: Number' }]
|
||||
code: 'new errors.TypeError(\'ERR_INVALID_ARG_TYPE\', \'a\', ' +
|
||||
'\'Number\')',
|
||||
errors: [{ message: 'primitive should use lowercase: Number' }],
|
||||
output: 'new errors.TypeError(\'ERR_INVALID_ARG_TYPE\', \'a\', ' +
|
||||
'\'number\')'
|
||||
},
|
||||
{
|
||||
code: 'new errors.TypeError("ERR_INVALID_ARG_TYPE", "a", "STRING")',
|
||||
errors: [{ message: 'primitive should use lowercase: STRING' }]
|
||||
code: 'new errors.TypeError(\'ERR_INVALID_ARG_TYPE\', \'a\', ' +
|
||||
'\'STRING\')',
|
||||
errors: [{ message: 'primitive should use lowercase: STRING' }],
|
||||
output: 'new errors.TypeError(\'ERR_INVALID_ARG_TYPE\', \'a\', ' +
|
||||
'\'string\')'
|
||||
},
|
||||
{
|
||||
code: 'new errors.TypeError("ERR_INVALID_ARG_TYPE", "a",' +
|
||||
'["String", "Number"])',
|
||||
code: 'new errors.TypeError(\'ERR_INVALID_ARG_TYPE\', \'a\', ' +
|
||||
'[\'String\', \'Number\']) ',
|
||||
errors: [
|
||||
{ message: 'primitive should use lowercase: String' },
|
||||
{ message: 'primitive should use lowercase: Number' }
|
||||
]
|
||||
],
|
||||
output: 'new errors.TypeError(\'ERR_INVALID_ARG_TYPE\', \'a\', ' +
|
||||
'[\'string\', \'number\']) '
|
||||
}
|
||||
]
|
||||
});
|
||||
|
||||
@@ -22,22 +22,33 @@ module.exports = function(context) {
|
||||
|
||||
switch (names.type) {
|
||||
case 'Literal':
|
||||
checkName(node, names.value);
|
||||
checkName(names);
|
||||
break;
|
||||
case 'ArrayExpression':
|
||||
names.elements.forEach((name) => {
|
||||
checkName(node, name.value);
|
||||
checkName(name);
|
||||
});
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
function checkName(node, name) {
|
||||
function checkName(node) {
|
||||
const name = node.value;
|
||||
const lowercaseName = name.toLowerCase();
|
||||
if (primitives.includes(lowercaseName) && !primitives.includes(name)) {
|
||||
if (name !== lowercaseName && primitives.includes(lowercaseName)) {
|
||||
const msg = `primitive should use lowercase: ${name}`;
|
||||
context.report(node, msg);
|
||||
context.report({
|
||||
node,
|
||||
message: msg,
|
||||
fix: (fixer) => {
|
||||
return fixer.replaceText(
|
||||
node,
|
||||
`'${lowercaseName}'`
|
||||
);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
return {
|
||||
|
||||
Reference in New Issue
Block a user