PHP WebShell

Текущая директория: /opt/BitGoJS/node_modules/@lerna/collect-updates/lib

Просмотр файла: collect-dependents.js

"use strict";

module.exports.collectDependents = collectDependents;

/**
 * @callback LocalDependentVisitor
 * @param {import("@lerna/package-graph").PackageGraphNode} dependentNode
 * @param {string} dependentName
 * @param {Map<string, import("@lerna/package-graph").PackageGraphNode>} siblingDependents
 */

/**
 * Build a set of nodes that are dependents of the input set.
 * @param {Set<import("@lerna/package-graph").PackageGraphNode>} nodes
 */
function collectDependents(nodes) {
  /** @type {typeof nodes} */
  const collected = new Set();

  nodes.forEach((currentNode) => {
    if (currentNode.localDependents.size === 0) {
      // no point diving into a non-existent tree
      return;
    }

    // breadth-first search
    const queue = [currentNode];
    const seen = new Set();

    /** @type {LocalDependentVisitor} */
    const visit = (dependentNode, dependentName, siblingDependents) => {
      if (seen.has(dependentNode)) {
        return;
      }

      seen.add(dependentNode);

      if (dependentNode === currentNode || siblingDependents.has(currentNode.name)) {
        // a direct or transitive cycle, skip it
        return;
      }

      collected.add(dependentNode);
      queue.push(dependentNode);
    };

    while (queue.length) {
      const node = queue.shift();

      node.localDependents.forEach(visit);
    }
  });

  return collected;
}

Выполнить команду


Для локальной разработки. Не используйте в интернете!