Sign Up
Log In
Log In
or
Sign Up
Places
All Projects
Status Monitor
Collapse sidebar
home:Tomcat42
perl-Class-Constructor
perl-Class-Constructor.spec
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
File perl-Class-Constructor.spec of Package perl-Class-Constructor
# # spec file for package perl-Class-Constructor (Version 1.1.4) # # Copyright (c) 2010 SUSE LINUX Products GmbH, Nuernberg, Germany. # # All modifications and additions to the file contributed by third parties # remain the property of their copyright owners, unless otherwise agreed # upon. The license for this file, and modifications and additions to the # file, is the same license as for the pristine package itself (unless the # license for the pristine package is not an Open Source License, in which # case the license is the MIT License). An "Open Source License" is a # license that conforms to the Open Source Definition (Version 1.9) # published by the Open Source Initiative. # Please submit bugfixes or comments via http://bugs.opensuse.org/ # Name: perl-Class-Constructor Version: 1.1.4 Release: 1 License: CHECK(GPL+ or Artistic) %define cpan_name Class-Constructor Summary: Simplify the creation of object constructors Url: http://search.cpan.org/dist/Class-Constructor/ Group: Development/Libraries/Perl Source: http://www.cpan.org/authors/id/M/MG/MGRAHAM/%{cpan_name}-%{version}.tar.gz BuildArch: noarch BuildRoot: %{_tmppath}/%{name}-%{version}-build BuildRequires: perl BuildRequires: perl-macros BuildRequires: perl(Class::Accessor) BuildRequires: perl(ExtUtils::MakeMaker) Requires: perl(Class::Accessor) %{perl_requires} %description Simplifies the creation of object constructors. Instead of writing: sub new { my $proto = shift; my $class = ref $proto || $proto; my $self = {}; bless $self, $class; my %args = @_; foreach my $attr ('first_attribute', 'second_attribute') { $self->$attr($args{$attr}); } $self->_init(); return $self; } You can just write: CLASS->mk_constructor( Auto_Init => [ 'first_attribute', 'second_attribute' ], ); There are other features as well: * Automatically call other initialization methods. Using the 'Init_Methods' method of 'mk_constructor', you can have your constructor method automatically call one or more initialization methods. * Automatic Construction of objects of Subclasses Your constructor can bless objects into one of its subclasses. For instance, the 'Fruit' class could bless objects into the 'Fruit::Apple' or 'Fruit::Orange' classes depending on a parameter passed to the constructor. See the Subclass_Param manpage for details. %prep %setup -q -n %{cpan_name}-%{version} %build %{__perl} Makefile.PL INSTALLDIRS=vendor %{__make} %{?_smp_mflags} %check %{__make} test %install %perl_make_install %perl_process_packlist %perl_gen_filelist %clean %{__rm} -rf %{buildroot} %files -f %{name}.files %defattr(-,root,root,755) %doc Changes README %changelog
Locations
Projects
Search
Status Monitor
Help
OpenBuildService.org
Documentation
API Documentation
Code of Conduct
Contact
Support
@OBShq
Terms
openSUSE Build Service is sponsored by
The Open Build Service is an
openSUSE project
.
Sign Up
Log In
Places
Places
All Projects
Status Monitor