summaryrefslogtreecommitdiff
authorkergoth <kergoth>2003-04-15 03:12:31 (UTC)
committer kergoth <kergoth>2003-04-15 03:12:31 (UTC)
commit7d32077ab9c4e33fb82390cd5279f049000a0e0c (patch) (unidiff)
treecd0f88932101eca6dbcd0f9cf6ff659840738e13
parent35edf52692c9f5e68b07072dd79b857d16d79559 (diff)
downloadopie-7d32077ab9c4e33fb82390cd5279f049000a0e0c.zip
opie-7d32077ab9c4e33fb82390cd5279f049000a0e0c.tar.gz
opie-7d32077ab9c4e33fb82390cd5279f049000a0e0c.tar.bz2
Ipkg-build that strips out epoch from package version when naming
the file.
Diffstat (more/less context) (ignore whitespace changes)
-rwxr-xr-xscripts/ipkg-build18
1 files changed, 10 insertions, 8 deletions
diff --git a/scripts/ipkg-build b/scripts/ipkg-build
index 0533048..c6af056 100755
--- a/scripts/ipkg-build
+++ b/scripts/ipkg-build
@@ -43,33 +43,33 @@ You probably want to remove them: " >&2
43 echo "*** Warning: The following files have a UID greater than 99. 43 echo "*** Warning: The following files have a UID greater than 99.
44You probably want to chown these to a system user: " >&2 44You probably want to chown these to a system user: " >&2
45 ls -ld $large_uid_files 45 ls -ld $large_uid_files
46 echo >&2 46 echo >&2
47 fi 47 fi
48 48
49 49
50 if [ ! -f "$CONTROL/control" ]; then 50 if [ ! -f "$CONTROL/control" ]; then
51 echo "*** Error: Control file $pkg_dir/$CONTROL/control not found." >&2 51 echo "*** Error: Control file $pkg_dir/$CONTROL/control not found." >&2
52 cd $owd 52 cd $owd
53 return 1 53 return 1
54 fi 54 fi
55 55
56 pkg=`required_field Package` 56 pkg=`required_field Package`
57 [ "$?" -ne 0 ] && PKG_ERROR=1 57 [ "$?" -ne 0 ] && PKG_ERROR=1
58 58
59 version=`required_field Version | sed 's/.*://;'` 59 version=`required_field Version | sed 's/Version://; s/^.://g;'`
60 [ "$?" -ne 0 ] && PKG_ERROR=1 60 [ "$?" -ne 0 ] && PKG_ERROR=1
61 61
62 arch=`required_field Architecture` 62 arch=`required_field Architecture`
63 [ "$?" -ne 0 ] && PKG_ERROR=1 63 [ "$?" -ne 0 ] && PKG_ERROR=1
64 64
65 required_field Maintainer >/dev/null 65 required_field Maintainer >/dev/null
66 [ "$?" -ne 0 ] && PKG_ERROR=1 66 [ "$?" -ne 0 ] && PKG_ERROR=1
67 67
68 required_field Description >/dev/null 68 required_field Description >/dev/null
69 [ "$?" -ne 0 ] && PKG_ERROR=1 69 [ "$?" -ne 0 ] && PKG_ERROR=1
70 70
71 section=`required_field Section` 71 section=`required_field Section`
72 [ "$?" -ne 0 ] && PKG_ERROR=1 72 [ "$?" -ne 0 ] && PKG_ERROR=1
73 if [ -z "$section" ]; then 73 if [ -z "$section" ]; then
74 echo "The Section field should have one of the following values:" >&2 74 echo "The Section field should have one of the following values:" >&2
75 echo "admin, base, comm, editors, extras, games, graphics, kernel, libs, misc, net, text, web, x11" >&2 75 echo "admin, base, comm, editors, extras, games, graphics, kernel, libs, misc, net, text, web, x11" >&2
@@ -108,43 +108,44 @@ You probably want to chown these to a system user: " >&2
108 for cf in `cat $CONTROL/conffiles`; do 108 for cf in `cat $CONTROL/conffiles`; do
109 if [ ! -f ./$cf ]; then 109 if [ ! -f ./$cf ]; then
110 echo "*** Error: $CONTROL/conffiles mentions conffile $cf which does not exist" >&2 110 echo "*** Error: $CONTROL/conffiles mentions conffile $cf which does not exist" >&2
111 PKG_ERROR=1 111 PKG_ERROR=1
112 fi 112 fi
113 done 113 done
114 fi 114 fi
115 115
116 cd $owd 116 cd $owd
117 return $PKG_ERROR 117 return $PKG_ERROR
118} 118}
119 119
120### 120###
121# ipkg-build "main" 121# ipkg-build "main"
122### 122###
123ogargs="" 123ogargs=""
124usage="Usage: $0 [-o owner] [-g group] [-c] <pkg_directory> [<destination_directory>]" 124outer=ar
125while getopts ":o:g:c" opt; do 125usage="Usage: $0 [-c] [-o owner] [-g group] <pkg_directory> [<destination_directory>]"
126while getopts "cg:o:" opt; do
126 case $opt in 127 case $opt in
127 o ) owner=$OPTARG 128 o ) owner=$OPTARG
128 ogargs="--owner=$owner" 129 ogargs="--owner=$owner"
129 ;; 130 ;;
130 g ) group=$OPTARG 131 g ) group=$OPTARG
131 ogargs="$ogargs --group=$group" 132 ogargs="$ogargs --group=$group"
132 ;; 133 ;;
133 c ) classic=1 134 c ) outer=tar
134 ;; 135 ;;
135 \? ) echo $usage >&2 136 \? ) echo $usage >&2
136 esac 137 esac
137done 138done
138 139
139 140
140shift $(($OPTIND - 1)) 141shift $(($OPTIND - 1))
141 142
142# continue on to process additional arguments 143# continue on to process additional arguments
143 144
144case $# in 145case $# in
1451) 1461)
146 dest_dir=. 147 dest_dir=.
147 ;; 148 ;;
1482) 1492)
149 dest_dir=$2 150 dest_dir=$2
150 ;; 151 ;;
@@ -173,27 +174,28 @@ fi
173if ! pkg_appears_sane $pkg_dir; then 174if ! pkg_appears_sane $pkg_dir; then
174 echo >&2 175 echo >&2
175 echo "ipkg-build: Please fix the above errors and try again." >&2 176 echo "ipkg-build: Please fix the above errors and try again." >&2
176 exit 1 177 exit 1
177fi 178fi
178 179
179tmp_dir=$dest_dir/IPKG_BUILD.$$ 180tmp_dir=$dest_dir/IPKG_BUILD.$$
180mkdir $tmp_dir 181mkdir $tmp_dir
181 182
182tar $ogargs -C $pkg_dir -czf $tmp_dir/data.tar.gz . --exclude=$CONTROL 183tar $ogargs -C $pkg_dir -czf $tmp_dir/data.tar.gz . --exclude=$CONTROL
183tar $ogargs -C $pkg_dir/$CONTROL -czf $tmp_dir/control.tar.gz . 184tar $ogargs -C $pkg_dir/$CONTROL -czf $tmp_dir/control.tar.gz .
184 185
185echo "2.0" > $tmp_dir/debian-binary 186echo "2.0" > $tmp_dir/debian-binary
186 187
187pkg_file=$dest_dir/${pkg}_${version}_${arch}.ipk 188pkg_file=$dest_dir/${pkg}_${version}_${arch}.ipk
188here_dir=$PWD 189here_dir=$PWD
190## tar -C $tmp_dir -czf $pkg_file ./debian-binary ./data.tar.gz ./control.tar.gz
189rm -f $pkg_file 191rm -f $pkg_file
190if [ -n "$classic" ]; then 192if [ "$outer" = "ar" ] ; then
191 tar -C $tmp_dir -czf $pkg_file ./debian-binary ./data.tar.gz ./control.tar.gz 193 cd $tmp_dir ; ar crf $here_dir/$pkg_file ./debian-binary ./data.tar.gz ./control.tar.gz
192else 194else
193 cd $tmp_dir ; ar crf $here_dir/$pkg_file ./debian-binary ./data.tar.gz ./control.tar.gz 195 cd $tmp_dir ; tar -zcf $here_dir/$pkg_file ./debian-binary ./data.tar.gz ./control.tar.gz
194fi 196fi
195cd $here_dir 197cd $here_dir
196rm $tmp_dir/debian-binary $tmp_dir/data.tar.gz $tmp_dir/control.tar.gz 198rm $tmp_dir/debian-binary $tmp_dir/data.tar.gz $tmp_dir/control.tar.gz
197rmdir $tmp_dir 199rmdir $tmp_dir
198 200
199echo "Packaged contents of $pkg_dir into $pkg_file" 201echo "Packaged contents of $pkg_dir into $pkg_file"