Adjust patch -p0 for binutils.
[nethome.git] / bin / hammock
index d477300..6a1c07b 100755 (executable)
@@ -9,6 +9,7 @@ use Carp qw(&carp);
 my $start=time();
 
 my $gdbcvsbare=$ENV{"HOME"}."/redhat/gdb-cvs-bare";
+my $binutilscvsbare=$ENV{"HOME"}."/redhat/binutils-cvs-bare";
 my $archermaster=$ENV{"HOME"}."/redhat/master";
 my $fedoracvsroot=q{:pserver:anonymous:@cvs.fedoraproject.org:/cvs/pkgs};
 my $rhelcvsroot=q{:pserver:anonymous:@192.168.67.2:3401/cvs/dist};
@@ -46,7 +47,7 @@ die if !GetOptions(
   "s|srcrpm=s"=>\$srcrpm,
     "file=s{,}"=>\@file,
 );
-$component and ($component=~m{^(?:(?:fedora|rhel)(?:gdb|glibc)|gdbcvs|archer-.*|/home/.*)$} or die "-c|--component required to be: fedoragdb|rhelgdb|fedoraglibc|rhelglibc|gdbcvs|archer-*|/home/*");
+$component and ($component=~m{^(?:(?:fedora|rhel)(?:gdb|binutils|glibc)|gdbcvs|binutilscvs|archer-.*|/home/.*)$} or die "-c|--component required to be: fedoragdb|rhelgdb|fedorabinutils|rhelbinutils|fedoraglibc|rhelglibc|gdbcvs|binutilscvs|archer-*|/home/*");
 $component and $component=~m{^/home/} and (-f "$component/gdb/gdbtypes.c" or die "$component/gdb/gdbtypes.c not found");
 $component and $srcrpm and die "-c|--component excludes -s|--srcrpm";
 $component or $srcrpm or die "-c|--component or -s|--srcrpm required";
@@ -139,24 +140,47 @@ while (my($name,$val)=each(%dump)) {
   close F or die $fname;
 }
 
