diff --git a/corpus/dist/AuthorDeps/dist.ini b/corpus/dist/AuthorDeps/dist.ini index 64b973155..c180bbc6a 100644 --- a/corpus/dist/AuthorDeps/dist.ini +++ b/corpus/dist/AuthorDeps/dist.ini @@ -22,3 +22,5 @@ version = 2 :version = 5.0 encoding = bytes filename = t/data.bin + +[MetaConfig] diff --git a/corpus/dist/AutoPrereqs/dist.ini b/corpus/dist/AutoPrereqs/dist.ini index 1f1d5851a..e17edef52 100644 --- a/corpus/dist/AutoPrereqs/dist.ini +++ b/corpus/dist/AutoPrereqs/dist.ini @@ -17,3 +17,5 @@ version = 2 [Encoding] encoding = bytes filename = t/data.bin + +[MetaConfig] diff --git a/corpus/dist/DZ-NonAscii/dist.ini b/corpus/dist/DZ-NonAscii/dist.ini index 46e0c934a..e7c4ce5c7 100644 --- a/corpus/dist/DZ-NonAscii/dist.ini +++ b/corpus/dist/DZ-NonAscii/dist.ini @@ -8,3 +8,4 @@ copyright_holder = ภูมิพลอดุลยเดช [@Classic] [MetaJSON] [NextRelease] +[MetaConfig] diff --git a/corpus/dist/DZ1/dist.ini b/corpus/dist/DZ1/dist.ini index 1215b7e23..1ed1b5fe5 100644 --- a/corpus/dist/DZ1/dist.ini +++ b/corpus/dist/DZ1/dist.ini @@ -5,3 +5,4 @@ license = Perl_5 copyright_holder = E. Xavier Ample [@Classic] +[MetaConfig] diff --git a/lib/Dist/Zilla/Plugin/AutoPrereqs.pm b/lib/Dist/Zilla/Plugin/AutoPrereqs.pm index 9ddaec954..1ab1554b2 100644 --- a/lib/Dist/Zilla/Plugin/AutoPrereqs.pm +++ b/lib/Dist/Zilla/Plugin/AutoPrereqs.pm @@ -118,6 +118,19 @@ has skips => ( isa => 'ArrayRef[Str]', ); +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { + map { $_ => $self->$_ } qw(finder test_finder configure_finder extra_scanners scanners skips), + }; + + return $config; +}; + sub register_prereqs { my $self = shift; diff --git a/lib/Dist/Zilla/Plugin/AutoVersion.pm b/lib/Dist/Zilla/Plugin/AutoVersion.pm index 67066f3f4..8a3c25c52 100644 --- a/lib/Dist/Zilla/Plugin/AutoVersion.pm +++ b/lib/Dist/Zilla/Plugin/AutoVersion.pm @@ -64,6 +64,19 @@ has format => ( . q<{{$ENV{DEV} ? (sprintf '_%03u', $ENV{DEV}) : ''}}> ); +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { + map { $_ => $self->$_ } qw(major format time_zone), + }; + + return $config; +}; + sub provide_version { my ($self) = @_; diff --git a/lib/Dist/Zilla/Plugin/CPANFile.pm b/lib/Dist/Zilla/Plugin/CPANFile.pm index aa1a5c170..aaf0b02e0 100644 --- a/lib/Dist/Zilla/Plugin/CPANFile.pm +++ b/lib/Dist/Zilla/Plugin/CPANFile.pm @@ -37,6 +37,17 @@ sub _hunkify_hunky_hunk_hunks { return $str; } +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { filename => $self->filename }; + + return $config; +}; + sub gather_files { my ($self, $arg) = @_; diff --git a/lib/Dist/Zilla/Plugin/Encoding.pm b/lib/Dist/Zilla/Plugin/Encoding.pm index 46b830c99..b6c8fcf47 100644 --- a/lib/Dist/Zilla/Plugin/Encoding.pm +++ b/lib/Dist/Zilla/Plugin/Encoding.pm @@ -64,6 +64,19 @@ has matches => ( default => sub { [] }, ); +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { + map { $_ => $self->$_ } qw(encoding filenames matches), + }; + + return $config; +}; + sub set_file_encodings { my ($self) = @_; diff --git a/lib/Dist/Zilla/Plugin/ExecDir.pm b/lib/Dist/Zilla/Plugin/ExecDir.pm index fb4257dec..e51433287 100644 --- a/lib/Dist/Zilla/Plugin/ExecDir.pm +++ b/lib/Dist/Zilla/Plugin/ExecDir.pm @@ -32,5 +32,17 @@ sub find_files { } with 'Dist::Zilla::Role::ExecFiles'; + +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { dir => $self->dir }; + + return $config; +}; + __PACKAGE__->meta->make_immutable; 1; diff --git a/lib/Dist/Zilla/Plugin/FakeRelease.pm b/lib/Dist/Zilla/Plugin/FakeRelease.pm index 6d730aea4..52b820bfc 100644 --- a/lib/Dist/Zilla/Plugin/FakeRelease.pm +++ b/lib/Dist/Zilla/Plugin/FakeRelease.pm @@ -13,6 +13,17 @@ has user => ( default => 'AUTHORID', ); +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { user => $self->user }; + + return $config; +}; + sub release { my $self = shift; diff --git a/lib/Dist/Zilla/Plugin/FileFinder/ByName.pm b/lib/Dist/Zilla/Plugin/FileFinder/ByName.pm index c50933e89..7b607259a 100644 --- a/lib/Dist/Zilla/Plugin/FileFinder/ByName.pm +++ b/lib/Dist/Zilla/Plugin/FileFinder/ByName.pm @@ -107,6 +107,19 @@ sub _join_re { $re; } +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { + map { $_ => $self->$_ } qw(dirs files matches skips), + }; + + return $config; +}; + sub find_files { my $self = shift; diff --git a/lib/Dist/Zilla/Plugin/FileFinder/Filter.pm b/lib/Dist/Zilla/Plugin/FileFinder/Filter.pm index 89f01667f..0bd906475 100644 --- a/lib/Dist/Zilla/Plugin/FileFinder/Filter.pm +++ b/lib/Dist/Zilla/Plugin/FileFinder/Filter.pm @@ -59,6 +59,19 @@ sub mvp_aliases { +{ qw( sub mvp_multivalue_args { qw(skips) } +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { + map { $_ => $self->$_ } qw(finder skips), + }; + + return $config; +}; + sub find_files { my $self = shift; diff --git a/lib/Dist/Zilla/Plugin/FinderCode.pm b/lib/Dist/Zilla/Plugin/FinderCode.pm index fb14f0869..03d35ed5a 100644 --- a/lib/Dist/Zilla/Plugin/FinderCode.pm +++ b/lib/Dist/Zilla/Plugin/FinderCode.pm @@ -20,6 +20,17 @@ has style => ( required => 1, ); +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { style => $self->style }; + + return $config; +}; + sub find_files { my ($self) = @_; diff --git a/lib/Dist/Zilla/Plugin/GenerateFile.pm b/lib/Dist/Zilla/Plugin/GenerateFile.pm index e9d45f788..08bc4ee81 100644 --- a/lib/Dist/Zilla/Plugin/GenerateFile.pm +++ b/lib/Dist/Zilla/Plugin/GenerateFile.pm @@ -103,6 +103,19 @@ has name_is_template => ( default => 0, ); +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { + map { $_ => $self->$_ } qw(filename content content_is_template name_is_template), + }; + + return $config; +}; + sub gather_files { my ($self, $arg) = @_; diff --git a/lib/Dist/Zilla/Plugin/MakeMaker.pm b/lib/Dist/Zilla/Plugin/MakeMaker.pm index ac46167b4..0ed58b7f3 100644 --- a/lib/Dist/Zilla/Plugin/MakeMaker.pm +++ b/lib/Dist/Zilla/Plugin/MakeMaker.pm @@ -78,6 +78,20 @@ with qw( Dist::Zilla::Role::TextTemplate ); +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { + make_path => $self->make_path, + # default_jobs is dumped by TestRunner + }; + + return $config; +}; + my $template = q!# This file was automatically generated by {{ $generated_by }}. use strict; use warnings; diff --git a/lib/Dist/Zilla/Plugin/ManifestSkip.pm b/lib/Dist/Zilla/Plugin/ManifestSkip.pm index c295a7409..f0e28d60c 100644 --- a/lib/Dist/Zilla/Plugin/ManifestSkip.pm +++ b/lib/Dist/Zilla/Plugin/ManifestSkip.pm @@ -33,6 +33,17 @@ Other modules: L. has skipfile => (is => 'ro', required => 1, default => 'MANIFEST.SKIP'); +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { skipfile => $self->skipfile }; + + return $config; +}; + sub prune_files { my ($self) = @_; my $files = $self->zilla->files; diff --git a/lib/Dist/Zilla/Plugin/MetaJSON.pm b/lib/Dist/Zilla/Plugin/MetaJSON.pm index 98f1ad935..c484aac0a 100644 --- a/lib/Dist/Zilla/Plugin/MetaJSON.pm +++ b/lib/Dist/Zilla/Plugin/MetaJSON.pm @@ -44,6 +44,19 @@ has version => ( default => '2', ); +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { + map { $_ => $self->$_ } qw(filename version), + }; + + return $config; +}; + sub gather_files { my ($self, $arg) = @_; diff --git a/lib/Dist/Zilla/Plugin/MetaNoIndex.pm b/lib/Dist/Zilla/Plugin/MetaNoIndex.pm index 02c4a6608..7f1beb3df 100644 --- a/lib/Dist/Zilla/Plugin/MetaNoIndex.pm +++ b/lib/Dist/Zilla/Plugin/MetaNoIndex.pm @@ -92,6 +92,19 @@ for my $attr (keys %ATTR_ALIAS) { ); } +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { + map { $_ => $self->$_ } qw(directories files packages namespaces), + }; + + return $config; +}; + =method metadata Returns a reference to a hash containing the distribution's no_index metadata. diff --git a/lib/Dist/Zilla/Plugin/MetaResources.pm b/lib/Dist/Zilla/Plugin/MetaResources.pm index f61d0b5a7..ed0de0a0e 100644 --- a/lib/Dist/Zilla/Plugin/MetaResources.pm +++ b/lib/Dist/Zilla/Plugin/MetaResources.pm @@ -61,6 +61,18 @@ sub BUILDARGS { }; } +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { resources => $self->resources }; + + return $config; +}; + + sub metadata { my ($self) = @_; diff --git a/lib/Dist/Zilla/Plugin/MetaYAML.pm b/lib/Dist/Zilla/Plugin/MetaYAML.pm index 068c0cfc7..a429b9285 100644 --- a/lib/Dist/Zilla/Plugin/MetaYAML.pm +++ b/lib/Dist/Zilla/Plugin/MetaYAML.pm @@ -45,6 +45,17 @@ has version => ( default => '1.4', ); +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { version => $self->version }; + + return $config; +}; + sub gather_files { my ($self, $arg) = @_; diff --git a/lib/Dist/Zilla/Plugin/ModuleBuild.pm b/lib/Dist/Zilla/Plugin/ModuleBuild.pm index b7f34ecce..690f294a1 100644 --- a/lib/Dist/Zilla/Plugin/ModuleBuild.pm +++ b/lib/Dist/Zilla/Plugin/ModuleBuild.pm @@ -108,6 +108,19 @@ sub _dump_as { return $dumper->Dump; } +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { + map { $_ => $self->$_ } qw(mb_version mb_class mb_lib), + }; + + return $config; +}; + sub register_prereqs { my ($self) = @_; diff --git a/lib/Dist/Zilla/Plugin/ModuleShareDirs.pm b/lib/Dist/Zilla/Plugin/ModuleShareDirs.pm index 19a417b70..e2931db09 100644 --- a/lib/Dist/Zilla/Plugin/ModuleShareDirs.pm +++ b/lib/Dist/Zilla/Plugin/ModuleShareDirs.pm @@ -59,5 +59,17 @@ sub BUILDARGS { } with 'Dist::Zilla::Role::ShareDir'; + +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { module_map => $self->_module_map }; + + return $config; +}; + __PACKAGE__->meta->make_immutable; 1; diff --git a/lib/Dist/Zilla/Plugin/NextRelease.pm b/lib/Dist/Zilla/Plugin/NextRelease.pm index 849846732..593bee89a 100644 --- a/lib/Dist/Zilla/Plugin/NextRelease.pm +++ b/lib/Dist/Zilla/Plugin/NextRelease.pm @@ -96,6 +96,19 @@ sub section_header { return _format_version($self->format, $self); } +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { + map { $_ => $self->$_ } qw(time_zone format filename update_filename user_stash), + }; + + return $config; +}; + has _original_changes_content => ( is => 'rw', isa => 'Str', diff --git a/lib/Dist/Zilla/Plugin/PkgVersion.pm b/lib/Dist/Zilla/Plugin/PkgVersion.pm index 5c9e53627..2f2463dac 100644 --- a/lib/Dist/Zilla/Plugin/PkgVersion.pm +++ b/lib/Dist/Zilla/Plugin/PkgVersion.pm @@ -97,6 +97,19 @@ sub BUILD { if $self->use_our; } +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { + map { $_ => $self->$_ } qw(die_on_existing_version die_on_line_insertion), + }; + + return $config; +}; + sub munge_files { my ($self) = @_; diff --git a/lib/Dist/Zilla/Plugin/PodVersion.pm b/lib/Dist/Zilla/Plugin/PodVersion.pm index cba19f613..fb5c5dd0b 100644 --- a/lib/Dist/Zilla/Plugin/PodVersion.pm +++ b/lib/Dist/Zilla/Plugin/PodVersion.pm @@ -20,6 +20,18 @@ will not be added. =cut +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { finder => $self->finder }; + + return $config; +}; + + sub munge_files { my ($self) = @_; diff --git a/lib/Dist/Zilla/Plugin/PruneCruft.pm b/lib/Dist/Zilla/Plugin/PruneCruft.pm index b0ddf7e1f..96391bca8 100644 --- a/lib/Dist/Zilla/Plugin/PruneCruft.pm +++ b/lib/Dist/Zilla/Plugin/PruneCruft.pm @@ -84,6 +84,17 @@ sub exclude_file { return; } +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { except => $self->except }; + + return $config; +}; + sub prune_files { my ($self) = @_; diff --git a/lib/Dist/Zilla/Plugin/PruneFiles.pm b/lib/Dist/Zilla/Plugin/PruneFiles.pm index 7d15752a9..a17ae67d5 100644 --- a/lib/Dist/Zilla/Plugin/PruneFiles.pm +++ b/lib/Dist/Zilla/Plugin/PruneFiles.pm @@ -55,6 +55,19 @@ has matches => ( default => sub { [] }, ); +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { + map { $_ => $self->$_ } qw(filenames matches), + }; + + return $config; +}; + sub prune_files { my ($self) = @_; diff --git a/lib/Dist/Zilla/Plugin/ShareDir.pm b/lib/Dist/Zilla/Plugin/ShareDir.pm index c12d5abcd..0c64b57c1 100644 --- a/lib/Dist/Zilla/Plugin/ShareDir.pm +++ b/lib/Dist/Zilla/Plugin/ShareDir.pm @@ -41,5 +41,17 @@ sub share_dir_map { } with 'Dist::Zilla::Role::ShareDir'; + +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { dir => $self->dir }; + + return $config; +}; + __PACKAGE__->meta->make_immutable; 1; diff --git a/lib/Dist/Zilla/Plugin/UploadToCPAN.pm b/lib/Dist/Zilla/Plugin/UploadToCPAN.pm index d26332d52..a4a702680 100644 --- a/lib/Dist/Zilla/Plugin/UploadToCPAN.pm +++ b/lib/Dist/Zilla/Plugin/UploadToCPAN.pm @@ -225,6 +225,19 @@ has uploader => ( } ); +around dump_config => sub { + my $orig = shift; + my $self = shift; + + my $config = $self->$orig; + + $config->{+__PACKAGE__} = { + map { $_ => $self->$_ } qw(credentials_stash subdir upload_uri), + }; + + return $config; +}; + sub before_release { my $self = shift; diff --git a/t/commands/authordeps.t b/t/commands/authordeps.t index ddffd1122..1a86b976e 100644 --- a/t/commands/authordeps.t +++ b/t/commands/authordeps.t @@ -18,7 +18,7 @@ is_deeply( [ +{ perl => '5.005' }, ( map { +{"Dist::Zilla::Plugin::$_" => '5.0'} } qw ), - ( map { +{"Dist::Zilla::Plugin::$_" => 0} } qw ), + ( map { +{"Dist::Zilla::Plugin::$_" => 0} } qw ), ], "authordeps in corpus/dist/AuthorDeps" ) or diag explain $authordeps;