Skip to main content
Glama
by Ritesh-sudo
querying.js4 kB
/** * Find all elements matching the query. If not in XML mode, the query will ignore * the contents of `<template>` elements. * * @param query - Function that returns true if the element matches the query. * @param elems - Nodes to query. If a node is an element, its children will be queried. * @param options - Options for querying the document. * @returns All matching elements. */ export function findAll(query, elems, options) { const { adapter, xmlMode = false } = options; const result = []; /** Stack of the arrays we are looking at. */ const nodeStack = [elems]; /** Stack of the indices within the arrays. */ const indexStack = [0]; for (;;) { // First, check if the current array has any more elements to look at. if (indexStack[0] >= nodeStack[0].length) { // If we have no more arrays to look at, we are done. if (nodeStack.length === 1) { return result; } nodeStack.shift(); indexStack.shift(); // Loop back to the start to continue with the next array. continue; } const elem = nodeStack[0][indexStack[0]++]; if (!adapter.isTag(elem)) continue; if (query(elem)) result.push(elem); if (xmlMode || adapter.getName(elem) !== "template") { /* * Add the children to the stack. We are depth-first, so this is * the next array we look at. */ const children = adapter.getChildren(elem); if (children.length > 0) { nodeStack.unshift(children); indexStack.unshift(0); } } } } /** * Find the first element matching the query. If not in XML mode, the query will ignore * the contents of `<template>` elements. * * @param query - Function that returns true if the element matches the query. * @param elems - Nodes to query. If a node is an element, its children will be queried. * @param options - Options for querying the document. * @returns The first matching element, or null if there was no match. */ export function findOne(query, elems, options) { const { adapter, xmlMode = false } = options; /** Stack of the arrays we are looking at. */ const nodeStack = [elems]; /** Stack of the indices within the arrays. */ const indexStack = [0]; for (;;) { // First, check if the current array has any more elements to look at. if (indexStack[0] >= nodeStack[0].length) { // If we have no more arrays to look at, we are done. if (nodeStack.length === 1) { return null; } nodeStack.shift(); indexStack.shift(); // Loop back to the start to continue with the next array. continue; } const elem = nodeStack[0][indexStack[0]++]; if (!adapter.isTag(elem)) continue; if (query(elem)) return elem; if (xmlMode || adapter.getName(elem) !== "template") { /* * Add the children to the stack. We are depth-first, so this is * the next array we look at. */ const children = adapter.getChildren(elem); if (children.length > 0) { nodeStack.unshift(children); indexStack.unshift(0); } } } } export function getNextSiblings(elem, adapter) { const siblings = adapter.getSiblings(elem); if (siblings.length <= 1) return []; const elemIndex = siblings.indexOf(elem); if (elemIndex < 0 || elemIndex === siblings.length - 1) return []; return siblings.slice(elemIndex + 1).filter(adapter.isTag); } export function getElementParent(node, adapter) { const parent = adapter.getParent(node); return parent != null && adapter.isTag(parent) ? parent : null; } //# sourceMappingURL=querying.js.map

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/Ritesh-sudo/MCPJobSearch'

If you have feedback or need assistance with the MCP directory API, please join our Discord server