UNPKG

@exadel/eslint-plugin-esl

Version:

Helper ESLint rules to find and migrate ESL (@exadel/esl) library deprecations

43 lines (42 loc) 1.63 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __exportStar = (this && this.__exportStar) || function(m, exports) { for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.findRoot = findRoot; exports.collectAll = collectAll; exports.findAllBy = findAllBy; const ast_traverse_1 = require("./ast.traverse"); __exportStar(require("./ast.traverse"), exports); /** Finds the root node in the tree */ function findRoot(node) { while (node.parent) node = node.parent; return node; } /** Collect all current and nested AST nodes */ function collectAll(context, root) { return [...(0, ast_traverse_1.traverseNodes)(context, root)].map((path) => path.node); } /** Find all AST nodes by shape */ function findAllBy(context, root, shape) { const result = []; for (const node of (0, ast_traverse_1.traverseNodes)(context, root)) { const { node: current } = node; if (Object.keys(shape).every((key) => current[key] === shape[key])) { result.push(current); } } return result; }