author | kergoth <kergoth> | 2003-01-24 05:48:05 (UTC) |
---|---|---|
committer | kergoth <kergoth> | 2003-01-24 05:48:05 (UTC) |
commit | 4495fda0ab1d48800c6101ec635bafb70ebd07f1 (patch) (unidiff) | |
tree | d848b34e0bfe2c89bb664a92934128e6deca4e36 | |
parent | 53b0504f955d22600f3123f0837b0a0541453fca (diff) | |
download | opie-4495fda0ab1d48800c6101ec635bafb70ebd07f1.zip opie-4495fda0ab1d48800c6101ec635bafb70ebd07f1.tar.gz opie-4495fda0ab1d48800c6101ec635bafb70ebd07f1.tar.bz2 |
Correct a minor bug.. now it uses -e instead of -x to check for the pre/post scripts, and chmod 755's them after cp'ing, in case the permissions are hosed.
-rwxr-xr-x | mkipks | 3 |
1 files changed, 2 insertions, 1 deletions
@@ -91,150 +91,151 @@ do | |||
91 | packagename=${i##*/}; packagename=${packagename%.control} | 91 | packagename=${i##*/}; packagename=${packagename%.control} |
92 | version=$(eval echo '"'$(sed -n -e "s/^Version: *//p" $i)'"') | 92 | version=$(eval echo '"'$(sed -n -e "s/^Version: *//p" $i)'"') |
93 | depends=$(eval echo '"'$(sed -n -e "s/^Depends: *//p" $i)'"') | 93 | depends=$(eval echo '"'$(sed -n -e "s/^Depends: *//p" $i)'"') |
94 | files=$(eval echo $(sed -n -e "s/^Files://p" $i)) | 94 | files=$(eval echo $(sed -n -e "s/^Files://p" $i)) |
95 | arch=$(eval echo $(sed -n -e "s/^Arch://p" $i)) | 95 | arch=$(eval echo $(sed -n -e "s/^Arch://p" $i)) |
96 | section=$(sed -n -e "s/^Section: *//p" $i) | 96 | section=$(sed -n -e "s/^Section: *//p" $i) |
97 | provides=$(sed -n -e "s/^Provides: *//p" $i) | 97 | provides=$(sed -n -e "s/^Provides: *//p" $i) |
98 | conflicts=$(sed -n -e "s/^Conflicts: *//p" $i) | 98 | conflicts=$(sed -n -e "s/^Conflicts: *//p" $i) |
99 | license=$(sed -n -e "s/^License: *//p" $i) | 99 | license=$(sed -n -e "s/^License: *//p" $i) |
100 | summary=$(sed -n -e "s/^Description: *//p" $i) | 100 | summary=$(sed -n -e "s/^Description: *//p" $i) |
101 | package=${packagename}_${version}_$ARCH | 101 | package=${packagename}_${version}_$ARCH |
102 | ERROR= | 102 | ERROR= |
103 | if [ -z "$files" ] | 103 | if [ -z "$files" ] |
104 | then | 104 | then |
105 | mkdir -p $DATADIR/usr/share/doc/$packagename | 105 | mkdir -p $DATADIR/usr/share/doc/$packagename |
106 | else | 106 | else |
107 | for f in $files | 107 | for f in $files |
108 | do | 108 | do |
109 | if [ -d $f ] | 109 | if [ -d $f ] |
110 | then | 110 | then |
111 | ffiles=$(find $f -type f -o -type b -o -type c -o -type l) | 111 | ffiles=$(find $f -type f -o -type b -o -type c -o -type l) |
112 | else | 112 | else |
113 | ffiles=$f | 113 | ffiles=$f |
114 | fi | 114 | fi |
115 | for ff in $ffiles | 115 | for ff in $ffiles |
116 | do | 116 | do |
117 | case $ff in | 117 | case $ff in |
118 | */CVS/*) | 118 | */CVS/*) |
119 | continue | 119 | continue |
120 | ;;*~) | 120 | ;;*~) |
121 | continue | 121 | continue |
122 | ;;*.control) | 122 | ;;*.control) |
123 | continue | 123 | continue |
124 | ;; $QTDIR/*) | 124 | ;; $QTDIR/*) |
125 | BASE=$(dirname /opt/QtPalmtop/${ff#$QTDIR/}) | 125 | BASE=$(dirname /opt/QtPalmtop/${ff#$QTDIR/}) |
126 | ;; etc/*.d/*) | 126 | ;; etc/*.d/*) |
127 | BASE=$(dirname /$ff) | 127 | BASE=$(dirname /$ff) |
128 | ;; root/*) | 128 | ;; root/*) |
129 | BASE=$(dirname ${ff#root}) | 129 | BASE=$(dirname ${ff#root}) |
130 | ;; lib/*) | 130 | ;; lib/*) |
131 | BASE=$(dirname /opt/QtPalmtop/$ff) | 131 | BASE=$(dirname /opt/QtPalmtop/$ff) |
132 | ;; $OPIEDIR/lib/*) | 132 | ;; $OPIEDIR/lib/*) |
133 | BASE=$(dirname /opt/QtPalmtop/${ff#$OPIEDIR/}) | 133 | BASE=$(dirname /opt/QtPalmtop/${ff#$OPIEDIR/}) |
134 | ;; *) | 134 | ;; *) |
135 | # For SHARP ROM compatibility. Should change to Qtopia. | 135 | # For SHARP ROM compatibility. Should change to Qtopia. |
136 | BASE=/opt/QtPalmtop/$(dirname $ff) | 136 | BASE=/opt/QtPalmtop/$(dirname $ff) |
137 | esac | 137 | esac |
138 | 138 | ||
139 | if [ -f $ff -o -b $ff -o -c $ff ] | 139 | if [ -f $ff -o -b $ff -o -c $ff ] |
140 | then | 140 | then |
141 | D=$DATADIR$BASE | 141 | D=$DATADIR$BASE |
142 | if [ -x $ff -a -n "$STRIP" ] | 142 | if [ -x $ff -a -n "$STRIP" ] |
143 | then | 143 | then |
144 | case $(file $ff) in | 144 | case $(file $ff) in |
145 | $STRIP_FILES) | 145 | $STRIP_FILES) |
146 | $STRIP $ff | 146 | $STRIP $ff |
147 | ;; *) | 147 | ;; *) |
148 | esac | 148 | esac |
149 | fi | 149 | fi |
150 | if [ -n "$RPM" ] | 150 | if [ -n "$RPM" ] |
151 | then | 151 | then |
152 | case "$ff" in | 152 | case "$ff" in |
153 | /*) RPMFILES="$RPMFILES $ff" | 153 | /*) RPMFILES="$RPMFILES $ff" |
154 | ;; *) RPMFILES="$RPMFILES $OPIEDIR/$ff" | 154 | ;; *) RPMFILES="$RPMFILES $OPIEDIR/$ff" |
155 | esac | 155 | esac |
156 | else | 156 | else |
157 | mkdir -p $D | 157 | mkdir -p $D |
158 | if cp -a $ff $D | 158 | if cp -a $ff $D |
159 | then | 159 | then |
160 | true | 160 | true |
161 | else | 161 | else |
162 | ERROR=1 | 162 | ERROR=1 |
163 | fi | 163 | fi |
164 | fi | 164 | fi |
165 | else | 165 | else |
166 | echo >&2 "$0: $i: No such file: $ff" | 166 | echo >&2 "$0: $i: No such file: $ff" |
167 | ERROR=1 | 167 | ERROR=1 |
168 | fi | 168 | fi |
169 | done | 169 | done |
170 | done | 170 | done |
171 | fi | 171 | fi |
172 | if [ -z "$ERROR" ] | 172 | if [ -z "$ERROR" ] |
173 | then | 173 | then |
174 | if [ -n "$RPM" ] | 174 | if [ -n "$RPM" ] |
175 | then | 175 | then |
176 | SPEC=/tmp/mkipks-rpm-$$.spec | 176 | SPEC=/tmp/mkipks-rpm-$$.spec |
177 | echo >$SPEC "Summary: $summary" | 177 | echo >$SPEC "Summary: $summary" |
178 | echo >>$SPEC "Name: $packagename" | 178 | echo >>$SPEC "Name: $packagename" |
179 | echo >>$SPEC "Group: $section" ########## | 179 | echo >>$SPEC "Group: $section" ########## |
180 | echo >>$SPEC "License: $license" | 180 | echo >>$SPEC "License: $license" |
181 | echo >>$SPEC "Version: ${version%-*}" | 181 | echo >>$SPEC "Version: ${version%-*}" |
182 | echo >>$SPEC "Release: ${version#*-}" | 182 | echo >>$SPEC "Release: ${version#*-}" |
183 | 183 | ||
184 | echo >>$SPEC "%description" | 184 | echo >>$SPEC "%description" |
185 | sed -n -e '/^Description:/,$ p' $i | tail +2 >>$SPEC | 185 | sed -n -e '/^Description:/,$ p' $i | tail +2 >>$SPEC |
186 | echo >>$SPEC "%files" | 186 | echo >>$SPEC "%files" |
187 | echo >>$SPEC "%defattr(-,root,root)" | 187 | echo >>$SPEC "%defattr(-,root,root)" |
188 | /bin/ls $RPMFILES >>$SPEC | 188 | /bin/ls $RPMFILES >>$SPEC |
189 | rpm -bb --target $ARCH-unknown-linux $SPEC | 189 | rpm -bb --target $ARCH-unknown-linux $SPEC |
190 | # rm $SPEC | 190 | # rm $SPEC |
191 | elif [ -z "$IMAGEDIR" ] | 191 | elif [ -z "$IMAGEDIR" ] |
192 | then | 192 | then |
193 | #size=$(du -h -s $DATADIR | sed -e 's/[ ].*//') | 193 | #size=$(du -h -s $DATADIR | sed -e 's/[ ].*//') |
194 | if (which mkfs.jffs2 >/dev/null 2>&1); then | 194 | if (which mkfs.jffs2 >/dev/null 2>&1); then |
195 | size=$(mkfs.jffs2 -r $DATADIR | wc -c) | 195 | size=$(mkfs.jffs2 -r $DATADIR | wc -c) |
196 | fi | 196 | fi |
197 | echo "Package: $packagename" >$CTRLDIR/control | 197 | echo "Package: $packagename" >$CTRLDIR/control |
198 | if [ ! -z "$size" ]; then | 198 | if [ ! -z "$size" ]; then |
199 | echo "Installed-Size: $size" >>$CTRLDIR/control | 199 | echo "Installed-Size: $size" >>$CTRLDIR/control |
200 | else | 200 | else |
201 | if [ -z "$SIZEWARNED" ] | 201 | if [ -z "$SIZEWARNED" ] |
202 | then | 202 | then |
203 | echo "Warning, no mkfs.jffs2 found, unable to set Installed-Size." | 203 | echo "Warning, no mkfs.jffs2 found, unable to set Installed-Size." |
204 | SIZEWARNED=1 | 204 | SIZEWARNED=1 |
205 | fi | 205 | fi |
206 | fi | 206 | fi |
207 | echo "Architecture: $ARCH" >>$CTRLDIR/control | 207 | echo "Architecture: $ARCH" >>$CTRLDIR/control |
208 | echo "Filename: ./$package.ipk" >>$CTRLDIR/control | 208 | echo "Filename: ./$package.ipk" >>$CTRLDIR/control |
209 | echo "Version: $version" >>$CTRLDIR/control | 209 | echo "Version: $version" >>$CTRLDIR/control |
210 | [ ! -z "$depends" ] && echo "Depends: $depends" >>$CTRLDIR/control | 210 | [ ! -z "$depends" ] && echo "Depends: $depends" >>$CTRLDIR/control |
211 | [ ! -z "$provides" ] && echo "Provides: $provides" >>$CTRLDIR/control | 211 | [ ! -z "$provides" ] && echo "Provides: $provides" >>$CTRLDIR/control |
212 | [ ! -z "$conflicts" ] && echo "Conflicts: $conflicts" >>$CTRLDIR/control | 212 | [ ! -z "$conflicts" ] && echo "Conflicts: $conflicts" >>$CTRLDIR/control |
213 | egrep -v "^(Files|Version|Depends|Provides|Conflicts|Architecture):" >>$CTRLDIR/control $i | 213 | egrep -v "^(Files|Version|Depends|Provides|Conflicts|Architecture):" >>$CTRLDIR/control $i |
214 | [ -n "$classicopts" ] && echo "$DEB_VERSION" >$TDIR/debian-binary | 214 | [ -n "$classicopts" ] && echo "$DEB_VERSION" >$TDIR/debian-binary |
215 | base=${i%.control} | 215 | base=${i%.control} |
216 | scripts="preinst postinst prerm postrm" | 216 | scripts="preinst postinst prerm postrm" |
217 | for pf in $scripts | 217 | for pf in $scripts |
218 | do | 218 | do |
219 | if [ -x ${base}.$pf ] | 219 | if [ -e ${base}.$pf ] |
220 | then | 220 | then |
221 | cp ${base}.$pf $CTRLDIR/$pf | 221 | cp ${base}.$pf $CTRLDIR/$pf |
222 | chmod 755 $CTRLDIR/$pf | ||
222 | fi | 223 | fi |
223 | done | 224 | done |
224 | cd $ORIGDIR; $OPIEDIR/scripts/ipkg-build $classicopts -o root -g root $TDIR; cd $OPIEDIR; | 225 | cd $ORIGDIR; $OPIEDIR/scripts/ipkg-build $classicopts -o root -g root $TDIR; cd $OPIEDIR; |
225 | RESULT=$package.ipk | 226 | RESULT=$package.ipk |
226 | if [ -n "$VERB" ] | 227 | if [ -n "$VERB" ] |
227 | then | 228 | then |
228 | echo >&2 "Built $RESULT ($size)" | 229 | echo >&2 "Built $RESULT ($size)" |
229 | fi | 230 | fi |
230 | if [ -n "$LIST" ] | 231 | if [ -n "$LIST" ] |
231 | then | 232 | then |
232 | echo $RESULT | 233 | echo $RESULT |
233 | fi | 234 | fi |
234 | fi | 235 | fi |
235 | else | 236 | else |
236 | echo >&2 "Not building $package package" | 237 | echo >&2 "Not building $package package" |
237 | fi | 238 | fi |
238 | done | 239 | done |
239 | # clean up | 240 | # clean up |
240 | rm -rf $TDIR | 241 | rm -rf $TDIR |