tools: simplify lowercase-name-for-primitive rule
PR-URL: https://github.com/nodejs/node/pull/17653 Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Jon Moss <me@jonathanmoss.me> Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de> Reviewed-By: Anatoli Papirovski <apapirovski@mac.com>
This commit is contained in:
parent
eecea2e0e5
commit
203ce5f9e0
@ -9,41 +9,38 @@
|
||||
// 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) {
|
||||
return {
|
||||
NewExpression(node) {
|
||||
if (
|
||||
node.callee.property &&
|
||||
node.callee.property.name === 'TypeError' &&
|
||||
node.arguments[0].value === 'ERR_INVALID_ARG_TYPE'
|
||||
) {
|
||||
checkNamesArgument(node.arguments[2]);
|
||||
}
|
||||
function checkNamesArgument(node) {
|
||||
const names = node.arguments[2];
|
||||
|
||||
function checkNamesArgument(names) {
|
||||
switch (names.type) {
|
||||
case 'Literal':
|
||||
checkName(names.value);
|
||||
break;
|
||||
case 'ArrayExpression':
|
||||
names.elements.forEach((name) => {
|
||||
checkName(name.value);
|
||||
});
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
function checkName(name) {
|
||||
const lowercaseName = name.toLowerCase();
|
||||
if (primitives.includes(lowercaseName) && !primitives.includes(name)) {
|
||||
const msg = `primitive should use lowercase: ${name}`;
|
||||
context.report(node, msg);
|
||||
}
|
||||
}
|
||||
switch (names.type) {
|
||||
case 'Literal':
|
||||
checkName(node, names.value);
|
||||
break;
|
||||
case 'ArrayExpression':
|
||||
names.elements.forEach((name) => {
|
||||
checkName(node, name.value);
|
||||
});
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
function checkName(node, name) {
|
||||
const lowercaseName = name.toLowerCase();
|
||||
if (primitives.includes(lowercaseName) && !primitives.includes(name)) {
|
||||
const msg = `primitive should use lowercase: ${name}`;
|
||||
context.report(node, msg);
|
||||
}
|
||||
}
|
||||
|
||||
return {
|
||||
[astSelector]: (node) => checkNamesArgument(node)
|
||||
};
|
||||
};
|
||||
|
Loading…
x
Reference in New Issue
Block a user