# NAME Dist::Zilla::PluginBundle::ATOOMIC - ATOOMIC's plugin bundle # VERSION version 1.00 # SYNOPSIS name = My-Module author = Nicolas R <atoomic@cpan.org> license = Artistic_2_0 copyright_holder = Dave Rolsky [@ATOOMIC] dist = My-Module ; Default is ATOOMIC::MakeMaker - or set it to ModuleBuild make_tool = ATOOMIC::MakeMaker ; These files won't be added to tarball exclude_files = ... ; Default is ATOOMIC authority = ATOOMIC ; Used to do things like add the PPPort plugin - determined automatically but can be overridden has_xs = ... ; Passed to AutoPrereqs - can be repeated prereqs_skip = ... ; Passed to Test::Pod::Coverage::Configurable if set pod_coverage_also_private = ... ; Passed to Test::Pod::Coverage::Configurable if set - can be repeated pod_coverage_class = ... ; Passed to Test::Pod::Coverage::Configurable if set - can be repeated pod_coverage_skip = ... ; Passed to Test::Pod::Coverage::Configurable if set - can be repeated pod_coverage_trustme = ... ; For pod spelling test - can be repeated stopwords = ... ; Can also put them in a separate file stopwords_file = .. ; Defaults to false use_github_homepage = 0 ; Defaults to false use_github_issues = 0 # DESCRIPTION This is the [Dist::Zilla](https://metacpan.org/pod/Dist::Zilla) plugin bundle I use for my distributions. Don't use this directly for your own distributions, but you may find it useful as a source of ideas for building your own bundle. This bundle uses [Dist::Zilla::Role::PluginBundle::PluginRemover](https://metacpan.org/pod/Dist::Zilla::Role::PluginBundle::PluginRemover) and [Dist::Zilla::Role::PluginBundle::Config::Slicer](https://metacpan.org/pod/Dist::Zilla::Role::PluginBundle::Config::Slicer) so I can remove or configure any plugin as needed. This is more or less equivalent to the following `dist.ini`: ; Picks one of these - defaults to ATOOMIC::MakeMaker [ATOOMIC::MakeMaker] [ModuleBuild] [Git::GatherDir] ; Both are configured by setting exclude_files for the bundle. Simple ; values like "./foo/bar.pl" are treated as filenames, others like ; "*\.jnk$" are treated as a regex. exclude_filenames = ... exclude_match = ... [ManifestSkip] [License] [ExecDir] [ShareDir] [Manifest] [CheckVersionIncrement] [TestRelease] [ConfirmRelease] [UploadToCPAN] [VersionFromMainModule] [Authority] ; Configured by setting authority for the bundle authority = ... do_munging = 0 [AutoPrereqs] ; Configured by setting skip_prereqs for the bundle skip = ... [CopyFilesFromBuild] copy = Build.PL copy = CODE_OF_CONDUCT.md copy = CONTRIBUTING.md copy = LICENSE copy = Makefile.PL copy = README.md copy = cpanfile copy = ppport.h [GitHub::Meta] ; Configured by setting use_github_issues for the bundle bugs = 0 ; Configured by setting use_github_homepage for the bundle homepage = 0 [MetaResources] homepage = http://metacpan.org/release/My-Module ; RT bits are omitted if use_github_issue is true bugtracker.web = http://rt.cpan.org/Public/Dist/Display.html?Name=My-Module bugtracker.mail = bug-My-Module@rt.cpan.org [MetaProvides::Pckage] meta_noindex = 1 [Meta::Contributors] [Meta::Config] [MetaJSON] [MetaYAML] [NextRelease] ; Width is configured by setting next_release_width for the bundle format = %-8v %{yyyy-MM-dd}d%{ (TRIAL RELEASE)}T ; Scans the test files for use of Test2 and picks either [Prereqs / Test::More with Test2] -phase = test -type = requires Test::More = 1.302015 ; If the distro doesn't use Test2 [Prereqs / Test::More with subtest] -phase = test -type = requires Test::More = 0.96 [Prereqs / Modules for use with tidyall] -phase = develop -type = requires Code::TidyAll::Plugin::Test::Vars = 0.02 Parallel::ForkManager' = 1.19 Perl::Critic = 1.126 Perl::Tidy = 20160302 Test::Vars = 0.009 [Prereqs / Test::Version which fixes https://github.com/plicease/Test-Version/issues/7] -phase = develop -type = requires Test::Version = 2.05 [PromptIfStale] phase = build module = Dist::Zilla::PluginBundle::ATOOMIC [PromptIfStale] phase = release check_all_plugins = 1 check_all_prereqs = 1 check_authordeps = 1 skip = Dist::Zilla::Plugin::ATOOMIC::Contributors skip = Dist::Zilla::Plugin::ATOOMIC::Git::CheckFor::CorrectBranch skip = Dist::Zilla::Plugin::ATOOMIC::License skip = Dist::Zilla::Plugin::ATOOMIC::TidyAll skip = Pod::Weaver::PluginBundle::ATOOMIC [Test::Pod::Coverage::Configurable] ; Configured by setting pod_coverage_class for the bundle class = ... ; Configured by setting pod_coverage_skip for the bundle skip = ... ; Configured by setting pod_coverage_trustme for the bundle trustme = ... [Test::PodSpelling] ; Configured by setting stopwords and/or stopwords_file for the bundle stopwods = ... [PodSyntaxTests] [ATOOMIC::RunExtraTests] [MojibakeTests] [Test::CleanNamespaces] [Test::CPAN::Changes] [Test::CPAN::Meta::JSON] [Test::EOL] [Test::NoTabs] [Test::Portability] [Test::Synopsis] [Test::TidyAll] verbose = 1 jobs = 4 minimum_perl = 5.010 [Test::Compile] xt_mode = 1 [Test::ReportPrereqs] verify_prereqs = 1 [Test::Version] is_strict = 1 ; Generates/updates a .mailmap file [ATOOMIC::Contributors] [Git::Contributors] [SurgicalPodWeaver] ; See Pod::Weaver::PluginBundle::ATOOMIC in this same distro for more info config_plugin = @ATOOMIC ; Nasty hack so I can pass config from the dist.ini to the Pod::Weaver ; bundle. Currently used so I can set ; "ATOOMIC::WeaverConfig.include_donations_pod = 0" in a dist.ini file. [ATOOMIC::WeaverConfig] [ReadmeAnyFromPod / README.md in build] type = markdown filename = README.md location = build phase = build [GenerateFile::FromShareDir / Generate CONTRIBUTING.md] -dist = Dist-Zilla-PluginBundle-ATOOMIC -filename = CONTRIBUTING.md ; This is determined by looking through the distro for .xs files. has_xs = ... [GenerateFile::FromShareDir / Generate CODE_OF_CONDUCT.md] -dist = Dist-Zilla-PluginBundle-ATOOMIC -filename = CODE_OF_CONDUCT.md [InstallGuide] [CPANFile] ; Only added if the distro has .xs files [PPPort] ; Like the default License plugin except that it defaults to Artistic 2.0. ; Also, if the copyright_year for the bundle is not this year, it passes ; something like "2014-2016" to Software::License. [ATOOMIC::License] [CheckPrereqsIndexed] [EnsureChangesHasContent] ; Just like Dist::Zilla::Plugin::Git::CheckFor::CorrectBranch except that ; it allows releases from any branch for TRIAL ; releases. https://github.com/RsrchBoy/dist-zilla-pluginbundle-git-checkfor/issues/24 [ATOOMIC::Git::CheckFor::CorrectBranch] [Git::CheckFor::MergeConflicts] ; Generates/updates tidyall.ini, perlcriticrc, and perltidyrc [ATOOMIC::TidyAll] ; The allow_dirty list is basically all of the generated or munged files ; in the distro, including: ; Build.PL ; CODE_OF_CONDUCT.md ; CONTRIBUTING.md ; Changes ; LICENSE ; Makefile.PL ; README.md ; cpanfile ; ppport.h ; tidyall.ini [Git::Check] allow_dirty = ... [Git::Commit / Commit generated files] allow_dirty = ... [Git::Tag] [Git::Push] [BumpVersionAfterRelease] [Git::Commit / Commit version bump] allow_dirty_match = .+ commit_msg = Bump version after release [Git::Push / Push version bump] # SUPPORT I am also usually active on IRC as 'autarch' on `irc://irc.perl.org`. # SOURCE The source code repository for Dist-Zilla-PluginBundle-ATOOMIC can be found at [https://github.com/atoomic/Dist-Zilla-PluginBundle-ATOOMIC](https://github.com/atoomic/Dist-Zilla-PluginBundle-ATOOMIC). # AUTHOR Nicolas R <atoomic@cpan.org> # CONTRIBUTORS - Dave Rolsky <autarch@urth.org> - Mark Fowler <mark@twoshortplanks.com> - Nicolas Rochelemagne <rochelemagne@cpanel.net> # COPYRIGHT AND LICENSE This software is Copyright (c) 2018 by Nicolas R. This is free software, licensed under: The Artistic License 2.0 (GPL Compatible) The full text of the license can be found in the `LICENSE` file included with this distribution.