Skip to content

A JavaScript visitor utility for directed-acyclic graphs

License

Notifications You must be signed in to change notification settings

seanzer/dag-visitor

Repository files navigation

dag-visitor

A generic visitor library for directed-acyclic graphs in JavaScript. The purpose of this library is to use best practices for traversing a graph. It avoids using recursion to enable processing of large graphs.

Example usage

// Setup a DAG
const a = { id: 'a', children: []};
const b = { id: 'b', children: []};
a.children.push(b);

const dfsVisitor = new DfsVisitor(
    (node) => { 
        console.log(`previsit: ${node.id}`); 
        return node.children; 
    },
    (node) => { console.log(`postvisit: ${node.id}`); });

dfsVisitor.visit([a, b]);

// previsit: a
// previsit: b
// postvisit: b
// postvisit: a

About

A JavaScript visitor utility for directed-acyclic graphs

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published