NAME
    Git::PurePerl::Walker - Walk over a sequence of commits in a
    Git::PurePerl repo

VERSION
    version 0.003000

SYNOPSIS
            use Git::PurePerl::Walker;
            use Git::PurePerl::Walker::Method::FirstParent;

            my $repo = Git::PurePerl->new( ... );

            my $walker = Git::PurePerl::Walker->new(
                    repo => $repo,
                    method => Git::PurePerl::Walker::Method::FirstParent->new(
                            start => $repo->ref_sha1('refs/heads/master'),
                    ),
                    on_commit => sub {
                            my ( $commit ) = @_;
                            print $commit->sha1;
                    },
            );

            $walker->step_all;

CONSTRUCTOR ARGUMENTS
  repo
    Mandatory: An instance of "Git::PurePerl" representing the repository to
    work with.

  method
    Mandatory: either a "Str" describing a Class Name Suffix, or an "Object"
    that "does" "Git::PurePerl::Walker::Role::Method".

    If its a "Str", the "Str" will be expanded as follows:

            ->new(
                    ...
                    method => 'Foo',
                    ...
            );

            $className = 'Git::PurePerl::Walker::Method::Foo'

    And the resulting class will be loaded, and instantiated for you. (
    Assuming of course, you don't need to pass any fancy args ).

    If you need fancy args, or a class outside the
    "Git::PurePerl::Walker::Method::" namespace, constructing the object
    will have to be your responsibility.

            ->new(
                    ...
                    method => Foo::Class->new(),
                    ...
            )

  on_commit
    Mandatory: either a "Str" that can be expanded in a way similar to that
    by "*method*", a "CodeRef", or an object that "does"
    "Git::PurePerl::Walker::Role::OnCommit".

    If passed a "Str" it will be expanded like so:

            ->new(
                    ...
                    on_commit => $str,
                    ...
            );

            $class = 'Git::PurePerl::Walker::OnCommit::' . $str;

    And the resulting class loaded and instantiated.

    If passed a "CodeRef", "Git::PurePerl::Walker::OnCommit::CallBack" will
    be loaded and your "CodeRef" will be passed as an argument.

            ->new(
                    ...
                    on_commit => sub {
                            my ( $commit ) = @_;

                    },
                    ...
            );

    If you need anything fancier, or requiring an unusual namespace, you'll
    want to construct the object yourself.

            ->new(
                    ...
                    on_commit => Foo::Package->new()
                    ...
            );

METHODS
  reset
            $walker->reset();

    Reset the walk routine back to the state it was before you walked.

  step
    Increments one step forward in the git history, and dispatches the
    object to the "OnCommit" handlers.

    If there are more possible steps to take, it will return a true value.

            while ( $walker->step ) {
                    /* Code to execute if walker has more items */
            }

    This code is almost identical to:

            while(1) {
                    $walker->on_commit->handle( $walker->method->current );

                    last if not $walker->method->has_next;

                    $walker->method->next;

                    /*  Code to execute if walker has more items */
            }

  step_all
            my $steps = $walker->step_all;

    Mostly a convenience method to iterate until it can iterate no more, but
    without you needing to wrap it in a while() block.

    Returns the number of steps executed.

ATTRIBUTES
  repo
  method
  on_commit
ATTRIBUTE GENERATED METHODS
  repo
            # Getter
            my $repo = $walker->repo();

  method
            # Getter
            my $method_object = $walker->method();

  on_commit
            # Getter
            my $on_commit_object = $walker->on_commit();

PRIVATE ATTRIBUTES
  _method
  _on_commit
PRIVATE METHODS
  _build_repo
  _build_method
  _build_on_commit
PRIVATE ATTRIBUTE GENERATED METHODS
  _method
            # Getter
            my $methodish = $walker->_method();

  _on_commit
            # Getter
            my $on_commitish => $walker->_on_commit();

AUTHOR
    Kent Fredric <kentnl@cpan.org>

COPYRIGHT AND LICENSE
    This software is copyright (c) 2014 by Kent Fredric <kentnl@cpan.org>.

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