NAME

Changes::Release - Release object class

SYNOPSIS

use Changes::Release;
my $rel = Changes::Release->new(
    # A Changes object
    container => $changes_object,
    datetime => '2022-11-17T08:12:42+0900',
    datetime_formatter => sub
    {
        my $dt = shift( @_ ) || DateTime->now;
        require DateTime::Format::Strptime;
        my $fmt = DateTime::Format::Strptime->new(
            pattern => '%FT%T%z',
            locale => 'en_GB',
        );
        $dt->set_formatter( $fmt );
        $dt->set_time_zone( 'Asia/Tokyo' );
        return( $dt );
    },
    format => '%FT%T%z',
    line => 12,
    note => 'Initial release',
    spacer => "\t",
    time_zone => 'Asia/Tokyo',
    version => 'v0.1.0',
) || die( Changes::Release->error, "\n" );
my $change = $rel->add_change( $change_object );
# or
my $change = $rel->add_change( text => 'Some comments' );
my $group = $rel->add_group( $group_object );
# or
my $group = $rel->add_group( name => 'Some group' );
my $change = $rel->delete_change( $change_object );
my $group = $rel->delete_group( $group_object );
say $rel->as_string;

VERSION

v0.2.1

DESCRIPTION

This class implements a Changes file release line. Such information usually comprise of a version number, a release datetime and an optional note

Each release section can contain group and changes that are all stored and accessible in "changes"

If an error occurred, it returns an error

The result of this method is cached so that the second time it is called, the cache is used unless there has been any change.

METHODS

add_change

Provided with a Changes::Change object, or an hash or hash reference of options passed to the constructor of Changes::Change, and this will add the change object to the list of elements for this release object.

It returns the Changes::Change object, or an error if an error occurred.

add_group

Provided with a Changes::Group object, or an hash or hash reference of options passed to the constructor of Changes::Group, and this will add the change object to the list of elements.

It returns the Changes::Group object, or an error if an error occurred.

as_string

Returns a string object representing the release. It does so by calling as_string on each element stored in "elements". Those elements can be Changes::Group and Changes::Change objects.

If an error occurred, it returns an error

The result of this method is cached so that the second time it is called, the cache is used unless there has been any change.

changes

Read only. This returns an array object containing all the change objects within this release object.

container

Sets or gets the container object for this release object. A container is the object representing the Changes file: a Changes object.

Note that if you instantiate a release object directly, this value will obviously be undef. This value is set by Changes upon parsing the Changes file.

datetime

Sets or gets the release datetime information. This uses "_parse_datetime" in Module::Generic to parse the string, so please check that documentation for supported formats.

However, most format are supported including ISO8601 format and W3CDTF format (e.g. 2022-07-17T12:10:03+09:00)

Note that if you use a relative datetime format such as -2D for 2 days ago, the datetime format will be set to a unix timestamp, and in that case you need to also specify the format option with the desired datetime format.

You can alternatively directly set a DateTime object.

It returns a DateTime object whose date formatter object is set to the same format as provided. This ensures that any stringification of the DateTime object reverts back to the string as found in the Changes file or as provided by the user.

datetime_formatter

Sets or gets a code reference callback to be used when formatting the release datetime. This allows you to use alternative formatter and greater control over the formatting of the release datetime.

This code is called with a DateTime object, and it must return a DateTime object. Any other value will be discarded and it will fallback on setting up a DateTime with current date and time using UTC as time zone and $DEFAULT_DATETIME_FORMAT as default datetime format.

The code executed may die if needed and any exception will be caught and a warning will be issued if warnings are enabled for Changes.

defaults

Sets or gets an hash of default values for the Changes::Change object when it is instantiated by the new_change method.

Default is undef, which means no default value is set.

my $ch = Changes->new(
    file => '/some/where/Changes',
    defaults => {
        # For Changes::Change
        spacer1 => "\t",
        spacer2 => ' ',
        marker => '-',
        max_width => 72,
        wrapper => $code_reference,
        # For Changes::Group
        group_spacer => "\t",
        group_type => 'bracket', # [Some group]
    }
);

delete_change

This takes a list of change to remove and returns an array object of those changes thus removed.

A change provided can only be a Changes::Change object.

If an error occurred, this will return an error

delete_group

This takes a list of group to remove and returns an array object of those groups thus removed.

A group provided can either be a Changes::Group object, or a group name as a string.

If an error occurred, this will return an error

elements

Sets or gets an array object of all the elements within this release object. Those elements can be Changes::Group, Changes::Change and Changes::NewLine objects.

format

Sets or gets a DateTime format to be used with DateTime::Format::Strptime. See "STRPTIME PATTERN TOKENS" in DateTime::Format::Strptime for details on possible patterns.

You can also specify an alternative formatter with "datetime_formatter"

If you specify the special value default, it will use default value set in the global variable $DEFAULT_DATETIME_FORMAT, which is %FT%T%z (for example: 2022-12-08T20:13:09+0900)

It returns a scalar object

groups

Read only. This returns an array object containing all the group objects within this release object.

line

Sets or gets an integer representing the line number where this release line was found in the original Changes file. If this object was instantiated separately, then obviously this value will be undef

new_change

Instantiates and returns a new Changes::Change, passing its constructor any argument provided.

my $change = $rel->new_change( text => 'Some change' ) ||
    die( $rel->error );

new_group

Instantiates and returns a new Changes::Group, passing its constructor any argument provided.

my $change = $rel->new_group( name => 'Some group' ) ||
    die( $rel->error );

new_line

Returns a new Changes::NewLine object, passing it any parameters provided.

If an error occurred, it returns an error object

new_version

Returns a new Changes::Version object, passing it any parameters provided.

If an error occurred, it returns an error object

nl

Sets or gets the new line character, which defaults to \n

It returns a number object

note

Sets or gets an optional note that is set after the release datetime.

It returns a scalar object

raw

Sets or gets the raw line as found in the Changes file for this release. If nothing is change, and a raw version exists, then it is returned instead of computing the formatting of the line.

It returns a scalar object

remove_change

This is an alias for "delete_change"

remove_group

This is an alias for "delete_group"

set_default_format

Sets the default DateTime format pattern used by DateTime::Format::Strptime. This default value used is $DEFAULT_DATETIME_FORMAT, which, by default is: %FT%T%z, i.e. something that would look like 2022-12-06T20:13:09+0900

spacer

Sets or gets the space that can be found between the version information and the datetime. Normally this would be just one space, but since it can be other space, this is used to capture it and ensure the result is identical to what was parsed.

This defaults to a single space if it is not set.

It returns a scalar object

time_zone

Sets or gets a time zone to use for the release date. A valid time zone can either be an olson time zone string such as Asia/Tokyo, or an DateTime::TimeZone object.

It returns a DateTime::TimeZone object upon success, or an error if an error occurred.

version

Sets or gets the version information for this release. This returns a version object. If you prefer to use a different class, such as Perl::Version, then you can set the global variable $VERSION_CLASS accordingly.

It returns a version object, or an object of whatever class you have set with $VERSION_CLASS

changes

Sets or gets the array object containing all the object representing the changes for that release. Those changes can be Changes::Group, Changes::Change or Changes::Line

AUTHOR

Jacques Deguest <jack@deguest.jp>

SEE ALSO

Changes, Changes::Group, Changes::Change, Changes::Version, Changes::NewLine

COPYRIGHT & LICENSE

Copyright(c) 2022 DEGUEST Pte. Ltd.

All rights reserved

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.