NAME
Algorithm::DependencySolver::Traversal - A module for traversing a dependency graph
SYNOPSIS
my $traversal = Algorithm::DependencySolver::Traversal->new(
Solver => $solver,
visit => sub {
my $operation = shift;
print "Visited operation: ", $operation->id, "\n";
},
);
$traversal->run;
DESCRIPTION
Given an Algorithm::DependencySolver::Solver.pm object, traverses it in such a way that upon entering a node, all of its prerequisites will have already been entered.
Concurrency
Currently this module is not thread-safe. However, it has been design in such a way that it should be easy to allow concurrency at a later stage, without needing to break backwards compatibility.
Note that if we allow concurrency, the visitable
list may be empty, without indicating that the traversal is complete.
METHODS
choose
During the traversal, we maintain a list of nodes, visitable
, which can be immediately visited. If this list is empty, the traversal is complete.
The choose
function is called to decide which node is visitable
to visit next. Note that choose
is guaranteed to be called, even if visitable
is a singleton (but not if it's empty).
dryrun
Create a linear path and return it as an array of the arguments that would have been passed into the visit
function.
Use run_path
to run a path created by dryrun
.