Remember to add the osgideps patch..
This commit is contained in:
parent
344000f3c1
commit
6a747fab31
197
rpm-4.4.2.2-osgideps.patch
Normal file
197
rpm-4.4.2.2-osgideps.patch
Normal file
@ -0,0 +1,197 @@
|
|||||||
|
changeset: 6184:9de21aa6bd62
|
||||||
|
tag: tip
|
||||||
|
user: Panu Matilainen <pmatilai@redhat.com>
|
||||||
|
date: Thu Sep 06 08:19:03 2007 +0300
|
||||||
|
files: scripts/Makefile.am scripts/osgideps.pl
|
||||||
|
description:
|
||||||
|
Add OSGi dependency extractor script from Kyu Lee
|
||||||
|
(transplanted from 838c8ccfcf2619369e76bdca375721e049052dc8)
|
||||||
|
|
||||||
|
|
||||||
|
diff -r 358dd9d838a6 -r 9de21aa6bd62 scripts/Makefile.am
|
||||||
|
--- a/scripts/Makefile.am Thu Oct 11 14:14:00 2007 +0300
|
||||||
|
+++ b/scripts/Makefile.am Thu Sep 06 08:19:03 2007 +0300
|
||||||
|
@@ -21,7 +21,7 @@ EXTRA_DIST = \
|
||||||
|
sql.prov sql.req tcl.req tgpg trpm u_pkg.sh \
|
||||||
|
vpkg-provides.sh vpkg-provides2.sh \
|
||||||
|
macros.perl* macros.python* \
|
||||||
|
- macros.php* find-*.php find-php-* mono-find*
|
||||||
|
+ macros.php* find-*.php find-php-* mono-find* osgideps.pl
|
||||||
|
|
||||||
|
installprefix = $(DESTDIR)
|
||||||
|
|
||||||
|
@@ -38,7 +38,7 @@ config_SCRIPTS = \
|
||||||
|
cpanflute cpanflute2 Specfile.pm find-provides.perl \
|
||||||
|
find-requires.perl freshen.sh get_magic.pl getpo.sh http.req \
|
||||||
|
magic.prov magic.req perldeps.pl perl.prov perl.req pythondeps.sh \
|
||||||
|
- mono-find-requires mono-find-provides \
|
||||||
|
+ mono-find-requires mono-find-provides osgideps.pl \
|
||||||
|
rpmdb_loadcvt rpmdiff rpmdiff.cgi \
|
||||||
|
rpm.daily rpm.log rpm.xinetd rpm2cpio.sh \
|
||||||
|
sql.prov sql.req tcl.req tgpg trpm u_pkg.sh \
|
||||||
|
diff -r 358dd9d838a6 -r 9de21aa6bd62 scripts/osgideps.pl
|
||||||
|
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
|
||||||
|
+++ b/scripts/osgideps.pl Thu Sep 06 08:19:03 2007 +0300
|
||||||
|
@@ -0,0 +1,161 @@
|
||||||
|
+#!/usr/bin/perl
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+use Cwd;
|
||||||
|
+use Getopt::Long;
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+$cdir = getcwd();
|
||||||
|
+$TEMPDIR="/tmp";
|
||||||
|
+$MANIFEST_NAME="META-INF/MANIFEST.MF";
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+# prepare temporary directory
|
||||||
|
+if (! (-d $TEMPDIR)) {
|
||||||
|
+ if (($_ = `mkdir $TEMPDIR`) != 0) {exit 1;}
|
||||||
|
+ elsif (! (-w $TEMPDIR) && (-x $TEMPDIR)) {exit 1;}
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# parse options
|
||||||
|
+my ($show_provides, $show_requires);
|
||||||
|
+
|
||||||
|
+my $result = GetOptions("provides" => \$show_provides,
|
||||||
|
+ "requires" => \$show_requires);
|
||||||
|
+
|
||||||
|
+exit(1) if (not $result);
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+@allfiles = <STDIN>;
|
||||||
|
+
|
||||||
|
+if ($show_provides) {
|
||||||
|
+ do_provides(@allfiles);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+if ($show_requires) {
|
||||||
|
+ do_requires(@allfiles);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+exit(0);
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+sub do_provides {
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+foreach $jar (@_) {
|
||||||
|
+
|
||||||
|
+next if -f $jar && -r $jar;
|
||||||
|
+ $jar =~ s/[^[:print:]]//g;
|
||||||
|
+ # if this jar contains MANIFEST.MF file
|
||||||
|
+ if (`jar tf $jar | grep -e \^$MANIFEST_NAME` eq "$MANIFEST_NAME\n") {
|
||||||
|
+ # extract MANIFEST.MF file from jar to temporary directory
|
||||||
|
+ chdir $TEMPDIR;
|
||||||
|
+ `jar xf $cdir/$jar $MANIFEST_NAME`;
|
||||||
|
+ open(MANIFEST, "$MANIFEST_NAME");
|
||||||
|
+ my $bundleName = "";
|
||||||
|
+ my $bundleVersion = "";
|
||||||
|
+ # parse bundle name and version
|
||||||
|
+ while(<MANIFEST>) {
|
||||||
|
+ # get rid of non-print chars (some manifest files contain weird chars
|
||||||
|
+ s/[^[:print]]//g;
|
||||||
|
+ if (m/(^Bundle-SymbolicName: )((\w|\.)+)(\;*)(.*\n)/) {
|
||||||
|
+ $bundleName = $2;
|
||||||
|
+ }
|
||||||
|
+ if (m/(^Bundle-Version: )(.*)/) {
|
||||||
|
+ $bundleVersion = $2;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ # skip this jar if no bundle name exists
|
||||||
|
+ if (! $bundleName eq "") {
|
||||||
|
+ if (! $bundleVersion eq "") {
|
||||||
|
+ print "osgi(".$bundleName.") = ".$bundleVersion."\n";
|
||||||
|
+ } else {
|
||||||
|
+ print "osgi(".$bundleName.")\n";
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ chdir $cdir;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+sub do_requires {
|
||||||
|
+
|
||||||
|
+foreach $jar (@_) {
|
||||||
|
+next if -f $jar && -r $jar;
|
||||||
|
+$jar =~ s/[^[:print:]]//g;
|
||||||
|
+ if (`jar tf $jar | grep -e \^$MANIFEST_NAME` eq "$MANIFEST_NAME\n") {
|
||||||
|
+ chdir $TEMPDIR;
|
||||||
|
+ `jar xf $cdir/$jar $MANIFEST_NAME`;
|
||||||
|
+ open(MANIFEST, "$MANIFEST_NAME") or die;
|
||||||
|
+ my %reqcomp = ();
|
||||||
|
+ while(<MANIFEST>) {
|
||||||
|
+ if (m/(^(Require-Bundle|Import-Package): )(.*)$/) {
|
||||||
|
+ my $reqlist = "$3"."\n";
|
||||||
|
+ while(<MANIFEST>) {
|
||||||
|
+ if (m/^[[:upper:]][[:alpha:]]+-[[:upper:]][[:alpha:]]+: .*/) {
|
||||||
|
+ $len = length $_;
|
||||||
|
+ seek MANIFEST, $len*-1 , 1;
|
||||||
|
+ last;
|
||||||
|
+ }
|
||||||
|
+ $reqlist.="$_";
|
||||||
|
+ }
|
||||||
|
+ push @requirelist, parseReqString($reqlist);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ }
|
||||||
|
+ chdir $cdir;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+$list = "";
|
||||||
|
+for $require (@requirelist) {
|
||||||
|
+ $list .= "osgi(".$require->{NAME}.")".$require->{VERSION}."\n";
|
||||||
|
+}
|
||||||
|
+#$abc = `echo \"$list\"|grep -e \^osgi\\(.*\\)| sort|uniq`;
|
||||||
|
+print $list;
|
||||||
|
+
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+sub parseReqString {
|
||||||
|
+ my $reqstr = $_[0];
|
||||||
|
+ my @return;
|
||||||
|
+ $reqstr =~ s/ //g;
|
||||||
|
+ $reqstr =~ s/\n//g;
|
||||||
|
+ $reqstr =~ s/[^[:print:]]//g;
|
||||||
|
+ $reqstr =~ s/("[[:alnum:]|\-|\_|\.|\(|\)|\[|\]]+)(,)([[:alnum:]|\-|\_|\.|\(|\)|\[|\]]+")/$1 $3/g;
|
||||||
|
+ @reqcomp = split /,/g, $reqstr;
|
||||||
|
+ foreach $reqelement (@reqcomp) {
|
||||||
|
+ @reqelementfrmnt = split /;/g, $reqelement;
|
||||||
|
+ $name="";
|
||||||
|
+ $version="";
|
||||||
|
+ $name = $reqelementfrmnt[0];
|
||||||
|
+ for $i (1 .. $#reqelementfrmnt) {
|
||||||
|
+ if ($reqelementfrmnt[$i] =~ m/(^(bundle-|)version=")(.*)(")/){
|
||||||
|
+ $version = $3;
|
||||||
|
+ last;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ $version = parseVersion($version);
|
||||||
|
+ push @return, { NAME=>"$name", VERSION=>"$version"};
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return @return;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+sub parseVersion {
|
||||||
|
+ my $ver = $_[0];
|
||||||
|
+ if ($ver eq "") { return "";}
|
||||||
|
+ if ($ver =~ m/(^[\[|\(])(.+)\ (.+)([\]|\)]$)/) {
|
||||||
|
+ ($1 eq "\[") ? return " <= $2" : return " < $2";
|
||||||
|
+ } else {
|
||||||
|
+ return " = $ver";
|
||||||
|
+ }
|
||||||
|
+ return $ver;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
|
Loading…
Reference in New Issue
Block a user