# # spec file for package perl-Object-MultiType # # Copyright (c) 2024 SUSE LLC # # 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 https://bugs.opensuse.org/ # %define cpan_name Object-MultiType Name: perl-Object-MultiType Version: 0.50.0 Release: 0 # 0.05 -> normalize -> 0.50.0 %define cpan_version 0.05 License: Artistic-1.0 OR GPL-1.0-or-later Summary: Perl Objects as Hash, Array, Scalar, Code and Glob at the same time URL: https://metacpan.org/release/%{cpan_name} Source0: https://cpan.metacpan.org/authors/id/G/GM/GMPASSOS/%{cpan_name}-%{cpan_version}.tar.gz Source100: README.md BuildArch: noarch BuildRequires: perl BuildRequires: perl-macros Provides: perl(Object::MultiType) = %{version} Provides: perl(Object::MultiType::Saver) %undefine __perllib_provides %{perl_requires} %description This module return an object that works like a Hash, Array, Scalar, Code and Glob object at the same time. The usual way is to call it from your module at new(): package FOO ; use Object::MultiType ; use vars qw(@ISA) ; @ISA = qw(Object::MultiType) ; ## Is good to 'Object::MultiType' be the last in @ISA! sub new { my $class = shift ; my $this = Object::MultiType->new() ; bless($this,$class) ; } %prep %autosetup -n %{cpan_name}-%{cpan_version} %build perl Makefile.PL INSTALLDIRS=vendor %make_build %check make test %install %perl_make_install %perl_process_packlist %perl_gen_filelist %files -f %{name}.files %doc Changes README %changelog