]> git.pld-linux.org Git - packages/rpm.git/blobdiff - rpm-perl-req-perlfile.patch
- fix building python bindings (force librarries from build tree)
[packages/rpm.git] / rpm-perl-req-perlfile.patch
index 45043f743eb062a9fe900b01dafe6add6cbf9fd1..16ad595114be3d0be9e782727e16bdac52d0e75b 100644 (file)
@@ -1,17 +1,53 @@
---- rpm-4.0/scripts/perl.req   Wed Jul  5 14:26:37 2000
-+++ rpm-4.0.new/scripts/perl.req       Wed Nov 15 21:31:03 2000
-@@ -82,6 +82,53 @@
- exit 0;
+--- rpm-4.2/scripts/perl.req.wigperl   Tue Apr  1 13:33:52 2003
++++ rpm-4.2/scripts/perl.req   Tue Apr  1 13:39:47 2003
+@@ -39,28 +39,19 @@
+ eval { require version; $HAVE_VERSION = 1; };
  
  
+-if ("@ARGV") {
+-  foreach (@ARGV) {
++foreach ( @ARGV ? @ARGV : <> ) {
++      chomp;
+     if (m=/usr/(sbin|bin|lib|share|X11R6/(lib|bin))/=) {
+       if (! m=(/(doc|man|info|usr/src)/|\.(so|ph|h|html|pod)$)=) {
+-        process_file($_);
++        process_file($_) if -f;
+       }
+     }
+-  }
+-} else {
+-
+-  # notice we are passed a list of filenames NOT as common in unix the
+-  # contents of the file.
+-
+-  foreach (<>) {
+-     if (m=/usr/(sbin|bin|lib|share|X11R6/(lib|bin))/=) {
+-       if (! m=(/(doc|man|info|usr/src)/|\.(so|ph|h|html|pod)$)=) {
+-         process_file($_);
+-       }
+-     }
+-  }
+ }
++foreach (sort keys %provide) {
++    delete $require{$_};
++}
++delete $require{the}; # don't count "use the sth" as perl module  
+ foreach $perlver (sort keys %perlreq) {
+   print "perl >= $perlver\n";
+@@ -82,6 +74,53 @@
+   }
+ }
 +sub is_perlfile {
 +    my $file = shift;
 +    my $fh = shift;
-+    
++
 +    my $fl = <$fh>;
 +
 +    my $is_perl = 0;
-+  
++
 +    my $nw = 0;
 +
 +    if ($file =~ /\.(so|ph|h|html|pod|gz|bz2|png|gif|jpg|xpm|a|patch|o|mo)$/) {
 +          last if ($. > 30);
 +      }
 +    }
-+    
++
 +    seek($fh, 0, 0);
-+    
++
 +    $is_perl = 1 if ($nw > 1);  # propably perl file
-+    
++
 +    #if (!$is_perl) {
 +    #   print STDERR "NOPERL $file\n";
 +    #   return 0;
 +    return $is_perl;
 +}
 +
  sub process_file {
-   
-@@ -90,6 +137,8 @@
-   
-   open(FILE, "<$file")||
-     die("$0: Could not open file: '$file' : $!\n");
-+
+   my ($file) = @_;
+@@ -90,6 +129,8 @@
+     return;
+   }
 +  return if (!is_perlfile($file, \*FILE));
-   
++
    while (<FILE>) {
-     
-@@ -209,6 +258,10 @@
-       # if the module name starts in a dot it is not a module name.
  
-       ($module =~ m/^\./) && next;
+     # skip the "= <<" block
+@@ -111,6 +152,10 @@
+       last;
+     }
++    if (m/^\s*package\s+([_:a-zA-Z0-9]+)\s*;/) {
++      $provide{$1} = 1;
++    }
 +
+     # Each keyword can appear multiple times.  Don't
+     #  bother with datastructures to store these strings,
+     #  if we need to print it print it now.
+@@ -236,6 +281,10 @@
+       ($module =~ m/^\./) && next;
 +      # name starts in a non alphanumeric character it is not a module 
 +      # name.
 +      ($module =~ m/^\W/) && next;
++
        # if the module ends with .pm strip it to leave only basename.
  
+       $module =~ s/\.pm$//;
This page took 0.299139 seconds and 4 git commands to generate.