NAME
Dist::Zilla::PluginBundle::Author::LXP - configure Dist::Zilla like LXP
VERSION
This module is part of distribution Dist-Zilla-PluginBundle-Author-LXP v1.0.1.
This distribution's version numbering follows the conventions defined at semver.org.
SYNOPSIS
In dist.ini:
[@Author::LXP]
DESCRIPTION
This Dist::Zilla plugin bundle configures Dist::Zilla the way CPAN author LXP
uses it, achieving the same result as these entries in a dist.ini file:
;; PHASE: METADATA ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; Don't allow PAUSE/CPAN to index test libraries. Not sure whether
; this is strictly needed, but better safe than sorry...
[MetaNoIndex]
directory = t
; More of the same thing. Must appear after MetaNoIndex
; configuration.
[MetaProvides::Package]
meta_noindex = 1
;; PHASE: GATHER FILES ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; Without a GatherDir plugin, Dist::Zilla sees no files.
[GatherDir]
; Add a LICENSE file to the build. The generated POD for each
; module will also reference this file.
[License]
; Distributions released to the CPAN include a META.json/META.yml
; file. Emit both of these.
[MetaJSON]
[MetaYAML]
; Add a MANIFEST file.
[Manifest]
; Add a test to ensure that all of the source code actually
; compiles.
[Test::Compile]
; Test that everything has a $VERSION defined.
[Test::Version]
; Ensure that everything is appropriately documented...
[PodCoverageTests]
; ...and properly...
[PodSyntaxTests]
; ...and without typos. "semver" is added to each file by a plugin
; defined in Pod::Weaver::PluginBundle::Author::LXP (see PodWeaver
; configuration below), so explicitly whitelist that "word" here.
[Test::PodSpelling]
stopwords = semver
; Test correctness of the META.yml file.
[MetaTests]
; Add some more tests for source code formatting.
[Test::EOL]
[NoTabsTests]
; Assess the distribution's readiness for CPAN.
[Test::Kwalitee]
;; PHASE: PRUNE FILES ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; GatherDir...but we don't want to include old builds within new
; ones.
[PruneCruft]
; See also: ReadmeAnyFromPod configurations below, apparently.
;; PHASE: MUNGE FILES ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; Write a $VERSION declaration into each module.
[PkgVersion]
; Rewrite POD into complete documents.
[PodWeaver]
config_plugin = @Author::LXP
; On build, update the version number in the built Changes file.
; After release, create a new section in the source Changes file.
; Conform to the date/time format specified by CPAN::Changes::Spec.
[NextRelease]
format = %-7v %{yyyy-MM-dd}d
time_zone = UTC
; All of the extra tests need to be moved into the main test
; directory of the build in order to run.
[ExtraTests]
;; PHASE: REGISTER PREREQUISITES ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; See also: PodCoverageTests configuration above.
; See also: PodSyntaxTests configuration above.
; See also: MetaTests configuration above.
; Programmatically determine the distribution's dependencies.
; This information is needed for the META.* and Makefile.PL files.
[AutoPrereqs]
; Determine the minimum Perl version required for the distribution.
[MinimumPerl]
; Don't explicitly declare dependencies that are part of Perl
; itself. This needs to be declared after all other plugins in
; this phase.
[PrereqsClean]
; See also: MakeMaker configuration below.
;; PHASE: INSTALL TOOL ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; Add a README file to the build, generated from the finalised POD
; for the main module.
[ReadmeAnyFromPod]
; Also generate a README POD file for the repository root.
; (This does not form part of the final build.)
[ReadmeAnyFromPod / PodRoot]
; Emit a Makefile.PL file in the build. This permits testing via
; "dzil test".
[MakeMaker]
; Emit an INSTALL file with installation instructions.
; (Must be defined after MakeMaker configuration.)
[InstallGuide]
;; PHASE: BEFORE RELEASE ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; Ensure that the Changes file documents somehing for the release.
[CheckChangesHasContent]
; Don't allow a release to occur while there are dirty files (other
; than those that may have new version information written as part
; of the build process).
[Git::Check]
allow_dirty = Changes
allow_dirty = dist.ini
allow_dirty = README.pod
; Ensure that all tests pass.
[TestRelease]
; If all is well, publish the distribution.
[ConfirmRelease]
[UploadToCPAN]
;; PHASE: RELEASER ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; See also: UploadToCPAN configuration above.
;; PHASE: AFTER RELEASE ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; See also: NextRelease configuration above.
; Commit changes to the files modified after a release.
; (Must be defined after NextRelease configuration.)
[Git::Commit]
allow_dirty = Changes
allow_dirty = dist.ini
allow_dirty = README.pod
time_zone = UTC
; Tag releases. Do this before pushing so that the tag is still
; created locally if pushing fails for some reason. Don't create
; an annotated tag since another commit occurs at release time
; anyway.
[Git::Tag]
tag_message =
; Push changes to the remote repository when a release is made.
[Git::Push]
;; PHASE: TEST RUNNER ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; See also: MakeMaker configuration above.
;; PHASE: BUILD RUNNER ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; See also: MakeMaker configuration above.
ACKNOWLEDGEMENTS
Dist::Zilla::AppCommand::dumpphases, which adds a dumpphases
command to dzil
, was invaluable to me in better understanding Dist::Zilla's phase ordering and better identifying which plugins run during which phase (or in some cases, phases).
SUPPORT
Bugs / Feature Requests
Please report any bugs or feature requests by email to bug-dist-zilla-pluginbundle-author-lxp at rt.cpan.org
, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Dist-Zilla-PluginBundle-Author-LXP. You will be automatically notified of any progress on the request by the system.
Source Code
The source code for this distribution is available online in a Git repository. Please feel welcome to contribute patches.
https://github.com/lx/perl5-Dist-Zilla-PluginBundle-Author-LXP
git clone git://github.com/lx/perl5-Dist-Zilla-PluginBundle-Author-LXP
AUTHOR
Alex Peters <lxp@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2013 by Alex Peters.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.
The full text of the license can be found in the 'LICENSE' file included with this distribution.