Author: arekm                        Date: Tue Jul 29 20:43:16 2008 GMT
Module: SOURCES                       Tag: HEAD
---- Log message:
- use versions from rpm-4_4_9 branch

---- Files affected:
SOURCES:
   rpm-php-requires (1.16 -> 1.17) , rpm-php-provides (1.9 -> 1.10) 

---- Diffs:

================================================================
Index: SOURCES/rpm-php-requires
diff -u SOURCES/rpm-php-requires:1.16 SOURCES/rpm-php-requires:1.17
--- SOURCES/rpm-php-requires:1.16       Mon Dec  1 20:59:42 2003
+++ SOURCES/rpm-php-requires    Tue Jul 29 22:43:10 2008
@@ -1,78 +1,82 @@
-#!/usr/bin/perl -W
+#!/usr/bin/perl
 #####################################################################
 #                                                                   #
-# Check system dependencies between php-pear/php-pecl modules       #
+# Check system dependences between php-pear modules                 #
 #                                                                   #
-# Adam Go��biowski  <[EMAIL PROTECTED]>                           #
-#                                                                   #
-# based on previous work by:                                        #
 # Pawe� Go�aszewski <[EMAIL PROTECTED]>                            #
-# Micha� Moskal     <[EMAIL PROTECTED]>                        #
-#                                                                   #
-# ----------------------------------------------------------------- #
-# ChangeLog:                                                        #
-# 20031201: complete rewrite to use PEAR's package.xml, now handles #
-#           all dependencies, including PHP modules (like php-gmp), #
-#           and PECL extensions   (adamg)                           #
+# Micha� Moskal <[EMAIL PROTECTED]>                            #
+# ------------------------------------------------------------------#
+# TODO:                                                             #
+# - extension_loaded - dependencies.                                #
+# - some clean-up...                                                #
 #####################################################################
 
[EMAIL PROTECTED] = ();
-$fname = '/dev/null';
-foreach ( @ARGV ? $ARGV : <> )
-{
-    $fname = $_ if (/package.xml/)
-}
+$pear = "/usr/share/pear";
 
-open F, $fname;
[EMAIL PROTECTED] = ();
+%req = ();
 
