NAME
Build::Hopen::G::Runnable - parent class for runnable things in a hopen graph
SYNOPSIS
Anything with "run" inherits from this. TODO should this be a role?
ATTRIBUTES
need
Inputs this Runnable requires. A Build::Hopen::Util::NameSet, with the restriction that need
may not contain regexes. ("Sorry, I can't run unless you give me every variable in the world that starts with Q." I don't think so!)
scope
If defined, a Build::Hopen::Scope that will have the final say on the data used by "run". This is the basis of the fine-grained override mechanism in hopen.
want
Inputs this Runnable accepts but does not require. A Build::Hopen::Util::NameSet, which may include regexes.
FUNCTIONS
run
Run the operation, whatever that means. Must return a new hashref. Must be implemented by subclasses. Usage:
my $hrOutputs = $op->run([options])
Options are:
- -scope
-
A Build::Hopen::Scope or subclass including the inputs the caller wants to pass to the Runnable. The Runnable itself should use its own "scope", usually by setting
$self->scope->outer($outer_scope)
within itsrun()
call. - -phase
-
If given, the phase that is currently under way in a build-system run.
- -generator
-
If given, the Build::Hopen::Gen instance in use for the current build-system run.
See the source for this function, which contains as an example of setting the scope.
passthrough
Returns a new hashref of this Runnable's local values, as defined by "local" in Build::Hopen::Scope. Usage:
my $hashref = $runnable->passthrough([-scope => $outer_scope])