NAME

Data::Hopen::G - Namespace for graph-related items in hopen

SYNOPSIS

Almost everything graph-related in hopen lives under Data::Hopen::G. This includes nodes, edges, and graphs (specifically, directed acyclic graphs, DAGs).

Classes are (all under Data::Hopen::G):

Entity - something in the graph
    Runnable - something that has a run() method and need/want namesets
                (TODO should this be a Role::Tiny role?)
        Link - connection between Nodes
        Node - abstract graph node
            Op - abstract operation
                Goal - a node that just gives a name to a set of operations
                PassthroughOp - no-op concrete operation
                DAG - the graph

Specific use cases of the graph are not under ...::G. For example, tools used in the hopen build system are under Data::Hopen::Tool.

ELEMENTS

Data::Hopen::G::Op

An operation. Operations can, e.g., transform their inputs or invoke a generator routine (Data::Hopen::Gen) based on their inputs. Operations can output values representing the generator action they took, or that will later be used by the generator or downstream nodes.

A connection between operations. Edges should, generally speaking, not invoke generator routines. Instead, they should transform their inputs to outputs, possibly with reference to the environment or (if necessary) the identity (but not details) of the generator in use.

Data::Hopen::G::DAG

A graph of operations and edges. Every relationship between operations and edges is expressed in a DAG. A DAG has zero or more goals (Data::Hopen::G::Goal) that represent named activities expressed in the DAG.