+sub subst
+{
+  my($sub,$in,$out)=@_;
+
+  $out||=$in;
+
+  local *F;
+  open F,$in or die $in;
+  local $_=do { local $/; <F>; } or die $in;
+  close F or die $in;
+
+  &{$sub}() or die $_."\nError substituting $in";
+
+  open F,">$out" or die $out;
+  print F $_ or die $out;
+  close F or die $out;
+}
+
 # PID->distro
 my %child;
 for my $distro (@distrouse) {
+  my $rpmbuild="rpmbuild";
+
   my $cvsbasedir;
   my $cvsroot;
   my $cvsrepo;
-  if ($component=~/^fedora(gdb|glibc)$/) {
+  if ($component=~/^fedora(gdb|binutils|glibc)$/) {
     $cvsrepo=$1;
     $cvsbasedir="F-$1" if $distro=~/^fedora-(\d+)-$arches_re$/;
     $cvsbasedir="devel" if $distro=~/^fedora-rawhide-$arches_re$/;
     die "$component vs. $distro" if !$cvsbasedir;
     $cvsroot=$fedoracvsroot;
   }
-  if ($component=~/^rhel(gdb|glibc)$/) {
+  if ($component=~/^rhel(gdb|binutils|glibc)$/) {
     $cvsrepo=$1;
     $cvsbasedir="RHEL-$1" if $distro=~/^epel-(\d+)-$arches_re$/;
     die "$component vs. $distro" if !$cvsbasedir;
     $cvsroot=$rhelcvsroot;
+    # EPEL still uses Berkeley DB version 8 while F-11+ (F-10?) uses version 9.
+    # Using db_dump and db_load would no longer make it mock compatible.
+    $rpmbuild.=q{ --dbpath $PWD --nodeps};
   }
 
   my $distrodir="$dir/$distro";
@@ -176,6 +200,9 @@ for my $distro (@distrouse) {
   my $builddir="$distrodir/build";
   newdir $builddir;
 
+  # Do not use mockrun as the rpm database may be in a different version.
+  spawn "rpm -r /var/lib/mock/$distro/root -qa|sort >$distrodir/rpm-qa";
+
   $::distro=$distro;
   sub mockrun($)
   {
@@ -183,13 +210,12 @@ for my $distro (@distrouse) {
 
     $c="export PATH=\"$path:\$PATH\"; $c" if $path;
     $c="export MAKEFLAGS=\"-j\$[`getconf _NPROCESSORS_ONLN`*3/2]\"; $c";
+    $c="export http_proxy=http://127.0.0.1:3128/; $c";
     $c="set -ex; cd $builddir; $c";
     die "found ': $c" if $c=~/'/;
     spawn "mockrun $::distro '$c'";
   }
 
-  mockrun "rpm -qa|sort >$distrodir/rpm-qa";
-
   if ($cvsbasedir) {
     die if !$cvsroot;
     die if !$cvsrepo;
@@ -198,6 +224,8 @@ for my $distro (@distrouse) {
     -d $componentdir or die "Failed checkout to: $componentdir";
     # Required for RHEL; Fedora does so automatically.
     spawn "cd $componentdir/..; cvs -q -z3 -d $cvsroot co common";
+    # Workaround (RHEL-5?) curl which uses `Pragma: nocache' on $http_proxy.
+    subst sub { s{echo "curl }{$&-H 'Pragma: cache' }; },"$componentdir/../common/Makefile.common";
 
     for my $file (@file) {
       my $filebase=$file;
@@ -210,7 +238,9 @@ for my $distro (@distrouse) {
 
     my $glob="$componentdir/*.src.rpm";
     @{[glob $glob]}==0 or die "Found some before test-srpm: $glob";
-    spawn "cd $componentdir; make test-srpm";
+    # No `spawn' as we could get:
+    # error: unpacking of archive failed on file X;4a56efef: cpio: MD5 sum mismatch
+    mockrun "cd $componentdir; make test-srpm";
     my @srcrpm=(glob $glob);
     @srcrpm==1 or die "Did not find 1 srcrpm: @srcrpm";
     $srcrpm=$srcrpm[0];
@@ -221,18 +251,20 @@ for my $distro (@distrouse) {
     $srcrpmbasename=~s{^.*/}{};
     spawn "cp -p $srcrpm $builddir/$srcrpmbasename";
 
-    my $rpmbuildlocal=q{rpmbuild --define "_topdir $PWD" --define "_builddir $PWD" --define "_rpmdir $PWD" --define "_sourcedir $PWD" --define "_specdir $PWD" --define "_srcrpmdir $PWD" --define "_build_name_fmt %%{NAME}-%%{VERSION}-%%{RELEASE}.%%{ARCH}.rpm"};
+    my $rpmbuildlocal=$rpmbuild.q{ --define "_topdir $PWD" --define "_builddir $PWD" --define "_rpmdir $PWD" --define "_sourcedir $PWD" --define "_specdir $PWD" --define "_srcrpmdir $PWD" --define "_build_name_fmt %%{NAME}-%%{VERSION}-%%{RELEASE}.%%{ARCH}.rpm"};
     $rpmbuildlocal="orphanripper $rpmbuildlocal" if $cvsrepo && $cvsrepo eq "glibc";
     mockrun $rpmbuildlocal." --rebuild --with testsuite".($parallel<2 ? "" : " --with parallel")." $srcrpmbasename";
   }
 
   my $baretestsuite;
 
-  if ($component eq "gdbcvs") {
-    if (-d $gdbcvsbare) {
-      spawn "cp -a $gdbcvsbare $builddir/src; cd $builddir/src; cvs update -A";
+  if ($component=~/^(gdb|binutils)cvs$/) {
+    my $which=$1;
+    my $cvsbare=$which eq "gdb" ? $gdbcvsbare : $binutilscvsbare;
+    if (-d $cvsbare) {
+      spawn "cp -a $cvsbare $builddir/src; cd $builddir/src; cvs update -A";
     } else {
-      spawn "cd $builddir; cvs -q -z3 -d :pserver:anoncvs:\@sourceware.org:/cvs/src co gdb";
+      spawn "cd $builddir; cvs -q -z3 -d :pserver:anoncvs:\@sourceware.org:/cvs/src co $which";
     }
     spawn "cd $builddir/src".q{; test -z "$(cvs update -A)"};
     $baretestsuite="$builddir/src";
@@ -256,38 +288,47 @@ for my $distro (@distrouse) {
   if ($baretestsuite) {
     for my $file (@file) {
       my $target="$baretestsuite/$file";
-      if ($file=~m{\Q.patch\E$}) {
+      if ($file=~m{[.](R?)patch$}) {
+       my $R=$1;
        my $fileabs=$file;
        $fileabs=$ENV{"PWD"}."/$fileabs" if $fileabs!~m{^/};
-       spawn "cd $baretestsuite; patch -p1 <$fileabs";
+       spawn "cd $baretestsuite; patch -${R}p".($component=~/binutils/ ? "0" : "1")." <$fileabs";
       } else {
        -f $target or $file=~m{/testsuite/} or die "File $file does not exist at $target";
        spawn "rm -f $target; cp -p $file $target";
       }
     }
 
-    my @check=($distro=~/-x86_64/ ? qw(-m64 -m32) : -m32);
-    @check=map("check//unix/$_",@check);
-    # FSF GDB has no PIE support.
-    # @check=map({($_,"$_/-fPIE/-pie");} @check);
-    # for i in ".join(" ",@check).";do orphanripper make -k \$i || :;done
-    mockrun "cd $baretestsuite; errs1; errs2; cd gdb; ulimit -c unlimited; orphanripper make -k ".join(" ",@check)." || :; mkdir $out; ".q{for t in sum log;do for file in testsuite*/gdb.$t;do suffix="${file#testsuite.unix.}"; suffix="${suffix%/gdb.$t}"; ln $file}." $out/gdb-$distro".q{$suffix.$t || :; done; done;};
+    if ($component eq "binutilscvs") {
+      mockrun "cd $baretestsuite; errs1; errs2; ulimit -c unlimited; orphanripper make -k check || :; mkdir $out; ".q{for file in {gas/testsuite/gas,ld/ld,binutils/binutils}.{sum,log};do ln $file}." $out/binutils-$distro-".q{$(basename $file) || :; done;};
+
+      # gdbunpack does:
+      #                perl -i -pe 's{\Q'"$HOME"'\E/.*?/build/[^/]*/}{}g' "$base"/*
+      my $HOME=$ENV{"HOME"};
+      for my $file (<$out/*>) {
+       subst sub { s{\Q$HOME\E/.*?/build/[^/]*/}{}g; },$file;
+      }
+    } else {
+      my @check=($distro=~/-x86_64/ ? qw(-m64 -m32) : -m32);
+      @check=map("check//unix/$_",@check);
+      # FSF GDB has no PIE support.
+      # @check=map({($_,"$_/-fPIE/-pie");} @check);
+      # for i in ".join(" ",@check).";do orphanripper make -k \$i || :;done
+      mockrun "cd $baretestsuite; errs1; errs2; cd gdb; ulimit -c unlimited; orphanripper make -k ".join(" ",@check)." || :; mkdir $out; ".q{for t in sum log;do for file in testsuite*/gdb.$t;do suffix="${file#testsuite.unix.}"; suffix="${suffix%/gdb.$t}"; ln $file}." $out/gdb-$distro".q{$suffix.$t || :; done; done;};
+    }
   }
 
   # Call gdbunpack only if no direct $out directory will be created.
   # It is needed only for .src.rpm-built testsuites, no matter how .src.rpm
   # got created.
+  my @testinlog;
   if ($component=~/^(?:fedora|rhel)glibc$/) {
-    local *F;
-    open F,$log or die $log;
-    my $F=do { local $/; <F>; } or die $log;
-    close F or die $log;
-    $F=~s{^.*?\n(={20}TESTING DETAILS={17}\n.*\n={20}PLT RELOCS END={18}\n).*$}{$1}s or die "No TESTING part found: $log";
-
-    open F,">$out" or die $out;
-    print F $F or die $out;
-    close F or die $out;
+    @testinlog=(qr/={20}TESTING DETAILS={17}/,qr/={20}PLT RELOCS END={18}/);
+  }
+  if (@testinlog) {
+    subst sub { s{^.*?\n($testinlog[0]\n.*\n$testinlog[1]\n).*$}{$1}s; },$log,$out;
   } elsif ($cvsbasedir || $srcrpm) {
+    # Applies both to gdb and binutils.
     spawn "gdbunpack $log";
   }