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

Dist::Zilla
Dist::Zilla::Role::FileGatherer
Dist::Zilla::Role::ErrorLogger

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.