NAME

SVN::Simple::Hook::PreCommit - Role for Subversion pre-commit hooks

VERSION

version 0.210

SYNOPSIS

package MyHook::Cmd;
use Moose;
extends 'MooseX::App::Cmd';

package MyHook::Cmd::Command::pre_commit;
use Moose;
extends 'MooseX::App::Cmd::Command';
with 'SVN::Simple::Hook::PreCommit';

sub execute {
    my ( $self, $opt, $args ) = @_;
    my $txn = $self->txn();

    warn $self->author, ' changed ',
        scalar keys %{ $self->root->paths_changed() }, " paths\n";

    return;
}

DESCRIPTION

This Moose::Role gives you access to the current Subversion transaction for use in a pre-commit hook. It's designed for use with MooseX::App::Cmd::Command classes, so consult the main MooseX::App::Cmd documentation for details on how to extend it to create your scripts.

ATTRIBUTES

txn_name

Full name of the transaction to check in the repository.

transaction

The current Subversion transaction, automatically populated at object creation time when the txn_name is set.

author

The author of the current transaction as required by all SVN::Simple::Hook consumers.

root

The Subversion root node as required by all SVN::Simple::Hook consumers.

Example hooks/pre-commit hook script

#!/bin/sh

REPOS="$1"
TXN="$2"

perl -MMyHook::Cmd -e 'MyHook::Cmd->run()' pre_commit -r "$REPOS" -t "$TXN" || exit 1
exit 0

BUGS

Please report any bugs or feature requests on the bugtracker website https://github.com/mjgardner/svn-simple-hook/issues

When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature.

AUTHOR

Mark Gardner <mjgardner@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2011 by GSI Commerce.

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