use 5.008;
use strict;
# ABSTRACT: provide the allow_dirty & changelog attributes
use MooseX::Types::Moose qw{ ArrayRef Str };
# -- attributes
has allow_dirty => (
ro, lazy,
isa => ArrayRef[Str],
builder => '_build_allow_dirty',
);
has changelog => ( ro, isa=>Str, default => 'Changes' );
around mvp_multivalue_args => sub {
my ($orig, $self) = @_;
my @start = $self->$orig;
return (@start, 'allow_dirty');
};
# -- builders & initializers
sub _build_allow_dirty { [ 'dist.ini', shift->changelog ] }
sub list_dirty_files
{
my ($self, $listAllowed) = @_;
my $allowlist = $self->allow_dirty;
my %allowed = map { $_ => 1 } @$allowlist;
my @file = qx "svk status";
my @uncommitted = grep m/^("?M|D)/, @file;
chomp @uncommitted;
s/^.*\s(\S+)$/$1/ for @uncommitted;
return grep { $allowed{$_} ? $listAllowed : ! $listAllowed } @uncommitted;
} # end list_dirty_files
no Moose::Role;
no MooseX::Has::Sugar;
1;
=pod
=head1 NAME
Dist::Zilla::Role::SVK::DirtyFiles - provide the allow_dirty & changelog attributes
=head1 VERSION
version 0.02
=head1 DESCRIPTION
This role is used within the svk (was: git) plugin to work with files that are
dirty in the local svk checkout.
=head1 ATTRIBUTES
=head2 allow_dirty
A list of files that are allowed to be dirty in the svk checkout.
Defaults to C<dist.ini> and the changelog (as defined per the
C<changelog> attribute.
=head2 changelog
The name of the changelog. Defaults to C<Changes>.
=head1 METHODS
=head2 list_dirty_files
my @dirty = $plugin->list_dirty_files($listAllowed);
This returns a list of the modified or deleted files in the checkout, filtered against the C<allow_dirty> attribute, excluding dot files. If C<$listAllowed> is true, only allowed files are listed. If it's false, only files that are not allowed to be dirty are listed.
In scalar context, returns the number of dirty files.
=for Pod::Coverage mvp_multivalue_args
=head1 AUTHOR
Dr Bean <drbean at (a) cpan dot (.) org>
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2010 by Dr Bean.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
=cut
__END__