NAME
Data::Hopen::G::GraphBuilder - fluent interface for building graphs
SYNOPSIS
A GraphBuilder wraps a Data::Hopen::G::DAG and a current Data::Hopen::G::Node. It permits building chains of nodes in a fluent way. For example, in an App::hopen hopen file:
# $Build is a Data::Hopen::G::DAG created by App::hopen
use language 'C';
my $builder = $Build->C::compile(file => 'foo.c');
# Now $builder holds $Build (the DAG) and a node created by
# C::compile().
ATTRIBUTES
name
An optional name, in case you want to identify your Builder instances.
dag
The current Data::Hopen::G::DAG instance, if any.
node
The current Data::Hopen::G::Node instance, if any.
INSTANCE FUNCTIONS
add
Adds a node to the graph. Returns the node. Note that this does not change the builder's current node ("node").
default_goal
Links the most recent node in the chain to the default goal in the DAG. If the DAG does not have a default goal, adds one called "all".
As a side effect, calling this function clears the builder's record of the current node and returns undef
. The idea is that this function will be used at the end of a chain of calls. Clearing state in this way reduces the chance of unintentionally connecting nodes.
goal
Links the most recent node in the chain to the given goal in the DAG. Clears the builder's record of the current node and returns undef.
to
Connect one node to another, where both are wrapped in GraphBuilder
s. Usage:
$builder_1->to($builder_2);
# No $builder_1->node has an edge to $builder_2->node
Returns undef
, because chaining would be ambiguous. For example, in the snippet above, would the chain continue from $builder_1
or $builder_2
?
Does not change the state of either GraphBuilder.
STATIC FUNCTIONS
make_GraphBuilder
Given the name of a subroutine, wrap the given subroutine for use in a GraphBuilder chain such as that shown in the "SYNOPSIS". Usage:
sub worker {
my $graphbuilder = shift;
...
return $node; # Will automatically be linked into the chain
}
make_GraphBuilder 'worker';
# now worker can take a DAG or GraphBuilder, and the
# return value will be the GraphBuilder.
The worker
subroutine is called in scalar context.