summaryrefslogtreecommitdiff
authorkergoth <kergoth>2003-04-23 20:52:52 (UTC)
committer kergoth <kergoth>2003-04-23 20:52:52 (UTC)
commite3428ff385782fd0d61acb0d08b147f0f0d430a7 (patch) (unidiff)
tree489e56df65a0a7717a8a45905520aa90f0c619a7
parentef6d0c5cb053d2140ffbcf54930dcfddd6341acd (diff)
downloadopie-e3428ff385782fd0d61acb0d08b147f0f0d430a7.zip
opie-e3428ff385782fd0d61acb0d08b147f0f0d430a7.tar.gz
opie-e3428ff385782fd0d61acb0d08b147f0f0d430a7.tar.bz2
Handle OPIEDIR/root/* in Files
Diffstat (more/less context) (ignore whitespace changes)
-rwxr-xr-xmkipks2
1 files changed, 2 insertions, 0 deletions
diff --git a/mkipks b/mkipks
index ec39dcb..73bff3c 100755
--- a/mkipks
+++ b/mkipks
@@ -55,192 +55,194 @@ RPM=
55 55
56while [ $# -ne 0 ] 56while [ $# -ne 0 ]
57do 57do
58 case "$1" in 58 case "$1" in
59 -v) 59 -v)
60 VERB=1 60 VERB=1
61 echo >&2 "Packaging for version $VERSION_MAJ.$VERSION_MIN.$VERSION_PAT$VERSION_CVS" 61 echo >&2 "Packaging for version $VERSION_MAJ.$VERSION_MIN.$VERSION_PAT$VERSION_CVS"
62 ;; -l) 62 ;; -l)
63 LIST=1 63 LIST=1
64 ;; -i) 64 ;; -i)
65 shift 65 shift
66 IMAGEDIR=$1 66 IMAGEDIR=$1
67 DATADIR=$IMAGEDIR 67 DATADIR=$IMAGEDIR
68 mkdir -p $IMAGEDIR 68 mkdir -p $IMAGEDIR
69 ;; -classic) 69 ;; -classic)
70 classicopts=-c 70 classicopts=-c
71 ;; -rpm) 71 ;; -rpm)
72 if [ "$OPIEDIR" != "/opt/Qtopia" ] 72 if [ "$OPIEDIR" != "/opt/Qtopia" ]
73 then 73 then
74 echo >&2 '$OPIEDIR is not the standard /usr/Qtopia directory.' 74 echo >&2 '$OPIEDIR is not the standard /usr/Qtopia directory.'
75 sleep 1 75 sleep 1
76 #exit 1 76 #exit 1
77 fi 77 fi
78 RPM=1 78 RPM=1
79 ;; -arch) 79 ;; -arch)
80 shift 80 shift
81 ARCH=$1 81 ARCH=$1
82 STRIP= 82 STRIP=
83 STRIP_FILES= 83 STRIP_FILES=
84 ;; /*) 84 ;; /*)
85 FILES="$FILES $1" 85 FILES="$FILES $1"
86 ;; *) 86 ;; *)
87 FILES="$FILES $PWD/$1" 87 FILES="$FILES $PWD/$1"
88 esac 88 esac
89 shift 89 shift
90done 90done
91 91
92if [ -z "$FILES" ] 92if [ -z "$FILES" ]
93then 93then
94 FILES=`find $OPIEDIR -name "*.control" -print` 94 FILES=`find $OPIEDIR -name "*.control" -print`
95fi 95fi
96 96
97RDIR=$PWD 97RDIR=$PWD
98ORIGDIR=`pwd` 98ORIGDIR=`pwd`
99cd $OPIEDIR 99cd $OPIEDIR
100 100
101for i in $FILES 101for i in $FILES
102do 102do
103 rm -rf $TDIR 103 rm -rf $TDIR
104 104
105 mkdir -p $DATADIR 105 mkdir -p $DATADIR
106 mkdir -p $CTRLDIR 106 mkdir -p $CTRLDIR
107 107
108 packagename=${i##*/}; packagename=${packagename%.control} 108 packagename=${i##*/}; packagename=${packagename%.control}
109 version=$(eval echo '"'$(sed -n -e "s/^Version: *//p" $i)'"') 109 version=$(eval echo '"'$(sed -n -e "s/^Version: *//p" $i)'"')
110 depends=$(eval echo '"'$(sed -n -e "s/^Depends: *//p" $i)'"') 110 depends=$(eval echo '"'$(sed -n -e "s/^Depends: *//p" $i)'"')
111 files=$(eval echo $(sed -n -e "s/^Files://p" $i)) 111 files=$(eval echo $(sed -n -e "s/^Files://p" $i))
112 arch=$(eval echo $(sed -n -e "s/^Arch://p" $i)) 112 arch=$(eval echo $(sed -n -e "s/^Arch://p" $i))
113 section=$(sed -n -e "s/^Section: *//p" $i) 113 section=$(sed -n -e "s/^Section: *//p" $i)
114 provides=$(sed -n -e "s/^Provides: *//p" $i) 114 provides=$(sed -n -e "s/^Provides: *//p" $i)
115 conflicts=$(sed -n -e "s/^Conflicts: *//p" $i) 115 conflicts=$(sed -n -e "s/^Conflicts: *//p" $i)
116 license=$(sed -n -e "s/^License: *//p" $i) 116 license=$(sed -n -e "s/^License: *//p" $i)
117 summary=$(sed -n -e "s/^Description: *//p" $i) 117 summary=$(sed -n -e "s/^Description: *//p" $i)
118 package=${packagename}_${version}_$ARCH 118 package=${packagename}_${version}_$ARCH
119 ERROR= 119 ERROR=
120 if [ -z "$files" ] 120 if [ -z "$files" ]
121 then 121 then
122 mkdir -p $DATADIR/usr/share/doc/$packagename 122 mkdir -p $DATADIR/usr/share/doc/$packagename
123 else 123 else
124 for f in $files 124 for f in $files
125 do 125 do
126 if [ -d $f ] 126 if [ -d $f ]
127 then 127 then
128 ffiles=$(find $f -type f -o -type b -o -type c -o -type l) 128 ffiles=$(find $f -type f -o -type b -o -type c -o -type l)
129 else 129 else
130 ffiles=$f 130 ffiles=$f
131 fi 131 fi
132 for ff in $ffiles 132 for ff in $ffiles
133 do 133 do
134 case $ff in 134 case $ff in
135 */CVS/*) 135 */CVS/*)
136 continue 136 continue
137 ;;*~) 137 ;;*~)
138 continue 138 continue
139 ;;*.control) 139 ;;*.control)
140 continue 140 continue
141 ;; $QTDIR/*) 141 ;; $QTDIR/*)
142 BASE=$(dirname /opt/QtPalmtop/${ff#$QTDIR/}) 142 BASE=$(dirname /opt/QtPalmtop/${ff#$QTDIR/})
143 ;; etc/*.d/*) 143 ;; etc/*.d/*)
144 BASE=$(dirname /$ff) 144 BASE=$(dirname /$ff)
145 ;; root/*) 145 ;; root/*)
146 BASE=$(dirname ${ff#root}) 146 BASE=$(dirname ${ff#root})
147 ;; lib/*) 147 ;; lib/*)
148 BASE=$(dirname /opt/QtPalmtop/$ff) 148 BASE=$(dirname /opt/QtPalmtop/$ff)
149 ;; $OPIEDIR/lib/*) 149 ;; $OPIEDIR/lib/*)
150 BASE=$(dirname /opt/QtPalmtop/${ff#$OPIEDIR/}) 150 BASE=$(dirname /opt/QtPalmtop/${ff#$OPIEDIR/})
151 ;; $OPIEDIR/root/*)
152 BASE=$(dirname /${ff#$OPIEDIR/root/})
151 ;; *) 153 ;; *)
152 # For SHARP ROM compatibility. Should change to Qtopia. 154 # For SHARP ROM compatibility. Should change to Qtopia.
153 BASE=/opt/QtPalmtop/$(dirname $ff) 155 BASE=/opt/QtPalmtop/$(dirname $ff)
154 esac 156 esac
155 157
156 if [ -f $ff -o -b $ff -o -c $ff ] 158 if [ -f $ff -o -b $ff -o -c $ff ]
157 then 159 then
158 D=$DATADIR$BASE 160 D=$DATADIR$BASE
159 if [ -x $ff -a -n "$STRIP" ] 161 if [ -x $ff -a -n "$STRIP" ]
160 then 162 then
161 case $(file $ff) in 163 case $(file $ff) in
162 $STRIP_FILES) 164 $STRIP_FILES)
163 $STRIP $ff 165 $STRIP $ff
164 ;; *) 166 ;; *)
165 esac 167 esac
166 fi 168 fi
167 if [ -n "$RPM" ] 169 if [ -n "$RPM" ]
168 then 170 then
169 case "$ff" in 171 case "$ff" in
170 /*) RPMFILES="$RPMFILES $ff" 172 /*) RPMFILES="$RPMFILES $ff"
171 ;; *) RPMFILES="$RPMFILES $OPIEDIR/$ff" 173 ;; *) RPMFILES="$RPMFILES $OPIEDIR/$ff"
172 esac 174 esac
173 else 175 else
174 mkdir -p $D 176 mkdir -p $D
175 if cp -a $ff $D 177 if cp -a $ff $D
176 then 178 then
177 true 179 true
178 else 180 else
179 ERROR=1 181 ERROR=1
180 fi 182 fi
181 fi 183 fi
182 else 184 else
183 echo >&2 "$0: $i: No such file: $ff" 185 echo >&2 "$0: $i: No such file: $ff"
184 ERROR=1 186 ERROR=1
185 fi 187 fi
186 done 188 done
187 done 189 done
188 fi 190 fi
189 if [ -z "$ERROR" ] 191 if [ -z "$ERROR" ]
190 then 192 then
191 if [ -n "$RPM" ] 193 if [ -n "$RPM" ]
192 then 194 then
193 SPEC=/tmp/mkipks-rpm-$$.spec 195 SPEC=/tmp/mkipks-rpm-$$.spec
194 echo >$SPEC "Summary: $summary" 196 echo >$SPEC "Summary: $summary"
195 echo >>$SPEC "Name: $packagename" 197 echo >>$SPEC "Name: $packagename"
196 echo >>$SPEC "Group: $section" ########## 198 echo >>$SPEC "Group: $section" ##########
197 echo >>$SPEC "License: $license" 199 echo >>$SPEC "License: $license"
198 echo >>$SPEC "Version: ${version%-*}" 200 echo >>$SPEC "Version: ${version%-*}"
199 echo >>$SPEC "Release: ${version#*-}" 201 echo >>$SPEC "Release: ${version#*-}"
200 202
201 echo >>$SPEC "%description" 203 echo >>$SPEC "%description"
202 sed -n -e '/^Description:/,$ p' $i | tail +2 >>$SPEC 204 sed -n -e '/^Description:/,$ p' $i | tail +2 >>$SPEC
203 echo >>$SPEC "%files" 205 echo >>$SPEC "%files"
204 echo >>$SPEC "%defattr(-,root,root)" 206 echo >>$SPEC "%defattr(-,root,root)"
205 /bin/ls $RPMFILES >>$SPEC 207 /bin/ls $RPMFILES >>$SPEC
206 rpm -bb --target $ARCH-unknown-linux $SPEC 208 rpm -bb --target $ARCH-unknown-linux $SPEC
207 # rm $SPEC 209 # rm $SPEC
208 elif [ -z "$IMAGEDIR" ] 210 elif [ -z "$IMAGEDIR" ]
209 then 211 then
210 #size=$(du -h -s $DATADIR | sed -e 's/[ ].*//') 212 #size=$(du -h -s $DATADIR | sed -e 's/[ ].*//')
211 if (which mkfs.jffs2 >/dev/null 2>&1); then 213 if (which mkfs.jffs2 >/dev/null 2>&1); then
212 size=$(mkfs.jffs2 -r $DATADIR | wc -c) 214 size=$(mkfs.jffs2 -r $DATADIR | wc -c)
213 fi 215 fi
214 if ! (cat $i|grep -q ^Package); then 216 if ! (cat $i|grep -q ^Package); then
215 echo "Package: $packagename" >$CTRLDIR/control 217 echo "Package: $packagename" >$CTRLDIR/control
216 fi 218 fi
217 if [ ! -z "$size" ]; then 219 if [ ! -z "$size" ]; then
218 echo "Installed-Size: $size" >>$CTRLDIR/control 220 echo "Installed-Size: $size" >>$CTRLDIR/control
219 else 221 else
220 if [ -z "$SIZEWARNED" ] 222 if [ -z "$SIZEWARNED" ]
221 then 223 then
222 echo "Warning, no mkfs.jffs2 found, unable to set Installed-Size." 224 echo "Warning, no mkfs.jffs2 found, unable to set Installed-Size."
223 SIZEWARNED=1 225 SIZEWARNED=1
224 fi 226 fi
225 fi 227 fi
226 echo "Architecture: $ARCH" >>$CTRLDIR/control 228 echo "Architecture: $ARCH" >>$CTRLDIR/control
227 echo "Version: $version" >>$CTRLDIR/control 229 echo "Version: $version" >>$CTRLDIR/control
228 [ ! -z "$depends" ] && echo "Depends: $depends" >>$CTRLDIR/control 230 [ ! -z "$depends" ] && echo "Depends: $depends" >>$CTRLDIR/control
229 [ ! -z "$provides" ] && echo "Provides: $provides" >>$CTRLDIR/control 231 [ ! -z "$provides" ] && echo "Provides: $provides" >>$CTRLDIR/control
230 [ ! -z "$conflicts" ] && echo "Conflicts: $conflicts" >>$CTRLDIR/control 232 [ ! -z "$conflicts" ] && echo "Conflicts: $conflicts" >>$CTRLDIR/control
231 egrep -v "^(Files|Version|Depends|Provides|Conflicts|Architecture):" >>$CTRLDIR/control $i 233 egrep -v "^(Files|Version|Depends|Provides|Conflicts|Architecture):" >>$CTRLDIR/control $i
232 [ -n "$classicopts" ] && echo "$DEB_VERSION" >$TDIR/debian-binary 234 [ -n "$classicopts" ] && echo "$DEB_VERSION" >$TDIR/debian-binary
233 base=${i%.control} 235 base=${i%.control}
234 scripts="preinst postinst prerm postrm" 236 scripts="preinst postinst prerm postrm"
235 for pf in $scripts 237 for pf in $scripts
236 do 238 do
237 if [ -e ${base}.$pf ] 239 if [ -e ${base}.$pf ]
238 then 240 then
239 cp ${base}.$pf $CTRLDIR/$pf 241 cp ${base}.$pf $CTRLDIR/$pf
240 chmod 755 $CTRLDIR/$pf 242 chmod 755 $CTRLDIR/$pf
241 fi 243 fi
242 done 244 done
243 cd $ORIGDIR; $OPIEDIR/scripts/ipkg-build $classicopts -o root -g root $TDIR; cd $OPIEDIR; 245 cd $ORIGDIR; $OPIEDIR/scripts/ipkg-build $classicopts -o root -g root $TDIR; cd $OPIEDIR;
244 RESULT=$package.ipk 246 RESULT=$package.ipk
245 if [ -n "$VERB" ] 247 if [ -n "$VERB" ]
246 then 248 then