]> git.pld-linux.org Git - packages/rpm-build-tools.git/blame - pearize.sh
- put %post before first %files section (after %clean)
[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#
62e972e1
ER
7# needs 'pear' for 'pear makerpm' command, ./builder for fetching sources.
8# You should have all PEAR packages installed to get best results.
dd7e9d0e
ER
9#
10# todo: adjust similiarily noautoreqdeps
c4bf44d2
ER
11# bugs: the beta portions in version deps could be wrong (php-4.3.0b1 and alike)
12# see php-pear-DBA_Relational.spec
62e972e1 13# Something strange: Requires: php-common < 4:3:5.1
dd7e9d0e 14#
62e972e1
ER
15# NOTE: old version of this script which was used to convert to new package format is in CVS branch MIGRATE.
16#
17# Send blames and beer\b\b\b\bideas to glen@pld-linux.org
dd7e9d0e 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 30
390d2e8f
ER
31getsource() {
32 local spec="$1"
33 local NR="$2"
34 rpmbuild --nodigest --nosignature -bp --define 'prep %dump' $spec 2>&1 | awk "/SOURCE$NR\t/ {print \$3}"
35}
36
37tarball=$(getsource $spec 0)
70f6b6a6 38
c5ad552d
ER
39if [ ! -f $tarball ]; then
40 ./builder -g "$spec"
41fi
42
4188dbdf
ER
43stmp=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX")
44cat > $stmp <<'EOF'
45@extra_headers@
46Optional: @optional@
d5150240
ER
47@optional-pkg@
48@optional-ext@
5e551ed7
ER
49License: @release_license@
50State: @release_state@
4188dbdf 51EOF
95c0e2f7
ER
52pear makerpm --spec-template=$stmp --rpm-pkgname=pearize $tarball
53template=pearize.spec
0c79d776
ER
54rm -f $stmp
55
5e241fea
ER
56mv $template .$template~
57template=.$template~
19133cbd 58
dd7e9d0e
ER
59# take as argument dependency in form NAME EQUALITY VERSION
60# adds rpm epoch to VERSION if the package is installed and has epoch bigger than zero.
61add_epoch() {
62 local dep="$@"
63 local pkg="$1"
a36710cb
ER
64 local ver="$3"
65
66 # already have epoch
67 if [[ "$ver" = *:* ]]; then
68 echo "$dep"
69 return
70 fi
71
dd7e9d0e
ER
72 query=$(rpm -q --qf '%{epoch}\n' $pkg || :)
73 epoch=$(echo "$query" | grep -v 'installed' || :)
74 if [ "$epoch" ] && [ "$epoch" -gt 0 ]; then
63dd75f0 75 echo "$dep" | sed -e "s, [<>=]\+ ,&$epoch:,"
dd7e9d0e
ER
76 else
77 echo "$dep"
78 fi
19133cbd
ER
79}
80
5e551ed7
ER
81preamble=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX")
82# take just main package preamble, preamble of tests (and other) subpackage(s) just confuses things.
83sed -ne '/^Name:/,/^BuildRoot/p' $spec > $preamble
84
dd7e9d0e
ER
85# create backup
86bak=$(cp -fbv $spec $spec | awk '{print $NF}' | tr -d "['\`]" )
19133cbd 87
5e551ed7
ER
88# parse requires
89requires=$(grep '^Requires:' $template || :)
dd7e9d0e
ER
90if [ -n "$requires" ]; then
91 echo "$requires" | while read tag dep; do
92 dep=$(add_epoch $dep)
93 if ! grep -q "^Requires:.*$dep" $preamble; then
94 sed -i -e "/^BuildRoot/iRequires:\t$dep" $spec
95 fi
96 done
c9f81079
ER
97fi
98
5e551ed7
ER
99# parse conflicts
100conflicts=$(grep '^Conflicts:' $template || :)
dd7e9d0e 101if [ -n "$conflicts" ]; then
df07ff19 102 echo "$conflicts" | while read tag dep; do
dd7e9d0e
ER
103 dep=$(add_epoch $dep)
104 if ! grep -q "^Conflicts:.*$req" $preamble; then
105 sed -i -e "/^BuildRoot/iConflicts:\t$dep" $spec
106 fi
107 done
05779902
ER
108fi
109
cb4369bd
ER
110# parse optional deps
111optional=$(grep '^Optional:' $template || :)
112if [ -n "$optional" ]; then
113 echo "$optional" | while read tag dep; do
114 for req in $dep; do
961c2719 115 m=$(grep "^%define.*_noautoreq" $spec | grep -o "$req" || :)
cb4369bd 116 if [ -z "$m" ]; then
961c2719 117 sed -i -e "/^%define.*_noautoreq/s,$, $req," $spec
cb4369bd
ER
118 fi
119 done
120 done
121fi
a12e7b76 122has_opt=$(egrep -c '^Optional-(pkg|ext):' $template || :)
b299cb78 123if [ "$has_opt" -gt 0 ]; then
07dbc9c8 124 if ! grep -q '%{_docdir}/.*/optional-packages.txt' $spec; then
b299cb78 125 sed -i -e '
20aec7a3 126 /^%files$/{
b299cb78
ER
127 i%post
128 iif [ -f %{_docdir}/%{name}-%{version}/optional-packages.txt ]; then
129 i\ cat %{_docdir}/%{name}-%{version}/optional-packages.txt
130 ifi
131 i
132 }
07dbc9c8
ER
133 ' $spec
134 fi
135 if ! grep -q '%doc.*optional-packages.txt' $spec; then
136 sed -i -e '
b299cb78
ER
137 /^%doc install.log/{
138 s/$/ optional-packages.txt/
139 }
140 ' $spec
141 fi
142fi
cb4369bd 143
5e551ed7
ER
144# parse state
145state=$(awk '/^State:/{print $2}' $template)
146sed -i -e "/^%define.*_status/{
147 /%define.*_status.*$state/!s/.*/%define\t\t_status\t\t$state/
148}" $spec
149
dd7e9d0e 150rm -f $preamble
4d240bd1 151
dd7e9d0e
ER
152diff=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX")
153if ! diff -u $bak $spec > $diff; then
154 vim -o $spec $diff
155 rm -f $diff
156else
157 echo "$spec: No diffs"
4d240bd1 158fi
c4bf44d2 159#exit 1
This page took 0.056015 seconds and 4 git commands to generate.