NAME

ExtUtils::Builder::Planner - An ExtUtils::Builder Plan builder

VERSION

version 0.009

SYNOPSIS

my $planner = ExtUtils::Builder::Planner->new;
$planner->create_node(
    target       => 'foo',
    dependencies => [ 'bar' ],
    actions      => \@actions,
);
my $plan = $planner->materialize;

DESCRIPTION

METHODS

add_node($node)

This adds an ExtUtils::Builder::Node to the planner.

create_node(%args)

This creates a new node and adds it to the planner using add_node. It takes the same named arguments as ExtUtils::Builder::Node.

  • target

    The target of the node. This is mandatory.

  • dependencies

    The list of dependencies for this node.

  • actions

    The actions to perform to create or update this node.

  • phony

    A boolean to mark a target as phony. This defaults to false.

add_plan($plan)

This adds all nodes in the plan to the planner.

add_delegate($name, $sub)

This adds $sub as a helper method to this planner, with the name $name.

create_phony($target, @dependencies)

This is a helper function that calls create_node for a action-free phony target.

load_module($extension, $version, %options)

This adds the delegate from the given module. If $version is defined it will verify if the extension is at least that version.

new_scope()

This opens a new scope on the planner. It return a child planner that shared the build tree state with its parent, but any delegated added to it will not be added to the parent.

run_dsl($filename)

This runs $filename as a DSL file. This is a script file that includes Planner methods as functions. For example:

 use strict;
 use warnings;

 create_node(
     target       => 'foo',
     dependencies => [ 'bar' ],
     actions      => [
		command(qw/echo Hello World!/),
		function(module => 'Foo', function => 'bar'),
		code(code => 'print "Hello World"'),
	 ],
 );

 load_module("Foo");

 add_foo("a.foo", "a.bar");

This will also add command, function and code helper functions that correspond to ExtUtils::Builder::Action::Command, ExtUtils::Builder::Action::Function and ExtUtils::Builder::Action::Code respectively.

materialize()

This returns a new ExtUtils::Builder::Plan object based on the planner.

AUTHOR

Leon Timmermans <fawaka@gmail.com>

COPYRIGHT AND LICENSE

This software is copyright (c) 2013 by Leon Timmermans.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.