Blame view
node_modules/eslint/lib/rules/guard-for-in.js
1.17 KB
f7563de62
|
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 |
/** * @fileoverview Rule to flag for-in loops without if statements inside * @author Nicholas C. Zakas */ "use strict"; //------------------------------------------------------------------------------ // Rule Definition //------------------------------------------------------------------------------ module.exports = { meta: { docs: { description: "require `for-in` loops to include an `if` statement", category: "Best Practices", recommended: false }, schema: [] }, create(context) { return { ForInStatement(node) { /* * If the for-in statement has {}, then the real body is the body * of the BlockStatement. Otherwise, just use body as provided. */ const body = node.body.type === "BlockStatement" ? node.body.body[0] : node.body; if (body && body.type !== "IfStatement") { context.report({ node, message: "The body of a for-in should be wrapped in an if statement to filter unwanted properties from the prototype." }); } } }; } }; |