]> git.pld-linux.org Git - packages/rpm-build-tools.git/blobdiff - pearize.sh
don't override GETURI when using wget
[packages/rpm-build-tools.git] / pearize.sh
old mode 100644 (file)
new mode 100755 (executable)
index 4cb3f18..55363d6
@@ -4,17 +4,32 @@
 # it is still better than nothing. if somebody wishes to add sorting in this
 # script. i'd be just glad :)
 #
-# needs pear makerpm command.
-# requires tarball to exist in ../SOURCES.
-# you should have all pear packages installed to get best results
+# needs 'pear' for 'pear make-rpm-spec' command, ./builder for fetching sources.
+# You should have all PEAR packages installed to get best results (needed for epoch autodetection)
+# So far there are 3 packages with epoch > 0:
+# $ grep ^Epoch:.* php-pear-*.spec | grep -v 'Epoch:.*0'
+# php-pear-MDB2.spec:Epoch:               1
+# php-pear-MDB.spec:Epoch:                1
+# php-pear-PEAR.spec:Epoch:               1
 #
-# todo: adjust similiarily noautoreqdeps
-# bugs: the beta portions in version deps could be wrong (php-4.3.0b1 and alike)
+# To create completely new PEAR package spec, follow something like this:
+# $ pear download RDF-alpha
+# File RDF-0.1.0alpha1.tgz downloaded
+# $ pear make-rpm-spec RDF-0.1.0alpha1.tgz
+# Wrote RPM spec file php-pear-RDF.spec
+# $
+#
+# TODO: adjust similiarily noautoreqdeps
+# BUGS: the beta portions in version deps could be wrong (php-4.3.0b1 and alike)
 # see php-pear-DBA_Relational.spec
-# SOmething strange: Requires: php-common < 4:3:5.1
+# Something strange: Requires: php-common < 4:3:5.1
+#
+# NOTE: old version of this script which was used to convert to new package format is in CVS branch MIGRATE.
 #
-# note: old version pf this script which was used to convert to new package format is in CVS branch MIGRATE
-# send blames and beer\b\b\b\bideas to glen@pld-linux.org
+# Send blames and beer\b\b\b\bideas to glen@pld-linux.org
+
+PROGRAM=${0##*/}
+APPDIR=$(d=$0; [ -L "$d" ] && d=$(readlink -f "$d"); dirname "$d")
 
 set -e
 spec="$1"
@@ -26,26 +41,39 @@ if [ ! -f "$spec" ]; then
        echo >&2 "$spec doesn't exist?"
        exit 1
 fi
+
+if [[ "$(rpm -q php-pear-PEAR_Command_Packaging)" == *is?not* ]]; then
+       echo >&2 "Please install php-pear-PEAR_Command_Packaging"
+       exit 1
+fi
 echo "Processing $spec"
 
-rc=$(awk '/^%define.*_rc/{print $NF}' $spec)
-pre=$(awk '/^%define.*_pre/{print $NF}' $spec)
-beta=$(awk '/^%define.*_beta/{print $NF}' $spec)
-tarball=$(rpm -q --qf "../SOURCES/%{name}-%{version}$rc$pre$beta.tgz\n" --specfile "$spec" | head -n 1 | sed -e 's,php-pear-,,')
+getsource() {
+       local spec="$1"
+       local NR="$2"
+       rpmbuild --nodigest --nosignature -bp --define 'prep %dump' $spec 2>&1 | awk  "/SOURCE$NR\t/ {print \$3}"
+}
+
+tarball=$(getsource $spec 0)
+if [ -z "$tarball" ]; then
+       echo >&2 "Spec is missing Source0!"
+       exit 1
+fi
+
+if [ ! -f $tarball ]; then
+       $APPDIR/builder -g "$spec"
+fi
 
 stmp=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX")
+template=pearize.spec
 cat > $stmp <<'EOF'
 @extra_headers@
-Optional: @optional@
-@optional-pkg@
-@optional-ext@
 License: @release_license@
 State: @release_state@
 EOF
-pear makerpm --spec-template=$stmp $tarball
+pear make-rpm-spec --spec-template=$stmp --output=$template $tarball
 rm -f $stmp
 
-template=$(rpm -q --qf "%{name}-%{version}$rc$pre$beta.spec\n" --specfile "$spec" | head -n 1)
 mv $template .$template~
 template=.$template~
 
@@ -76,14 +104,29 @@ preamble=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX")
 sed -ne '/^Name:/,/^BuildRoot/p' $spec > $preamble
 
 # create backup
-bak=$(cp -fbv $spec $spec | awk '{print $NF}' | tr -d "['\`]" )
+bak=$(LC_ALL=C cp -fbv $spec $spec | awk '{print $NF}' | tr -d "['\`]" )
 
+# ensure rpm-build-macros is present
+if ! grep -q "^BuildRequires:.*rpmbuild(macros)" $preamble; then
+       sed -i -e "/^BuildRequires:.*rpm-php-pearprov/aBuildRequires:\trpmbuild(macros) >= 1.300" $spec
+fi
 # parse requires
+requires=$(grep '^BuildRequires:' $template || :)
+if [ -n "$requires" ]; then
+       echo "$requires" | while read tag dep; do
+               dep=$(add_epoch $dep)
+               if ! grep -q "^BuildRequires:.*$dep" $preamble; then
+                       sed -i -e "/^BuildRoot/iBuildRequires:\t$dep" $spec
+               fi
+       done
+fi
+
 requires=$(grep '^Requires:' $template || :)
 if [ -n "$requires" ]; then
        echo "$requires" | while read tag dep; do
                dep=$(add_epoch $dep)
                if ! grep -q "^Requires:.*$dep" $preamble; then
+                       dep=$(echo "$dep" | sed -e 's,php-pear-PEAR\b,php-pear-PEAR-core,')
                        sed -i -e "/^BuildRoot/iRequires:\t$dep" $spec
                fi
        done
@@ -101,24 +144,102 @@ if [ -n "$conflicts" ]; then
 fi
 
 # parse optional deps
-optional=$(grep '^Optional:' $template || :)
+optional=$(grep '^Suggests:' $template || :)
 if [ -n "$optional" ]; then
        echo "$optional" | while read tag dep; do
+               dep=$(add_epoch $dep)
+               if ! grep -q "^Suggests:.*$dep" $preamble; then
+                       sed -i -e "/^BuildRoot/iSuggests:\t$dep" $spec
+               fi
+
                for req in $dep; do
-                       m=$(grep "^%define.*_noautoreq" $spec | fgrep -o "$req" || :)
+                       case "$req" in
+                       php-pear-*)
+                               # convert pear package name to file pattern
+                               req=$(echo "$req" | sed -e 's,^php-pear-,pear(,;y,_,/,;s,$,.*),')
+                               ;;
+                       *)
+                               # process only php-pear-* packages
+                               continue
+                               ;;
+                       esac
+
+                       m=$(grep "^%define.*_noautoreq" $spec || :)
                        if [ -z "$m" ]; then
