NAME

CPAN::Changes - Parser for CPAN style change logs

SYNOPSIS

  use CPAN::Changes;
  my $changes = CPAN::Changes->load('Changes');
  $changes->release('0.01');

DESCRIPTION

It is standard practice to include a Changes file in your distribution. The purpose the Changes file is to help a user figure out what has changed since the last release.

People have devised many ways to write the Changes file. A preliminary specification has been created (CPAN::Changes::Spec) to encourage module authors to write clear and concise Changes.

This module will help users programmatically read and write Changes files that conform to the specification.

METHODS

new ( %args )

Creates a CPAN::Changes object.

%args

preamble

The preamble section of the changelog.

releases

An arrayref of CPAN::Changes::Release objects.

load ( $filename, %args )

Creates a new CPAN::Changes object by parsing the given file via CPAN::Changes::Parser.

load_string ( $filename, %args )

Creates a new CPAN::Changes object by parsing the given string via CPAN::Changes::Parser.

preamble ( [ $preamble ] )

Gets or sets the preamble section.

releases ( [ @releases ] )

Gets or sets the list of releases as CPAN::Changes::Release objects.

add_release ( @releases )

Adds the given releases to the change log. If a release of the same version exists, it will be overwritten.

delete_release ( @versions )

Removes the given versions from change log.

find_release ( $version )

Finds a release with the given version.

reversed

Returns a new CPAN::Changes object with the releases in the opposite order.

clone ( %attrs )

Returns a new CPAN::Changes object with the given attributes changed.

serialize ( %options )

Returns the change log as a string suitable for saving as a Changes file.

width

The width to wrap lines at. By default, lines will be wrapped at 75 characters.

styles

An array reference of styles to use when outputting the entries, one for each level of change. The first entry is used for the release entry itself.

The styles can be either a single character to prefix change lines or two characters to use as a prefix and suffix.

indents

An array reference of indent strings to use when outputting the entries.

reverse (legacy)

If true, releases will be output in reversed order.

group_sort (legacy)

A code reference used to sort the groups in the releases.

LEGACY METHODS

delete_empty_groups

Removes empty groups.

release

An alias for find_release.

AUTHOR

haarg - Graham Knop (cpan:HAARG) <haarg@haarg.org>

CONTRIBUTORS

Brian Cassidy <bricas@cpan.org>

COPYRIGHT

Copyright (c) 2011-2015 the CPAN::Changes "AUTHOR" and "CONTRIBUTORS" as listed above.

LICENSE

This library is free software and may be distributed under the same terms as perl itself. See http://dev.perl.org/licenses/.