]> git.pld-linux.org Git - packages/rpm-build-tools.git/blame - pearize.sh
- fix conflicts parsing
[packages/rpm-build-tools.git] / pearize.sh
CommitLineData
70f6b6a6 1#!/bin/sh
dd7e9d0e
ER
2# updates php-pear .spec with Requires/Conflicts lines.
3# the items are added randomly to the preamble, but once added their order is left intact.
4# it is still better than nothing. if somebody wishes to add sorting in this
5# script. i'd be just glad :)
6#
7# needs pear makerpm command.
70f6b6a6 8# requires tarball to exist in ../SOURCES.
c4bf44d2 9# you should have all pear packages installed to get best results
dd7e9d0e
ER
10#
11# todo: adjust similiarily noautoreqdeps
c4bf44d2
ER
12# bugs: the beta portions in version deps could be wrong (php-4.3.0b1 and alike)
13# see php-pear-DBA_Relational.spec
14# SOmething strange: Requires: php-common < 4:3:5.1
dd7e9d0e
ER
15#
16# note: old version pf this script which was used to convert to new package format is in CVS branch MIGRATE
17# send blames and beer\b\b\b\bideas to glen@pld-linux.org
18
70f6b6a6
ER
19set -e
20spec="$1"
dd7e9d0e
ER
21if [ -z "$spec" ]; then
22 echo >&2 "Usage: $0 SPECFILE"
23 exit 0
24fi
25if [ ! -f "$spec" ]; then
26 echo >&2 "$spec doesn't exist?"
27 exit 1
28fi
ae02a056 29echo "Processing $spec"
c4bf44d2
ER
30
31rc=$(awk '/^%define.*_rc/{print $NF}' $spec)
32pre=$(awk '/^%define.*_pre/{print $NF}' $spec)
33beta=$(awk '/^%define.*_beta/{print $NF}' $spec)
34tarball=$(rpm -q --qf "../SOURCES/%{name}-%{version}$rc$pre$beta.tgz\n" --specfile "$spec" | head -n 1 | sed -e 's,php-pear-,,')
70f6b6a6 35
4188dbdf
ER
36stmp=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX")
37cat > $stmp <<'EOF'
38@extra_headers@
39Optional: @optional@
40EOF
5e241fea 41pear makerpm --spec-template=$stmp $tarball
0c79d776
ER
42rm -f $stmp
43
44template=$(rpm -q --qf "%{name}-%{version}$rc$pre$beta.spec\n" --specfile "$spec" | head -n 1)
5e241fea
ER
45mv $template .$template~
46template=.$template~
19133cbd 47
dd7e9d0e
ER
48requires=$(grep '^Requires:' $template || :)
49conflicts=$(grep '^Conflicts:' $template || :)
50preamble=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX")
51# take just main package preamble, preamble of tests (and other) subpackage(s) just confuses things.
52sed -ne '/^Name:/,/^BuildRoot/p' $spec > $preamble
53
54# take as argument dependency in form NAME EQUALITY VERSION
55# adds rpm epoch to VERSION if the package is installed and has epoch bigger than zero.
56add_epoch() {
57 local dep="$@"
58 local pkg="$1"
a36710cb
ER
59 local ver="$3"
60
61 # already have epoch
62 if [[ "$ver" = *:* ]]; then
63 echo "$dep"
64 return
65 fi
66
dd7e9d0e
ER
67 query=$(rpm -q --qf '%{epoch}\n' $pkg || :)
68 epoch=$(echo "$query" | grep -v 'installed' || :)
69 if [ "$epoch" ] && [ "$epoch" -gt 0 ]; then
70 echo "$dep" | sed -e "s, [<>=] ,&$epoch:,"
71 else
72 echo "$dep"
73 fi
19133cbd
ER
74}
75
dd7e9d0e
ER
76# create backup
77bak=$(cp -fbv $spec $spec | awk '{print $NF}' | tr -d "['\`]" )
19133cbd 78
dd7e9d0e
ER
79if [ -n "$requires" ]; then
80 echo "$requires" | while read tag dep; do
81 dep=$(add_epoch $dep)
82 if ! grep -q "^Requires:.*$dep" $preamble; then
83 sed -i -e "/^BuildRoot/iRequires:\t$dep" $spec
84 fi
85 done
c9f81079
ER
86fi
87
dd7e9d0e 88if [ -n "$conflicts" ]; then
df07ff19 89 echo "$conflicts" | while read tag dep; do
dd7e9d0e
ER
90 dep=$(add_epoch $dep)
91 if ! grep -q "^Conflicts:.*$req" $preamble; then
92 sed -i -e "/^BuildRoot/iConflicts:\t$dep" $spec
93 fi
94 done
05779902
ER
95fi
96
dd7e9d0e 97rm -f $preamble
4d240bd1 98
dd7e9d0e
ER
99diff=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX")
100if ! diff -u $bak $spec > $diff; then
101 vim -o $spec $diff
102 rm -f $diff
103else
104 echo "$spec: No diffs"
4d240bd1 105fi
c4bf44d2 106#exit 1
This page took 0.516584 seconds and 4 git commands to generate.