@exadel/eslint-plugin-esl
Version:
Helper ESLint rules to find and migrate ESL (@exadel/esl) library deprecations
43 lines (42 loc) • 1.63 kB
JavaScript
;
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;
}