@stead/dep-graph
v0.0.2
Published
Simple dependency graphs
Downloads
109
Readme
Dependency Graph
Simple dependency graphs
A simple dependency graph tool useful for determining the order to do a list of things that depend on certain items being done before they are.
Installation
npm i @stead/dep-graph
yarn add @stead/dep-graph
API
DepGraph
Nodes in the graph are just simple strings with optional data associated with them.
addNode(name, data)
- add a node in the graph with optional data. Ifdata
is not given,name
will be used as dataremoveNode(name)
- remove a node from the graphhasNode(name)
- check if a node exists in the graphsize()
- return the number of nodes in the graphgetNodeData(name)
- get the data associated with a node (will throw anError
if the node does not exist)setNodeData(name, data)
- set the data for an existing node (will throw anError
if the node does not exist)addDependency(from, to)
- add a dependency between two nodes (will throw anError
if one of the nodes does not exist)removeDependency(from, to)
- remove a dependency between two nodesclone()
- return a clone of the graph. Any data attached to the nodes will only be shallow-copieddependenciesOf(name, leavesOnly)
- get an array containing the nodes that the specified node depends on (transitively). IfleavesOnly
is true, only nodes that do not depend on any other nodes will be returned in the array.dependantsOf(name, leavesOnly)
- get an array containing the nodes that depend on the specified node (transitively). IfleavesOnly
is true, only nodes that do not have any dependants will be returned in the array.overallOrder(leavesOnly)
- construct the overall processing order for the dependency graph. IfleavesOnly
is true, only nodes that do not depend on any other nodes will be returned.
Dependency Cycles are detected when running dependenciesOf
, dependantsOf
, and overallOrder
and if one is found, a DepGraphCycleError
will be thrown that includes what the cycle was in the message as well as the cyclePath
property: e.g. Dependency Cycle Found: a -> b -> c -> a
. If you wish to silence this error, pass circular: true
when instantiating DepGraph
(more below).
Examples
import { DepGraph } from '@stead/dep-graph';
const graph = new DepGraph();
graph.addNode('a');
graph.addNode('b');
graph.addNode('c');
graph.size() // 3
graph.addDependency('a', 'b');
graph.addDependency('b', 'c');
graph.dependenciesOf('a'); // ['c', 'b']
graph.dependenciesOf('b'); // ['c']
graph.dependantsOf('c'); // ['a', 'b']
graph.overallOrder(); // ['c', 'b', 'a']
graph.overallOrder(true); // ['c']
graph.addNode('d', 'data');
graph.getNodeData('d'); // 'data'
graph.setNodeData('d', 'newData');
graph.getNodeData('d'); // 'newData'
graph.transpose(); // Reverse all edges of the graph
const circularGraph = new DepGraph({ circular: true });
circularGraph.addNode('a');
circularGraph.addNode('b');
circularGraph.addNode('c');
circularGraph.addNode('d');
circularGraph.addDependency('a', 'b');
circularGraph.addDependency('b', 'c'); // b depends on c
circularGraph.addDependency('c', 'a'); // c depends on a, which depends on b
circularGraph.addDependency('d', 'a');
circularGraph.dependenciesOf('b'); // ['a', 'c']
circularGraph.overallOrder(); // ['c', 'b', 'a', 'd']