summaryrefslogtreecommitdiff
path: root/tools/eslint-rules
diff options
context:
space:
mode:
authorcjihrig <cjihrig@gmail.com>2017-12-13 11:14:02 -0500
committercjihrig <cjihrig@gmail.com>2017-12-15 11:19:01 -0500
commit203ce5f9e0a9bdacf31214ed4b5cda00686353e7 (patch)
treee8b20de22604b432de3e3f9519689798c1048387 /tools/eslint-rules
parenteecea2e0e51db58dba00ccf36554c42cb814bae9 (diff)
downloadandroid-node-v8-203ce5f9e0a9bdacf31214ed4b5cda00686353e7.tar.gz
android-node-v8-203ce5f9e0a9bdacf31214ed4b5cda00686353e7.tar.bz2
android-node-v8-203ce5f9e0a9bdacf31214ed4b5cda00686353e7.zip
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>
Diffstat (limited to 'tools/eslint-rules')
-rw-r--r--tools/eslint-rules/lowercase-name-for-primitive.js53
1 files changed, 25 insertions, 28 deletions
diff --git a/tools/eslint-rules/lowercase-name-for-primitive.js b/tools/eslint-rules/lowercase-name-for-primitive.js
index bdf10328f3..cb603b62c0 100644
--- a/tools/eslint-rules/lowercase-name-for-primitive.js
+++ b/tools/eslint-rules/lowercase-name-for-primitive.js
@@ -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;
- }
- }
+ switch (names.type) {
+ case 'Literal':
+ checkName(node, names.value);
+ break;
+ case 'ArrayExpression':
+ names.elements.forEach((name) => {
+ checkName(node, 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);
- }
- }
+ 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)
};
};