]> git.pld-linux.org Git - packages/rpm-build-tools.git/blob - pearize.sh
- fix conflicts parsing
[packages/rpm-build-tools.git] / pearize.sh
1 #!/bin/sh
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.
8 # requires tarball to exist in ../SOURCES.
9 # you should have all pear packages installed to get best results
10 #
11 # todo: adjust similiarily noautoreqdeps
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
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
19 set -e
20 spec="$1"
21 if [ -z "$spec" ]; then
22         echo >&2 "Usage: $0 SPECFILE"
23         exit 0
24 fi
25 if [ ! -f "$spec" ]; then
26         echo >&2 "$spec doesn't exist?"
27         exit 1
28 fi
29 echo "Processing $spec"
30
31 rc=$(awk '/^%define.*_rc/{print $NF}' $spec)
32 pre=$(awk '/^%define.*_pre/{print $NF}' $spec)
33 beta=$(awk '/^%define.*_beta/{print $NF}' $spec)
34 tarball=$(rpm -q --qf "../SOURCES/%{name}-%{version}$rc$pre$beta.tgz\n" --specfile "$spec" | head -n 1 | sed -e 's,php-pear-,,')
35
36 stmp=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX")
37 cat > $stmp <<'EOF'
38 @extra_headers@
39 Optional: @optional@
40 EOF
41 pear makerpm --spec-template=$stmp $tarball
42 rm -f $stmp
43
44 template=$(rpm -q --qf "%{name}-%{version}$rc$pre$beta.spec\n" --specfile "$spec" | head -n 1)
45 mv $template .$template~
46 template=.$template~
47
48 requires=$(grep '^Requires:' $template || :)
49 conflicts=$(grep '^Conflicts:' $template || :)
50 preamble=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX")
51 # take just main package preamble, preamble of tests (and other) subpackage(s) just confuses things.
52 sed -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.
56 add_epoch() {
57         local dep="$@"
58         local pkg="$1"
59         local ver="$3"
60
61         # already have epoch
62         if [[ "$ver" = *:* ]]; then
63                 echo "$dep"
64                 return
65         fi
66
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
74 }
75
76 # create backup
77 bak=$(cp -fbv $spec $spec | awk '{print $NF}' | tr -d "['\`]" )
78
79 if [ -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
86 fi
87
88 if [ -n "$conflicts" ]; then
89         echo "$conflicts" | while read tag dep; do
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
95 fi
96
97 rm -f $preamble
98
99 diff=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX")
100 if ! diff -u $bak $spec > $diff; then
101         vim -o $spec $diff
102         rm -f $diff
103 else
104         echo "$spec: No diffs"
105 fi
106 #exit 1
This page took 0.114704 seconds and 4 git commands to generate.