-                               sed -i -e "/^%define.*_noautoreq/s/$/ $req/" $spec
+                               sed -i -e "/^BuildRoot:/{
+                                       a
+                                       a# exclude optional dependencies
+                                       a%define\       \       _noautoreq\     $req
+                               }
+                               " $spec
+                       else
+                               m=$(echo "$m" | grep -o "$req" || :)
+                               if [ -z "$m" ]; then
+                                       sed -i -e "/^%define.*_noautoreq/s,$, $req," $spec
+                               fi
                        fi
                done
        done
 fi
 
+optional=$(grep '^Optional-ext:' $template || :)
+if [ -n "$optional" ]; then
+       tmp=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX")
+       echo "$optional" | while read tag ext; do
+               grep -q "PHP extension .$ext" && continue
+               cat > $tmp <<-EOF
+               echo '%{name} can optionally use PHP extension "$ext"' >> optional-packages.txt
+               EOF
+               sed -i -e "
+               /%pear_package_setup/ {
+                       r $tmp
+               }
+               " $spec
+       done
+       rm -f .ext.tmp
+fi
+
+has_opt=$(grep -Ec '^Optional-(pkg|ext):' $template || :)
+if [ "$has_opt" -gt 0 ]; then
+       if ! grep -q 'rpmbuild(macros)' $spec; then
+               sed -i -e '
+               /rpm-php-pearprov/{
+                       aBuildRequires: rpmbuild(macros) >= 1.300
+               }
+               ' $spec
+       fi
+       if ! grep -Eq '%{_docdir}/.*/optional-packages.txt|%pear_package_print_optionalpackages' $spec; then
+               sed -i -e '
+               /^%files$/{
+                       i%post -p <lua>
+                       i%pear_package_print_optionalpackages
+                       i
+               }
+               /rpmbuild(macros)/{
+                       s/>=.*/>= 1.571/
+               }
+               ' $spec
+       fi
+       if ! grep -q '%doc.*optional-packages.txt' $spec; then
+               sed -i -e '
+               /^%doc install.log/{
+               s/$/ optional-packages.txt/
+               }
+               ' $spec
+       fi
+fi
+
 # parse state
 state=$(awk '/^State:/{print $2}' $template)
-sed -i -e "/^%define.*_status/{
-       /%define.*_status.*$state/!s/.*/%define\t\t_status\t\t$state/
+sed -i -e "/^%define.*_\?status/{
+       s/%define[[:space:]]*_status.*/%define\t\t_status\t\t$state/
+       s/%define[[:space:]]*status.*/%define\t\tstatus\t\t$state/
 }" $spec
 
+# parse license
+#license=$(awk '/^License:/{print $2}' $template)
+#sed -i -e "s/^License:.*/License:\t$license/" $spec
+
 rm -f $preamble
 
 diff=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX")
@@ -128,4 +249,3 @@ if ! diff -u $bak $spec > $diff; then
 else
        echo "$spec: No diffs"
 fi
-#exit 1
This page took 0.051856 seconds and 4 git commands to generate.