-while (<F>) {
-       if ( /\s+\<dep\s+type\=\"([a-zA-z]*)\"/ ) {
-         $type = $1;
-         die ("ERROR: Unsupported type: $type\n") if ( $type !~ 
/^(pkg|ext|php|prog|os|sapi|zend)$/i);
-         # Default relation (as suggested by PEAR manual) is has
-         $rel = "has";
-         $rel = $1 if ( /rel="([a-zA-Z]*)"/ );
-         die ("ERROR: Unsupported relation: $rel\n") if ( $rel !~ 
/^(has|eq|lt|le|gt|ge)$/ );
-          
-         # Check if we don't have some unsupported connection betweend 
relation and type
-         die ("ERROR: Cannot use lt/le/gt/ge relation with prog/os/sapi 
type!\n") if ( $rel =~ /^(lt|le|gt|ge)$/ && $type =~ /^(prog|os|sapi)$/ );
-
-         # do we have version?
-         $version = "";
-         $version = $1 if ( /version="([a-zA-z0-9\.\+]*)"/ );
-
-         # optional - actually this one is optional ;)
-         # NOTE: 
-         # even though this attribute marks dependency as optional,
-         # we will add it to Requires: 
-         $optional = "no";
-         $optional = $1 if ( /optional="([a-zA-Z]*)"/ );
-          die ("ERROR: Ambigous value of optional attribute: $optional\n") if 
( $optional !~ /(yes|no)/i );
-
-         # now, check if we need to pull out package/extension/whatever name
-         $name = "";
-         $name = "php" if ( $type =~ /php/ );
-         $name = "$1"  if ( $type !~ /php/ && /\>([a-zA-Z0-9\_\-]*)\</ );
-          
-         $relation = "";
-         $relation = "<"  if ( $rel eq "lt");
-         $relation = "<=" if ( $rel eq "le");
-         $relation = "="  if ( $rel eq "eq");
-         $relation = ">=" if ( $rel eq "ge");
-         $relation = ">"  if ( $rel eq "gt");
-         $relation = "="  if ( $rel eq "has");
-         # die if we were unable to substitute relations
-         die "ERROR: Unexpected relation! ($rel)\n" if ( $relation eq "");
-          
-         $req = "";
-         $relver = "";
-         $relver = "$relation $version" if ( $version !~ /^$/ );
-         $req = "$name $relver" if ( $type =~ /(php|prog)/ );
-         $req = "php-$name $relver" if ( $type =~ /ext/ );
-         $req = "php-pear-$name" if ( $type =~ /pkg/ );
-          
-         push @req_arr, $req
+foreach (@ARGV ? $ARGV : <> ) {
+       chomp;
+       $f = $_;
+       push @files, $f;
+       # skip non-php files
+       next unless ($f =~ /\.php$/);
+       open(F, "< $f") or die;
+
+       if ($f =~ /$pear/) {
+               $file_dir = $f;
+               $file_dir =~ s|.*$pear/||;
+               $file_dir =~ s|/[^/]*$||;
+       } else {
+               $file_dir = undef;
+       }
+
+       while (<F>) {
+               # skip comments
+               next if (/^\s*(#|\/\/|\*|\/\*)/);
+
+               while (/(\W|^)(require|include)(_once)?
+                         \s* \(? \s* ("([^"]*)"|'([^']*)') 
+                         \s* \)? \s* ;/xg) {
+                       if ($5 ne "") {
+                               $x = $5;
+                       } elsif ($6 ne "") {
+                               $x = $6;
+                       } else {
+                               next;
+                       }
+
+                       next if ($x =~ m|^\./| or $x =~ /\$/);
+                       next unless ($x =~ /\.php$/);
+                       $req{$x} = 1;
+               }
+
+               next unless (defined $file_dir);
+
+               while (/(\W|^)(require|include)(_once)?
+                         \s* \(? \s* dirname \s* \( \s* __FILE__ \s* \) \s* \. 
\s*
+                         ("([^"]*)"|'([^']*)') 
+                         \s* \)? \s* ;/xg) {
+                       if ($5 ne "") {
+                               $x = $5;
+                       } elsif ($6 ne "") {
+                               $x = $6;
+                       } else {
+                               next;
+                       }
+
+                       next if ($x =~ /\$/);
+                       next unless ($x =~ /\.php$/);
+
+                       $x = "$file_dir/$x";
+                       $x =~ s|/+|/|g;
+                       $req{$x} = 1;
+               }
+       }
+}
 
-    }
+f: for $f (keys %req) {
+       for $g (@files) { next f if ($g =~ /\Q$f\E$/); }
+       print "pear($f)\n";
 }
-for $r (@req_arr) { print "$r\n"; }

================================================================
Index: SOURCES/rpm-php-provides
diff -u SOURCES/rpm-php-provides:1.9 SOURCES/rpm-php-provides:1.10
--- SOURCES/rpm-php-provides:1.9        Mon Dec  1 20:59:41 2003
+++ SOURCES/rpm-php-provides    Tue Jul 29 22:43:10 2008
@@ -1,17 +1,20 @@
 #!/usr/bin/perl
 #####################################################################
 #                                                                   #
-# Small script to generate provides for php-pear/php-pecl           #
+# Check system dependences between php-pear modules                 #
 #                                                                   #
-# Adam Go��biowski <[EMAIL PROTECTED]>                            #
-#                                                                   #
-# Somehow based on previous work by:                                #
-# Pawe� Go�aszewski <[EMAIL PROTECTED]>                           #
+# Pawe� Go�aszewski <[EMAIL PROTECTED]>                            #
 # Micha� Moskal <[EMAIL PROTECTED]>                            #
+# ------------------------------------------------------------------#
+# TODO:                                                             #
 #####################################################################
 
-# Contest: shrink this one to oneliner 
-# Bonus  : and fit in 80 columns ;)
+$pear = "/usr/share/pear";
 
-/package.xml/ and open(F, $_) foreach (@ARGV ? @ARGV : <> );
-/^\s+\<name\>([a-zA-Z0-9\_]+)\<\/name\>$/ and print "php-pear-$1" while (<F>);
+foreach (@ARGV ? @ARGV : <>) {
+       chomp;
+       $f = $_;
+       next unless ($f =~ /$pear.*\.php$/);
+       $f =~ s/.*$pear\///;
+       print "pear($f)\n";
+}
================================================================

---- CVS-web:
    
http://cvs.pld-linux.org/cgi-bin/cvsweb.cgi/SOURCES/rpm-php-requires?r1=1.16&r2=1.17&f=u
    
http://cvs.pld-linux.org/cgi-bin/cvsweb.cgi/SOURCES/rpm-php-provides?r1=1.9&r2=1.10&f=u

_______________________________________________
pld-cvs-commit mailing list
[email protected]
http://lists.pld-linux.org/mailman/listinfo/pld-cvs-commit

Reply via email to