NAME
Object::New - A default constructor for standard objects
VERSION
Version 0.02
SYNOPSIS
When you want Moose, there is Moose, but when you just want to write "standard" Perl5 OO code, there is a bit of boilerplate, and "->new" is one bit of it. This module just does just one thing: provide a sane default constructor you can use for standard Perl5 objects. (A standard object is here taken to be a blessed hash.)
If you want anything else, there is lots out there: Moose, obviously, but also Object::Tiny, and Rose::Object and many others. This modules is simply an exercise in code reuse, and an attempt to avoid a common piece of boilerplate.
THE GUTS
The new routine in all its glory is:
sub new {
my $class = shift;
my $object = {};
bless $object, $class;
if $object->can("init") {
$object->init(@_);
}
return $object;
}
So you get a blessed hash at the end. If your code has a init routine defined that an object in its namespace can access, it will call init as well, with the argument list passed to new.
To customise object construction, all you have to do is define an init routine:
package POW;
use Object::New;
use feature "say";
sub init {
my $self = shift;
my ($name, $rank, $serial_number) = @_;
$self->set_name($name);
$self->set_rank($rank);
$self->set_serial_number($serial_number);
}
# attribute accessors defined here...
sub interrogate {
my $self = shift;
say join(", ", $self->name, $self->rank, $self->serial_number);
}
EXPORT
This module exports one routine by default: "new"
If you don't want to import this, you don't want to be using this module.
SUBROUTINES/METHODS
new
A default constructor. This returns a reference to a hash, blessed into its invoking class. If an init method is available, it is called with the argument list passed to the constructor.
AUTHOR
Alex Kalderimis, <alex at gmail dot com>
BUGS
Please report any bugs or feature requests to bug-object-new at rt.cpan.org
, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Object-New. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
SUPPORT
You can find documentation for this module with the perldoc command.
perldoc Object::New
You can also look for information at:
RT: CPAN's request tracker
AnnoCPAN: Annotated CPAN documentation
CPAN Ratings
Search CPAN
ACKNOWLEDGEMENTS
LICENSE AND COPYRIGHT
Copyright 2011 Alex Kalderimis.
This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License.
See http://dev.perl.org/licenses/ for more information.