Module-Provision
view release on metacpan or search on metacpan
lib/Module/Provision/TraitFor/UpdatingContent.pm view on Meta::CPAN
package Module::Provision::TraitFor::UpdatingContent;
use namespace::autoclean;
use Class::Usul::Constants qw( EXCEPTION_CLASS OK );
use Class::Usul::Functions qw( throw );
use Unexpected::Functions qw( Unspecified );
use Moo::Role;
requires qw( appldir loc manifest_paths next_argv output );
# Private methods
my $_get_ignore_rev_regex = sub {
my $self = shift;
my $ignore_rev = $self->appldir->catfile( '.gitignore-rev' )->chomp;
return $ignore_rev->exists ? join '|', $ignore_rev->getlines : undef;
};
my $_get_update_args = sub {
return ($_[ 0 ]->next_argv, $_[ 0 ]->next_argv);
};
# Public methods
sub substitute_version {
my ($self, $path, $from, $to) = @_;
$path->substitute( "\Q\'${from}.%d\',\E", "\'${to}.%d\'," );
$path->substitute( "\Q v${from}.\$Rev\E", " v${to}.\$Rev" );
return;
}
sub update_copyright_year : method {
my $self = shift; my ($from, $to) = $self->$_get_update_args;
my $prefix = $self->loc( 'Copyright (c)' );
$from or throw Unspecified, [ 'from' ];
$to or throw Unspecified, [ 'to' ];
$self->quiet or $self->output( 'Updating copyright year' );
for my $path (@{ $self->manifest_paths }) {
$path->substitute( "\Q${prefix} ${from}\E", "${prefix} ${to}" );
}
return OK;
}
sub update_version : method {
my $self = shift; my ($from, $to) = $self->$_get_update_args;
my $ignore = $self->$_get_ignore_rev_regex;
$self->quiet or $self->output( 'Updating version numbers' );
($from, $to) = $self->update_version_pre_hook( $from, $to );
for my $path (@{ $self->manifest_paths }) {
$ignore and $path =~ m{ (?: $ignore ) }mx and next;
$self->substitute_version( $path, $from, $to );
}
$self->update_version_post_hook( $from, $to );
return OK;
}
sub update_version_post_hook { # Can be modified by applied traits
}
sub update_version_pre_hook { # Can be modified by applied traits
my ($self, @args) = @_;
($args[ 0 ] and $args[ 1 ]) or throw 'Insufficient arguments';
return @args;
}
1;
__END__
=pod
=encoding utf8
=head1 Name
Module::Provision::TraitFor::UpdatingContent - Perform search and replace on project file content
=head1 Synopsis
use Moose;
extends 'Module::Provision::Base';
with 'Module::Provision::TraitFor::UpdatingContent';
=head1 Description
Perform search and replace on project file content
=head1 Configuration and Environment
Requires the following attributes to be defined in the consuming
class; C<appldir>
Defines no attributes
=head1 Subroutines/Methods
=head2 substitute_version
$self->substitute_version( $path, $from, $to );
Substitutes the C<$to> string everywhere the C<$from> pattern occurs
in the C<$path> file. The C<$path> argument should be of type
L<File::DataClass::IO>
=head2 update_copyright_year - Updates the copyright year in the POD
$exit_code = $self->update_copyright_year;
Substitutes the existing copyright year for the new copyright year in all
files in the F<MANIFEST>
=head2 update_version - Updates the version numbers in all files
$exit_code = $self->update_version;
Substitutes the existing version number for the new version number in all
files in the F<MANIFEST>
( run in 0.412 second using v1.01-cache-2.11-cpan-5511b514fd6 )