]>
Commit | Line | Data |
---|---|---|
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 |
19 | set -e |
20 | spec="$1" | |
dd7e9d0e ER |
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 | |
ae02a056 | 29 | echo "Processing $spec" |
c4bf44d2 | 30 | |
390d2e8f ER |
31 | getsource() { |
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 | ||
37 | tarball=$(getsource $spec 0) | |
70f6b6a6 | 38 | |
c5ad552d ER |
39 | if [ ! -f $tarball ]; then |
40 | ./builder -g "$spec" | |
41 | fi | |
42 | ||
4188dbdf ER |
43 | stmp=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX") |
44 | cat > $stmp <<'EOF' | |
45 | @extra_headers@ | |
46 | Optional: @optional@ | |
d5150240 ER |
47 | @optional-pkg@ |
48 | @optional-ext@ | |
5e551ed7 ER |
49 | License: @release_license@ |
50 | State: @release_state@ | |
4188dbdf | 51 | EOF |
95c0e2f7 ER |
52 | pear makerpm --spec-template=$stmp --rpm-pkgname=pearize $tarball |
53 | template=pearize.spec | |
0c79d776 ER |
54 | rm -f $stmp |
55 | ||
5e241fea ER |
56 | mv $template .$template~ |
57 | template=.$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. | |
61 | add_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 |
81 | preamble=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX") |
82 | # take just main package preamble, preamble of tests (and other) subpackage(s) just confuses things. | |
83 | sed -ne '/^Name:/,/^BuildRoot/p' $spec > $preamble | |
84 | ||
dd7e9d0e ER |
85 | # create backup |
86 | bak=$(cp -fbv $spec $spec | awk '{print $NF}' | tr -d "['\`]" ) | |
19133cbd | 87 | |
5e551ed7 ER |
88 | # parse requires |
89 | requires=$(grep '^Requires:' $template || :) | |
dd7e9d0e ER |
90 | if [ -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 |
97 | fi |
98 | ||
5e551ed7 ER |
99 | # parse conflicts |
100 | conflicts=$(grep '^Conflicts:' $template || :) | |
dd7e9d0e | 101 | if [ -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 |
108 | fi |
109 | ||
cb4369bd ER |
110 | # parse optional deps |
111 | optional=$(grep '^Optional:' $template || :) | |
112 | if [ -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 | |
121 | fi | |
a12e7b76 | 122 | has_opt=$(egrep -c '^Optional-(pkg|ext):' $template || :) |
b299cb78 | 123 | if [ "$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 | |
142 | fi | |
cb4369bd | 143 | |
5e551ed7 ER |
144 | # parse state |
145 | state=$(awk '/^State:/{print $2}' $template) | |
146 | sed -i -e "/^%define.*_status/{ | |
147 | /%define.*_status.*$state/!s/.*/%define\t\t_status\t\t$state/ | |
148 | }" $spec | |
149 | ||
dd7e9d0e | 150 | rm -f $preamble |
4d240bd1 | 151 | |
dd7e9d0e ER |
152 | diff=$(mktemp "${TMPDIR:-/tmp}/fragXXXXXX") |
153 | if ! diff -u $bak $spec > $diff; then | |
154 | vim -o $spec $diff | |
155 | rm -f $diff | |
156 | else | |
157 | echo "$spec: No diffs" | |
4d240bd1 | 158 | fi |
c4bf44d2 | 159 | #exit 1 |