diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..ddff0a8 --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +SOURCES/ExtUtils-MakeMaker-6.68.tar.gz diff --git a/.perl-ExtUtils-MakeMaker.metadata b/.perl-ExtUtils-MakeMaker.metadata new file mode 100644 index 0000000..53ac3dc --- /dev/null +++ b/.perl-ExtUtils-MakeMaker.metadata @@ -0,0 +1 @@ +ae79549d97e87c4639dcdc881ea33fbc3acf54cd SOURCES/ExtUtils-MakeMaker-6.68.tar.gz diff --git a/SOURCES/ExtUtils-MakeMaker-6.68-USE_MM_LD_RUN_PATH.patch b/SOURCES/ExtUtils-MakeMaker-6.68-USE_MM_LD_RUN_PATH.patch new file mode 100644 index 0000000..59763e2 --- /dev/null +++ b/SOURCES/ExtUtils-MakeMaker-6.68-USE_MM_LD_RUN_PATH.patch @@ -0,0 +1,136 @@ +From dfe5d4e6ffa4ba2cc88c2e3d1fc69723a2dc7231 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Petr=20P=C3=ADsa=C5=99?= +Date: Thu, 12 Jan 2012 17:05:19 +0100 +Subject: [PATCH] Do not set RPATH by default +MIME-Version: 1.0 +Content-Type: text/plain; charset=UTF-8 +Content-Transfer-Encoding: 8bit + +Former behavior can be forced by setting USE_MM_LD_RUN_PATH +environment variable to 1. + +This is copy from `perl' package. +See . + +Signed-off-by: Petr Písař +--- + lib/ExtUtils/Liblist.pm | 5 ++++ + lib/ExtUtils/MM_Unix.pm | 2 +- + lib/ExtUtils/MakeMaker.pm | 58 +++++++++++++++++++++++++++++++++++++++++++++-- + 3 files changed, 62 insertions(+), 3 deletions(-) + +diff --git a/lib/ExtUtils/Liblist.pm b/lib/ExtUtils/Liblist.pm +index 9abb959..b256ca1 100644 +--- a/lib/ExtUtils/Liblist.pm ++++ b/lib/ExtUtils/Liblist.pm +@@ -88,6 +88,11 @@ libraries. LD_RUN_PATH is a colon separated list of the directories + in LDLOADLIBS. It is passed as an environment variable to the process + that links the shared library. + ++Fedora extension: This generation of LD_RUN_PATH is disabled by default. ++To use the generated LD_RUN_PATH for all links, set the USE_MM_LD_RUN_PATH ++MakeMaker object attribute / argument, (or set the $USE_MM_LD_RUN_PATH ++environment variable). ++ + =head2 BSLOADLIBS + + List of those libraries that are needed but can be linked in +diff --git a/lib/ExtUtils/MM_Unix.pm b/lib/ExtUtils/MM_Unix.pm +index 36397bf..ac1fece 100644 +--- a/lib/ExtUtils/MM_Unix.pm ++++ b/lib/ExtUtils/MM_Unix.pm +@@ -945,7 +945,7 @@ $(INST_DYNAMIC): $(OBJECT) $(MYEXTLIB) $(BOOTSTRAP) $(INST_ARCHAUTODIR)$(DFSEP). + } + + my $ld_run_path_shell = ""; +- if ($self->{LD_RUN_PATH} ne "") { ++ if (($self->{LD_RUN_PATH} ne "") && ($self->{USE_MM_LD_RUN_PATH})) { + $ld_run_path_shell = 'LD_RUN_PATH="$(LD_RUN_PATH)" '; + } + +diff --git a/lib/ExtUtils/MakeMaker.pm b/lib/ExtUtils/MakeMaker.pm +index 7ca7c2c..c1948bd 100644 +--- a/lib/ExtUtils/MakeMaker.pm ++++ b/lib/ExtUtils/MakeMaker.pm +@@ -281,7 +281,7 @@ sub full_setup { + PERL_SRC PERM_DIR PERM_RW PERM_RWX + PL_FILES PM PM_FILTER PMLIBDIRS PMLIBPARENTDIRS POLLUTE PPM_INSTALL_EXEC + PPM_INSTALL_SCRIPT PREREQ_FATAL PREREQ_PM PREREQ_PRINT PRINT_PREREQ +- SIGN SKIP TEST_REQUIRES TYPEMAPS VERSION VERSION_FROM XS XSOPT XSPROTOARG ++ SIGN SKIP TEST_REQUIRES TYPEMAPS USE_MM_LD_RUN_PATH VERSION VERSION_FROM XS XSOPT XSPROTOARG + XS_VERSION clean depend dist dynamic_lib linkext macro realclean + tool_autosplit + +@@ -431,7 +431,27 @@ sub new { + # PRINT_PREREQ is RedHatism. + if ("@ARGV" =~ /\bPRINT_PREREQ\b/) { + $self->_PRINT_PREREQ; +- } ++ } ++ ++ # USE_MM_LD_RUN_PATH - another RedHatism to disable automatic RPATH generation ++ if ( ( ! $self->{USE_MM_LD_RUN_PATH} ) ++ &&( ("@ARGV" =~ /\bUSE_MM_LD_RUN_PATH(=([01]))?\b/) ++ ||( exists( $ENV{USE_MM_LD_RUN_PATH} ) ++ &&( $ENV{USE_MM_LD_RUN_PATH} =~ /([01])?$/ ) ++ ) ++ ) ++ ) ++ { ++ my $v = $1; ++ if( $v ) ++ { ++ $v = ($v=~/=([01])$/)[0]; ++ }else ++ { ++ $v = 1; ++ }; ++ $self->{USE_MM_LD_RUN_PATH}=$v; ++ }; + + print "MakeMaker (v$VERSION)\n" if $Verbose; + if (-f "MANIFEST" && ! -f "Makefile" && ! $ENV{PERL_CORE}){ +@@ -2445,6 +2465,40 @@ precedence. A typemap in the current directory has highest + precedence, even if it isn't listed in TYPEMAPS. The default system + typemap has lowest precedence. + ++=item USE_MM_LD_RUN_PATH ++ ++boolean ++The Fedora perl MakeMaker distribution differs from the standard ++upstream release in that it disables use of the MakeMaker generated ++LD_RUN_PATH by default, UNLESS this attribute is specified , or the ++USE_MM_LD_RUN_PATH environment variable is set during the MakeMaker run. ++ ++The upstream MakeMaker will set the ld(1) environment variable LD_RUN_PATH ++to the concatenation of every -L ld(1) option directory in which a -l ld(1) ++option library is found, which is used as the ld(1) -rpath option if none ++is specified. This means that, if your application builds shared libraries ++and your MakeMaker application links to them, that the absolute paths of the ++libraries in the build tree will be inserted into the RPATH header of all ++MakeMaker generated binaries, and that such binaries will be unable to link ++to these libraries if they do not still reside in the build tree directories ++(unlikely) or in the system library directories (/lib or /usr/lib), regardless ++of any LD_LIBRARY_PATH setting. So if you specified -L../mylib -lmylib , and ++ your 'libmylib.so' gets installed into /some_directory_other_than_usr_lib, ++ your MakeMaker application will be unable to link to it, even if LD_LIBRARY_PATH ++is set to include /some_directory_other_than_usr_lib, because RPATH overrides ++LD_LIBRARY_PATH. ++ ++So for Fedora MakeMaker builds LD_RUN_PATH is NOT generated by default for ++every link. You can still use explicit -rpath ld options or the LD_RUN_PATH ++environment variable during the build to generate an RPATH for the binaries. ++ ++You can set the USE_MM_LD_RUN_PATH attribute to 1 on the MakeMaker command ++line or in the WriteMakefile arguments to enable generation of LD_RUN_PATH ++for every link command. ++ ++USE_MM_LD_RUN_PATH will default to 1 (LD_RUN_PATH will be used) IF the ++$USE_MM_LD_RUN_PATH environment variable is set during a MakeMaker run. ++ + =item VENDORPREFIX + + Like PERLPREFIX, but only for the vendor install locations. +-- +1.8.1.4 + diff --git a/SPECS/perl-ExtUtils-MakeMaker.spec b/SPECS/perl-ExtUtils-MakeMaker.spec new file mode 100644 index 0000000..19ee7ce --- /dev/null +++ b/SPECS/perl-ExtUtils-MakeMaker.spec @@ -0,0 +1,135 @@ +%global cpan_name ExtUtils-MakeMaker +%global cpan_version 6.68 + +Name: perl-%{cpan_name} +Version: %(echo '%{cpan_version}' | tr _ .) +Release: 3%{?dist} +Summary: Create a module Makefile +License: GPL+ or Artistic +Group: Development/Libraries +URL: http://search.cpan.org/dist/%{cpan_name}/ +Source0: http://www.cpan.org/authors/id/B/BI/BINGOS/%{cpan_name}-%{cpan_version}.tar.gz +# Do not set RPATH to perl shared-library modules by default. Bug #773622. +# This is copy from `perl' package. This is distributor extension. +Patch0: %{cpan_name}-6.68-USE_MM_LD_RUN_PATH.patch +BuildArch: noarch +BuildRequires: perl +# Makefile.Pl uses ExtUtils::MakeMaker from ./lib +BuildRequires: perl(Carp) +BuildRequires: perl(Config) +BuildRequires: perl(Cwd) +BuildRequires: perl(Exporter) +BuildRequires: perl(File::Basename) +BuildRequires: perl(File::Path) +BuildRequires: perl(File::Spec) >= 0.8 +BuildRequires: perl(lib) +BuildRequires: perl(strict) +BuildRequires: perl(vars) +BuildRequires: perl(warnings) +# Unbundled +BuildRequires: perl(File::Copy::Recursive) +# Tests: +BuildRequires: perl(AutoSplit) +BuildRequires: perl(CPAN::Meta) +BuildRequires: perl(Data::Dumper) +BuildRequires: perl(ExtUtils::Command) +BuildRequires: perl(ExtUtils::Install) +BuildRequires: perl(ExtUtils::Installed) +BuildRequires: perl(ExtUtils::Manifest) +BuildRequires: perl(File::Find) +BuildRequires: perl(File::Temp) +BuildRequires: perl(Getopt::Long) +BuildRequires: perl(IO::File) +BuildRequires: perl(less) +BuildRequires: perl(Parse::CPAN::Meta) +BuildRequires: perl(Pod::Man) +BuildRequires: perl(Test::Harness) +BuildRequires: perl(Test::More) +# Optional tests +BuildRequires: perl(ExtUtils::CBuilder) +Requires: perl(:MODULE_COMPAT_%(eval "`perl -V:version`"; echo $version)) +Requires: perl(ExtUtils::Command) +Requires: perl(ExtUtils::Install) +Requires: perl(ExtUtils::Manifest) +Requires: perl(File::Find) +Requires: perl(File::Spec) >= 0.8 +Requires: perl(Getopt::Long) +Requires: perl(Test::Harness) +# Optional run-time needed for generating documentation from POD: +Requires: perl(Pod::Man) + +# Do not export underspecified dependencies +%global __requires_exclude %{?__requires_exclude:%__requires_exclude|}^perl\\(File::Spec\\)\s*$ +# Do not export private redefinitions +%global __provides_exclude %{?__provides_exclude:%__provides_exclude|}^perl\\(DynaLoader|ExtUtils::MakeMaker::_version\\) + +%description +This utility is designed to write a Makefile for an extension module from a +Makefile.PL. It is based on the Makefile.SH model provided by Andy +Dougherty and the perl5-porters. + +%prep +%setup -q -n ExtUtils-MakeMaker-%{cpan_version} +%patch0 -p1 +# Remove bundled modules +rm -rf bundled/* ||: +sed -i -e '/^bundled\// d' MANIFEST + +%build +perl Makefile.PL INSTALLDIRS=vendor +make %{?_smp_mflags} + +%install +make pure_install DESTDIR=$RPM_BUILD_ROOT +find $RPM_BUILD_ROOT -type f -name .packlist -exec rm -f {} \; +%{_fixperms} $RPM_BUILD_ROOT/* + +%check +make test + +%files +%doc Changes NOTES PATCHING README TODO +%{_bindir}/* +%{perl_vendorlib}/* +%{_mandir}/man1/* +%{_mandir}/man3/* + +%changelog +* Fri Dec 27 2013 Daniel Mach - 6.68-3 +- Mass rebuild 2013-12-27 + +* Thu Jun 27 2013 Jitka Plesnikova - 6.68-2 +- Update BRs + +* Mon Jun 17 2013 Petr Pisar - 6.68-1 +- 6.68 bump + +* Mon Apr 22 2013 Petr Pisar - 6.66-1 +- 6.66 bump + +* Tue Jan 29 2013 Petr Pisar - 6.64-2 +- Run-require POD convertors to get manual pages when building other packages + +* Mon Dec 17 2012 Petr Pisar - 6.64-1 +- 6.64 bump + +* Tue Aug 28 2012 Petr Pisar - 6.63.02-241 +- Compute RPM version +- Do not build-require itself, the build script runs from ./lib + +* Mon Aug 13 2012 Marcela Mašláňová - 6.63.02-240 +- update version to the same as in perl.srpm +- Bump release to override sub-package from perl.spec + +* Fri Jul 20 2012 Fedora Release Engineering - 6.62-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_18_Mass_Rebuild + +* Wed Jun 06 2012 Petr Pisar - 6.62-3 +- Perl 5.16 rebuild + +* Thu Jan 12 2012 Petr Pisar - 6.62-2 +- Do not set RPATH to perl shared-library modules by default (bug #773622) + +* Fri Nov 25 2011 Petr Pisar 6.62-1 +- Specfile autogenerated by cpanspec 1.78. +- Remove defattr and BuildRoot from spec.