NAME
Dist::Zilla::Plugin::Manifest::Read - Read annotated source manifest
VERSION
Version v0.4.2_01, released on 2016-10-11 00:15 UTC. This is a trial release.
WHAT?
Dist-Zilla-Plugin-Manifest-Read
(or Manifest::Read
for brevity) is a Dist::Zilla
plugin. It reads annotated source manifest, checks existence of all listed files and directories, and adds selected files to the distribution. Manifest::Read
also does FileFinder
role, providing the list of added files for other plugins.
This is Dist::Zilla::Plugin::Manifest::Read
module documentation. Read this if you are going to hack or extend Manifest::Read
, or use it programmatically.
If you want to have annotated source manifest, read the user manual. General topics like getting source, building, installing, bug reporting and some others are covered in the README.
SYNOPSIS
DESCRIPTION
This class consumes Dist::Zilla::Role::FileGatherer and Dist::Zilla::Role::FileFinder
role. In order to fulfill requirements, the class implements gather_files
and find_files
methods. Other methods are supporting.
The class also consumes Dist::Zilla::Role::ErrorLogger role. It allows the class not to stop at the first problem but continue and report multiple errors to user.
OBJECT ATTRIBUTES
manifest_name
Name of manifest file to read.
Str
, read-only, default value is MANIFEST
, init_arg
is manifest
.
manifest_file
Manifest file as a Dist::Zilla
file object (Dist::Zilla::File::OnDisk
).
Object
, read-only.
_file_list
Array of files (object which do Dist::Zilla::Role::File
role) listed in the manifest and marked for inclusion to the distribution.
ArrayRef
, read-only, lazy, initialized with builder.
_file_hash
Hash of files (object which do Dist::Zilla::Role::File
role) listed in the manifest and marked for inclusion to the distribution. Hash keys are file names, hash values are references to file objects. Built from _file_list
.
HasfRef
, read-only, lazy, initialized with builder.
_lines
Array of chomped manifest lines, including comments and empty lines.
ArrayRef[Str]
, read-only, lazy, initialized with builder.
OBJECT METHODS
BUILD
This method creates bunch of file finders: Manifest::Write/AllFiles
, Manifest::Write/ExecFiles
, Manifest::Write/ExtraTestFiles
, Manifest::Write/InstallModules
, Manifest::Write/PerlExecFiles
, Manifest::Write/TestFiles
.
gather_files
This method fulfills Dist::Zilla::Role::FileGatherer role requirement. It adds files listed in manifest to distribution (and to _file_list
). Files marked to exclude from distribution and directories are not added.
find_files
This method fulfills Dist::Zilla::Role::FileFinder role requirement. It simply returns a copy of _file_list
attribute.
This method can be called by other plugins to iterate through files added by Manifest::Read
, see "SYNOPSIS".
Note: The method always returns the same list of files. Plugins which remove files from distribution (i. e. plugins which do Dist::Zilla::Role::FilePruner
role) do not affect result of the method.
_parse_lines
This method parses manifest lines. Each line is parsed separately (there is no line continuation).
If the method fails to parse a line, error is reported by calling method log_error
(implemented in Dist::Zilla::Role::ErrorLogger). This means that parsing is not stopped at the first failure, but entire manifest will be parsed and all the found errors will be reported.
The method returns list of hashrefs, a hash per file. Each hash has following keys and values:
- filename
-
Parsed filename (single-quoted filenames are unquoted, escape sequences are evaluated, if any).
- mark
-
Mark.
- comment
-
File comment, leading and trailing whitespaces are stripped.
- line
-
Number of manifest line the file listed in.
In your plugin:
# Iterate through the distribution files listed in MANIFEST
# (files not included into distrubution are not iterated):
my $files = $self->zilla->plugin_named( 'Manifest::Read' )->find_files();
for my $file ( @$files ) {
...
};
SEE ALSO
AUTHOR
Van de Bugger <van.de.bugger@gmail.com>
COPYRIGHT AND LICENSE
Copyright (C) 2015 Van de Bugger
License GPLv3+: The GNU General Public License version 3 or later <http://www.gnu.org/licenses/gpl-3.0.txt>.
This is free software: you are free to change and redistribute it. There is NO WARRANTY, to the extent permitted by law.