rev |
line source |
al@844
|
1 #!/bin/sh
|
al@844
|
2 # TazPkg - Tiny autonomous zone packages manager, hg.slitaz.org/tazpkg
|
al@844
|
3 # get - TazPkg module
|
al@844
|
4 # Get package to the cache directory
|
al@844
|
5
|
al@844
|
6
|
al@844
|
7 # 1. "Plain packages" - compiled and packed on cook.slitaz.org using receipts.
|
al@844
|
8 #
|
al@844
|
9 # Recently added other type of packages: packages that can't be compiled due to the closed sources
|
al@844
|
10 # or due to the giant size of that sources. In this case special script: a) downloads package
|
al@844
|
11 # compiled for other Linux from official web site, b) converts this package to the TazPkg format,
|
al@844
|
12 # c) installs this package as "plain" package.
|
al@844
|
13 #
|
al@844
|
14 # 2. "Get-packages" - package contains only one special script for downloading/converting.
|
al@844
|
15 # Sometimes get-package can get some specified version of the package, sometimes - different
|
al@844
|
16 # (latest) version.
|
al@844
|
17 #
|
al@844
|
18 # Packages 1. and 2. can be found in the wok repository: http://hg.slitaz.org/wok/
|
al@844
|
19 #
|
al@844
|
20 # 3. "Extra" get-scripts. Next addition - only script, without packaging.
|
al@844
|
21 # Extra get-scripts repository: http://hg.slitaz.org/get-scripts/
|
al@844
|
22 # Extra get-scripts mirror: http://mirror.slitaz.org/packages/get/
|
al@844
|
23 #
|
al@844
|
24 # 4. Converted "extra" packages. Next addition - some packages like LibreOffice / OpenOffice are
|
al@844
|
25 # big to compile them like _1. "Plain packages"_ as well as big to convert them on the user side
|
al@844
|
26 # (you need a lot of time, CPU, and RAM) and sometimes it is unable on the weak user machines.
|
al@844
|
27 # So, some selected and free packages are converted on the SliTaz server side, packaged and
|
al@844
|
28 # are ready to download by any user: http://mirror.slitaz.org/packages/extra/
|
al@844
|
29 #
|
al@844
|
30 #
|
al@844
|
31 # Algorithm to get package:
|
al@844
|
32 # - search package in question in the mirrored packages list, download if exists;
|
al@844
|
33 # - search "get-package" in the mirrored packages list, download if exists;
|
al@844
|
34 # - search package in the "extra" get-scripts list, download if exists and run it, get the package.
|
al@844
|
35 #
|
al@844
|
36 # Note, here doubling. Imagine, you may wanted "palemoon" package.
|
al@844
|
37 # 1. No "plain package";
|
al@844
|
38 # 2. Existing "get-palemoon" package;
|
al@844
|
39 # 3. Existing "palemoon" extra get-script;
|
al@844
|
40 # 4. Existing "palemoon" extra converted package.
|
al@844
|
41 # User will get 2. He can specify "--extra" option to get 3.
|
al@844
|
42 # FIXME: do something with doubling.
|
al@844
|
43
|
al@844
|
44
|
al@844
|
45
|
al@844
|
46
|
al@844
|
47 # Connect function libraries
|
al@844
|
48 . /lib/libtaz.sh
|
al@844
|
49 . /usr/lib/slitaz/libpkg.sh
|
al@844
|
50
|
al@844
|
51 # Get TazPkg working environment
|
al@844
|
52 . @@MODULES@@/getenv
|
al@844
|
53
|
al@844
|
54 . @@MODULES@@/find-depends
|
al@844
|
55
|
al@844
|
56
|
al@844
|
57
|
al@844
|
58
|
al@844
|
59 # Get cache directory path
|
al@844
|
60
|
al@844
|
61 get_cache_path() {
|
al@844
|
62 # input: $1 = DB folder such as "$PKGS_DB" or "$PKGS_DB/undigest/*"
|
al@844
|
63 # $2 (optional): 'extra' for cache for extra-package scripts
|
al@844
|
64 # output: path to cache directory
|
al@844
|
65
|
al@844
|
66 local cache_dir
|
al@844
|
67
|
pascal@972
|
68 if [ "$2" = 'extra' ]; then
|
al@844
|
69 cache_dir="$SAVE_CACHE_DIR/extra/packages"
|
pascal@972
|
70 elif [ "$1" = "$PKGS_DB" ]; then
|
al@844
|
71 # Main repository
|
al@844
|
72 cache_dir="$SAVE_CACHE_DIR/$SLITAZ_RELEASE/packages"
|
al@844
|
73 else
|
al@844
|
74 # Undigest repository
|
al@844
|
75 cache_dir="$SAVE_CACHE_DIR/${1##*/}/packages"
|
al@844
|
76 fi
|
al@844
|
77
|
al@844
|
78 # Make cache directory if absent
|
al@844
|
79 mkdir -p "$cache_dir"
|
al@844
|
80 chmod a+w "$cache_dir"
|
al@844
|
81
|
al@844
|
82 echo "$cache_dir"
|
al@844
|
83 }
|
al@844
|
84
|
al@844
|
85
|
al@844
|
86 # Download a file from mirror
|
al@844
|
87
|
al@844
|
88 download_from() {
|
al@844
|
89 # input: "<mirror_url>" "<package_name>-<version>.tazpkg"
|
al@844
|
90
|
al@844
|
91 debug "\ndownload_from('$1', '$2')"
|
al@844
|
92
|
al@844
|
93 case "$1" in
|
al@844
|
94 # Mirror URL can have a trailing slash or not.
|
al@844
|
95 http://* | https://* | ftp://*)
|
al@862
|
96 debug " wget -c -T 30 -U $UA ${1%/}/$2"
|
al@877
|
97 q=''; [ -n "$quiet" ] && q='-q'
|
al@864
|
98 # Display abridged wget status (skip info about connections)
|
al@937
|
99 wget -c $q -T 30 -U $UA ${1%/}/$2 2>&1 | awk '$0~"%"{printf "%s\r",$0}' >&2
|
al@844
|
100 ;;
|
al@844
|
101 *)
|
al@863
|
102 debug " cp ${1%/}/$2 ."
|
al@863
|
103 cp ${1%/}/$2 .;;
|
al@844
|
104 esac
|
al@844
|
105 }
|
al@844
|
106
|
al@844
|
107
|
al@844
|
108 # This function may be called by a get script.
|
al@844
|
109
|
al@844
|
110 abort_package() {
|
al@844
|
111 cd "$CUR_DIR"
|
al@844
|
112 rm -rf "$tmp_dir"
|
pascal@911
|
113 [ -n "$1" ] ||
|
pascal@911
|
114 set -- 'Could not download "%s" from "%s". Exiting.' "${TARBALL:-$PACKAGE}" "${WGET_URL:-$WEB_SITE}"
|
pascal@911
|
115 printf "$@"
|
al@844
|
116 exit 1
|
al@844
|
117 }
|
al@844
|
118
|
al@844
|
119
|
al@844
|
120 # Get extra-package file to the cache
|
al@844
|
121
|
al@844
|
122 get_pkg_extra() {
|
al@844
|
123 # input: $1 extra-package name (like 'dropbox')
|
al@844
|
124 # $2 (internal): empty or 'redo' (when recursive calling)
|
al@844
|
125 # action: download stuff and make package
|
al@844
|
126 # output: full path to created package
|
al@844
|
127
|
al@844
|
128 debug "\nget_pkg_extra('$1', '$2')"
|
al@844
|
129
|
al@844
|
130 local mirror extra_cache converted tmp_dir script
|
al@844
|
131
|
al@844
|
132 # Check extra.list
|
al@844
|
133 if [ ! -s "$PKGS_DB/extra.list" ]; then
|
al@844
|
134 # Empty extra.list
|
al@844
|
135 if [ "$2" != 'redo' ]; then
|
al@844
|
136 tazpkg recharge >&2
|
al@844
|
137 get_pkg_extra "$1" 'redo'; exit 0
|
al@844
|
138 else
|
al@844
|
139 # Give up
|
al@844
|
140 _ 'File "%s" empty.' 'extra.list' >&2
|
al@844
|
141 die 'Unable to find package "%s" in the extra packages list.' "$(boldify $1)"
|
al@844
|
142 fi
|
al@844
|
143 fi
|
al@844
|
144
|
al@844
|
145 # Extra.list exists and not empty
|
al@844
|
146 if ! grep -q "^$1|" "$PKGS_DB/extra.list"; then
|
al@844
|
147 die 'Unable to find package "%s" in the extra packages list.' "$(boldify $1)"
|
al@844
|
148 fi
|
al@844
|
149
|
al@844
|
150 # Extra-package found in extra.list
|
al@844
|
151
|
al@844
|
152 if [ -z "$nocache" ]; then
|
al@844
|
153 # Go to cache for "get-install" command; don't move for "get" command
|
al@844
|
154 extra_cache="$(get_cache_path "$PKGS_DB" 'extra')"
|
al@844
|
155 debug "cd '$extra_cache'"
|
al@844
|
156 cd "$extra_cache"
|
al@844
|
157
|
al@844
|
158 # Extra-cache should contain packages DB files (packages.info, etc.)
|
al@844
|
159 # to list extra-packages contained in the extra-cache
|
al@968
|
160 [ ! -e 'packages.info' -a ! -e "packages-$SLITAZ_ARCH.info" ] &&
|
al@968
|
161 tazpkg mkdb "$extra_cache" --root='' --forced >/dev/null
|
al@844
|
162
|
al@970
|
163 pi="packages-$SLITAZ_ARCH.info"
|
al@970
|
164 [ -e "$pi" ] || pi='packages.info'
|
al@968
|
165
|
al@968
|
166 if [ -e "$pi" ]; then
|
al@968
|
167 awk -F$'\t' -vp="$1" '$1==p{exit 1}' $pi
|
al@844
|
168 if [ "$?" -eq 1 ]; then
|
al@876
|
169 [ -z "$quiet" ] && _ 'Package "%s" already in the cache' "$1" >&2
|
al@844
|
170 echo -n "$(pwd)/"
|
al@968
|
171 awk -F$'\t' -vp="$1" '$1==p{printf "%s-%s.tazpkg\n", $1, $2; exit}' $pi
|
al@844
|
172 exit 0
|
al@844
|
173 fi
|
al@844
|
174 fi
|
al@844
|
175 fi
|
al@844
|
176
|
al@844
|
177 mirror="$(cat "$PKGS_DB/mirror")"
|
al@844
|
178 debug "mirror='$mirror'"
|
al@844
|
179
|
al@844
|
180
|
al@844
|
181 # Try converted extra-packages first
|
al@844
|
182 # FIXME: Workaround to get packages filenames (even better to have names and versions separate)
|
al@846
|
183 converted="$(wget -O - http://mirror1.slitaz.org/packages/extra/ 2>/dev/null | \
|
al@844
|
184 tr \'\" $'\n' | grep "$1-.*\.tazpkg$" | sort -u)"
|
al@844
|
185 debug "converted='$converted'"
|
al@844
|
186 if [ -n "$converted" ]; then
|
al@844
|
187 case "$mirror" in
|
al@844
|
188 http://*|https://*|ftp://*)
|
al@844
|
189 # Default 'http://mirror.slitaz.org/packages/cooking/'
|
al@844
|
190 # -> 'http://mirror.slitaz.org/packages/extra/'
|
al@862
|
191 debug "wget -T 30 -U '$UA' '${mirror%packages/*}packages/extra/$converted'"
|
al@877
|
192 q=''; [ -n "$quiet" ] && q='-q'
|
al@877
|
193 wget $q -T 30 -U "$UA" "${mirror%packages/*}packages/extra/$converted" \
|
al@938
|
194 2>&1 | awk '$0~"%"{printf "%s\r",$0}' >&2;;
|
al@844
|
195 esac
|
al@844
|
196 if [ -f "$converted" ]; then
|
al@844
|
197 echo "$extra_cache/$converted"; exit 0
|
al@844
|
198 fi
|
al@844
|
199 fi
|
al@844
|
200
|
al@844
|
201
|
al@844
|
202 # Fails to download converted extra-package; now try to download and execute get-script
|
al@844
|
203 cd ..
|
al@844
|
204 case "$mirror" in
|
al@844
|
205 http://*|https://*|ftp://*)
|
al@844
|
206 # Default 'http://mirror.slitaz.org/packages/cooking/'
|
al@844
|
207 # -> 'http://mirror.slitaz.org/packages/get/'
|
al@862
|
208 debug "wget -T 30 -U '$UA' '${mirror%packages/*}packages/get/$1'"
|
al@877
|
209 q=''; [ -n "$quiet" ] && q='-q'
|
al@877
|
210 wget $q -T 30 -U "$UA" "${mirror%packages/*}packages/get/$1" \
|
al@938
|
211 2>&1 | awk '$0~"%"{printf "%s\r",$0}' >&2;;
|
al@844
|
212 esac
|
al@844
|
213
|
al@844
|
214 if [ ! -f "$1" ]; then
|
al@844
|
215 # TODO: extra package or extra package script? :) Too complicated...
|
al@844
|
216 die 'Unable to download extra package "%s".' "$(boldify $1)"
|
al@844
|
217 fi
|
al@844
|
218
|
al@844
|
219 # Extra-package script downloaded in the /var/cache/tazpkg/extra/
|
al@844
|
220
|
al@844
|
221 unset_receipt
|
al@844
|
222 PACKAGE="$1"
|
al@844
|
223 script="$(realpath $1)"
|
al@844
|
224 tmp_dir="$(mktemp -d)"; cd "$tmp_dir"
|
al@844
|
225 # Run script
|
al@844
|
226 set -e
|
al@844
|
227 . "$script"
|
al@844
|
228 set +e
|
al@844
|
229
|
pascal@918
|
230 [ "$PWD" != "$tmp_dir" ] && mv $PACKAGE* $tmp_dir
|
pascal@918
|
231 cd $tmp_dir
|
pascal@918
|
232 [ -n "$VERSION" ] || VERSION="$(date +%Y%m%d)"
|
pascal@918
|
233 [ -d "$PACKAGE-$VERSION" ] || mv $PACKAGE $PACKAGE-$VERSION || abort_package
|
pascal@918
|
234 [ -n "$TARBALL" ] || TARBALL="$(basename $WGET_URL)"
|
al@844
|
235
|
al@844
|
236 if [ ! -s "$PACKAGE-$VERSION/receipt" ]; then
|
al@844
|
237 # Create receipt (if script not created it early) using variables from script
|
al@844
|
238 cat > "$PACKAGE-$VERSION/receipt" <<EOT
|
al@844
|
239 # SliTaz package receipt.
|
al@844
|
240
|
al@844
|
241 PACKAGE="$PACKAGE"
|
pascal@918
|
242 VERSION="$VERSION"
|
al@844
|
243 CATEGORY="${CATEGORY:-non-free}"
|
pascal@919
|
244 WEB_SITE="${WEB_SITE:-$WEBSITE}"
|
pascal@918
|
245 SHORT_DESC="${SHORT_DESC:-The $PACKAGE software package of SliTaz}"
|
al@844
|
246 MAINTAINER="${MAINTAINER:-nobody@slitaz.org}"
|
pascal@912
|
247 LICENSE="${LICENSE:-unknown}"
|
pascal@918
|
248 TARBALL="$TARBALL"
|
pascal@919
|
249 WGET_URL="${WGET_URL:-$WGETURL}"
|
al@844
|
250 CONFIG_FILES="$CONFIG_FILES"
|
al@844
|
251 SUGGESTED="$SUGGESTED"
|
al@844
|
252 PROVIDE="$PROVIDE"
|
al@844
|
253 DEPENDS="$DEPENDS"
|
al@844
|
254 HOST_ARCH="$HOST_ARCH"
|
al@844
|
255 TAGS="$TAGS"
|
al@844
|
256 EXTRA_SOURCE_FILES="$EXTRA_SOURCE_FILES"
|
al@844
|
257 EOT
|
al@844
|
258 fi
|
al@844
|
259
|
al@844
|
260 # Add dependencies which was found to already defined dependencies
|
al@950
|
261 DEPENDS="$(unset DEPENDS; . ./$PACKAGE-$VERSION/receipt; echo $DEPENDS)"
|
al@898
|
262 TMP_DIR="$tmp_dir"
|
al@844
|
263 for i in $(find_depends "$PACKAGE-$VERSION/fs"); do
|
al@844
|
264 case " $DEPENDS " in
|
al@844
|
265 *\ $i\ *) continue;;
|
al@844
|
266 esac
|
al@844
|
267 sed -i "s/^DEPENDS=\"/&$i /" "$PACKAGE-$VERSION/receipt"
|
al@844
|
268 done
|
al@844
|
269
|
al@844
|
270 # Remove empty variables
|
al@844
|
271 sed -i '/=""$/d' "$PACKAGE-$VERSION/receipt"
|
al@844
|
272
|
al@844
|
273 tazpkg pack "$PACKAGE-$VERSION" gzip >&2
|
al@844
|
274
|
al@844
|
275 if [ -z "nocache" ]; then
|
al@844
|
276 # move package to the extra-cache for "get-install" command
|
al@844
|
277 mv -f "$tmp_dir/$PACKAGE-$VERSION.tazpkg" "$extra_cache"
|
al@844
|
278 # Re-make extra packages database
|
al@844
|
279 tazpkg mkdb "$extra_cache" --root='' --forced >/dev/null
|
al@844
|
280 else
|
al@844
|
281 # move package to directory where "tazpkg get" command invoked
|
al@844
|
282 mv -f "$tmp_dir/$PACKAGE-$VERSION.tazpkg" "$CUR_DIR"
|
al@844
|
283 fi
|
al@844
|
284
|
al@844
|
285 # Clean
|
al@844
|
286 rm -rf "$tmp_dir"
|
al@844
|
287
|
al@844
|
288 # Function output: path to package
|
al@844
|
289 echo "$CUR_DIR/$PACKAGE-$VERSION.tazpkg"
|
al@844
|
290 }
|
al@844
|
291
|
al@844
|
292
|
pascal@873
|
293 # return possible name for a virtual package name
|
pascal@873
|
294
|
pascal@922
|
295 virtual_name() {
|
pascal@873
|
296 # input: $1 virtual package name
|
pascal@873
|
297 # $2 repository db directory
|
al@970
|
298 local i pi
|
al@970
|
299
|
al@970
|
300 pi="$2/packages-$SLITAZ_ARCH.info"
|
al@970
|
301 [ -e "$pi" ] || pi="$2/packages.info"
|
al@970
|
302
|
al@887
|
303 unset IFS
|
pascal@873
|
304 for i in $(grep -hs "^$1=" "$2/packages.equiv" | sed "s/^$1=//"); do
|
pascal@873
|
305 if echo $i | fgrep -q : ; then
|
pascal@873
|
306 # format 'alternative:newname'
|
pascal@873
|
307 # if alternative is installed then substitute newname
|
pascal@874
|
308 if [ -f $INSTALLED/${i%:*}/receipt ]; then
|
pascal@873
|
309 # substitute package dependency
|
pascal@873
|
310 echo ${i#*:}
|
pascal@873
|
311 return
|
pascal@873
|
312 fi
|
al@970
|
313 elif ! grep -q "^$1 " "$pi" || [ -f "$INSTALLED/$i/receipt" ]; then
|
pascal@873
|
314 # unconditional substitution
|
pascal@873
|
315 echo $i
|
pascal@873
|
316 return
|
pascal@873
|
317 fi
|
pascal@873
|
318 done
|
pascal@879
|
319 # the real package name
|
pascal@879
|
320 echo $1
|
pascal@873
|
321 }
|
pascal@873
|
322
|
pascal@922
|
323 virtual_pkg() {
|
pascal@922
|
324 # input: $1 virtual package name
|
pascal@922
|
325 # $2 repository db directory
|
pascal@922
|
326 # output: display possible package name
|
al@970
|
327 local pi
|
pascal@922
|
328
|
pascal@922
|
329 debug "\nvirtual_pkg('$1', '$2')"
|
pascal@922
|
330
|
al@970
|
331 pi="$2/packages-$SLITAZ_ARCH.info"
|
al@970
|
332 [ -e "$pi" ] || pi="$2/packages.info"
|
al@970
|
333
|
pascal@922
|
334 if [ "$tazpkg_command" != 'get-install' ]; then
|
pascal@922
|
335 # 'get' command: download any package
|
al@970
|
336 if [ -z "$(awk -F$'\t' -vp="$1" '{if ($1 == p) print p}' "$pi")" ]; then
|
paul@923
|
337 # This package does not exist in the list, it may be a virtual package
|
pascal@922
|
338 virtual_name "$1" "$2"
|
pascal@922
|
339 else
|
pascal@922
|
340 echo $1
|
pascal@922
|
341 fi
|
pascal@922
|
342 return
|
pascal@922
|
343 fi
|
pascal@922
|
344
|
pascal@922
|
345 virtual_name "$1" "$2"
|
pascal@922
|
346 }
|
pascal@922
|
347
|
al@887
|
348
|
al@844
|
349 # Download package file to the cache
|
al@844
|
350
|
al@844
|
351 get_pkg() {
|
al@844
|
352 # input: $1 package name either "name" or "name-version"
|
al@844
|
353 # $2 (internal): empty or 'redo' (when recursive calling)
|
al@844
|
354 # action: download package from mirror to the cache directory
|
al@844
|
355 # output: full path to the downloaded package
|
al@844
|
356
|
al@844
|
357 debug "\nget_pkg('$1', '$2')"
|
al@969
|
358 local repo line namever pkgsum pkgfile pi
|
al@844
|
359
|
al@844
|
360 IFS=$'\n'
|
al@844
|
361 for rep in $PRIORITY; do
|
al@970
|
362 pi="$rep/packages-$SLITAZ_ARCH.info"
|
al@970
|
363 [ -e "$pi" ] || pi="$rep/packages.info"
|
al@970
|
364 [ -e "$pi" ] || continue
|
al@968
|
365
|
al@971
|
366 # If found, output string "<name>-<ver>-<arch>.tazpkg"
|
al@971
|
367 # Field #11 may be:
|
al@971
|
368 # - empty (old format): treat as arch-dependent, use $SLITAZ_ARCH
|
al@971
|
369 # - 0: arch-independent (*-any.tazpkg)
|
al@971
|
370 # - 3: 32-bit \ just use $SLITAZ_ARCH in both cases -
|
al@971
|
371 # - 6: 64-bit / there's no 32-bit package in 64-bit repo
|
al@971
|
372 pkgfile=$(awk -F$'\t' -vpkg="$(virtual_pkg "$1" "$rep")" -varch="$SLITAZ_ARCH" '
|
al@971
|
373 $1==pkg || $1"-"$2==pkg {
|
al@971
|
374 a = ($11 == "0") ? "any" : arch;
|
al@971
|
375 printf("%s-%s-%s.tazpkg", $1, $2, a);
|
al@971
|
376 exit
|
al@971
|
377 }' "$pi")
|
al@965
|
378
|
al@971
|
379 if [ -n "$pkgfile" ]; then
|
al@965
|
380 pkgsum=$(awk -vfile="$pkgfile" '{if($2==file)print $1}' $rep/packages.md5)
|
al@844
|
381 break
|
al@844
|
382 fi
|
al@844
|
383 done
|
al@844
|
384 unset IFS
|
al@844
|
385
|
al@971
|
386 debug " rep='$rep'\n pkgfile='$pkgfile'\n pkgsum='$pkgsum'"
|
al@844
|
387
|
al@971
|
388 if [ -z "$pkgfile" ]; then
|
al@889
|
389 _ 'Unable to find package "%s" in the mirrored packages list.' "$1" >&2
|
al@844
|
390 # Retry with "get-package"; prevent looping with 'redo'
|
al@844
|
391 if [ "$2" != 'redo' ]; then
|
al@844
|
392 get_pkg "get-$1" 'redo'; exit 0
|
al@844
|
393 else
|
al@844
|
394 # Retry with extra-package
|
al@844
|
395 get_pkg_extra "${1#get-}"
|
al@844
|
396 exit 0
|
al@844
|
397 fi
|
al@844
|
398 fi
|
al@844
|
399
|
al@965
|
400 # We need package "$pkgfile" from "$rep" with "$pkgsum"
|
al@844
|
401
|
al@844
|
402 if [ -z "$nocache" ]; then
|
al@844
|
403 # Go to cache for "get-install" command; don't move for "get" command
|
al@844
|
404 debug "cd '$(get_cache_path "$rep")'"
|
al@844
|
405 cd "$(get_cache_path "$rep")"
|
al@844
|
406 fi
|
al@844
|
407
|
al@844
|
408 # Check if package already downloaded
|
al@965
|
409 if [ -f "$pkgfile" ]; then
|
al@971
|
410 [ -z "$nocache" -a -z "$quiet" ] && _ 'Package "%s" already in the cache' "$pkgfile" >&2
|
al@844
|
411
|
paul@943
|
412 # Check if downloading complete, resume if not complete
|
al@965
|
413 if ! tail -c 2k "$pkgfile" | fgrep -q '00000000TRAILER'; then
|
al@971
|
414 [ -z "$quiet" ] && _ 'Continuing package "%s" download' "$pkgfile" >&2
|
al@965
|
415 download_from "$(cat "$rep/mirror")" "$pkgfile"
|
al@844
|
416 fi
|
al@844
|
417 else
|
al@844
|
418 # Package absent in the cache, "cold" downloading
|
al@965
|
419 download_from "$(cat "$rep/mirror")" "$pkgfile"
|
al@844
|
420 fi
|
al@844
|
421
|
al@844
|
422 # Make sure we downloaded what we want with checksum
|
al@844
|
423
|
al@965
|
424 if [ "$($CHECKSUM "$pkgfile" | cut -d' ' -f1)" != "$pkgsum" ]; then
|
al@965
|
425 _ 'Checksum error for "%s"' "$pkgfile" >&2
|
al@965
|
426 rm "$pkgfile"
|
al@844
|
427
|
al@844
|
428 # Recharge DBs and try again; prevent looping with 'redo'
|
al@844
|
429 if [ "$2" != 'redo' ]; then
|
al@844
|
430 tazpkg recharge >&2
|
al@844
|
431 get_pkg "$1" 'redo'; exit 0
|
al@844
|
432 else
|
al@844
|
433 # Give up
|
al@844
|
434 # TODO: try another mirror?
|
al@844
|
435 die 'Please wait until the mirror synchronization is complete and try again.'
|
al@844
|
436 fi
|
al@844
|
437 fi
|
al@844
|
438
|
al@844
|
439 # Output: path to downloaded package
|
al@965
|
440 printf '%s/%s\n' "$(pwd)" "$pkgfile"
|
al@844
|
441 }
|
al@844
|
442
|
al@844
|
443
|
al@941
|
444 # Get local package from /home/slitaz/packages to co-work with the cookutils
|
al@941
|
445
|
al@941
|
446 get_pkg_cookmode() {
|
al@941
|
447 # input: $1 package name (like 'advancecomp')
|
al@941
|
448 # action: find package in /home/slitaz/packages (or where defined in the cook.conf)
|
al@941
|
449 # output: full path to the found package
|
al@941
|
450 # ROOT NOT USED
|
al@941
|
451
|
al@970
|
452 local PKGS='/home/slitaz/packages' found='0' i
|
al@950
|
453 [ -e "/etc/slitaz/cook.conf" ] && . /etc/slitaz/cook.conf
|
al@941
|
454
|
al@941
|
455 # Find local package
|
al@970
|
456 pi="$PKGS/packages-$SLITAZ_ARCH.info"
|
al@970
|
457 [ -e "$pi" ] || pi="$PKGS/packages.info"
|
al@968
|
458
|
al@971
|
459 pkgfile="$(awk -F$'\t' -vpkg="$1" -varch="$SLITAZ_ARCH" '{
|
al@971
|
460 if ($1 == pkg) {
|
al@971
|
461 a = ($11 == "0") ? "any" : arch;
|
al@971
|
462 printf("%s-%s-%s.tazpkg", $1, $2, a);
|
al@971
|
463 exit;
|
al@971
|
464 }
|
al@968
|
465 }' $pi)"
|
al@941
|
466
|
al@946
|
467 # Find local provided package
|
al@971
|
468 [ -n "$pkgfile" ] ||
|
al@971
|
469 pkgfile="$(awk -F$'\t' -vpkg="$1" -varch="$SLITAZ_ARCH" '{
|
al@971
|
470 if (index(" " $10 " ", " " pkg " ")) {
|
al@971
|
471 a = ($11 == "0") ? "any" : arch;
|
al@971
|
472 printf("%s-%s-%s.tazpkg", $1, $2, a);
|
al@971
|
473 exit;
|
al@971
|
474 }
|
al@968
|
475 }' $pi)"
|
al@941
|
476
|
al@971
|
477 if [ -e "$PKGS/$pkgfile" ]; then
|
al@971
|
478 echo "$PKGS/$pkgfile"
|
al@971
|
479 else
|
al@971
|
480 # Proceed to get package as usual (non-local)
|
al@971
|
481 get_pkg "$1"
|
al@971
|
482 fi
|
al@941
|
483 }
|
al@941
|
484
|
al@941
|
485
|
al@844
|
486
|
al@844
|
487
|
al@864
|
488 # Command 'get-install' calls 'get', then 'install' modules. Check package presence here, on the
|
al@864
|
489 # first stage, if '--forced' option not given
|
pascal@972
|
490 if [ "$tazpkg_command" = 'get-install' ]; then
|
al@866
|
491 if grep -qs "^$1$" "$BLOCKED"; then
|
al@866
|
492 _ 'Package "%s" blocked.' "$1" >&2
|
al@864
|
493 exit 1
|
al@864
|
494 fi
|
al@866
|
495
|
al@866
|
496 if [ -z "$forced" ]; then
|
al@866
|
497 awk -F$'\t' -vpv="$1" '$1==pv { exit 1 }' "$PKGS_DB/installed.info"
|
al@866
|
498 if [ "$?" -eq 1 ]; then
|
al@880
|
499 [ -z "$quiet" ] && (
|
al@866
|
500 newline
|
al@866
|
501 _ '"%s" package is already installed.' "$(colorize 34 "$1")"
|
al@866
|
502 longline "$(_ 'You can use the --forced option to force installation.')"
|
al@866
|
503 newline
|
al@866
|
504 ) >&2
|
al@866
|
505 # Prevent execution 'install' stage:
|
al@866
|
506 exit 1
|
al@866
|
507 fi
|
al@866
|
508 fi
|
al@864
|
509 fi
|
al@864
|
510
|
al@941
|
511 if [ -n "$cookmode" ]; then
|
al@941
|
512 # When '--cookmode' option given, try to find package in the local cook repository,
|
al@941
|
513 # then, if fails, try to get the package as usual
|
al@941
|
514 get_pkg_cookmode "$1"
|
al@941
|
515 elif [ -n "$extra" ]; then
|
al@844
|
516 # When '--extra' option given, extra-package has priority over 'regular' packages
|
al@844
|
517 get_pkg_extra "$1"
|
al@844
|
518 else
|
al@844
|
519 # Try to get 'package', then 'get-package', then extra 'package'
|
al@844
|
520 get_pkg "$1"
|
al@844
|
521 fi
|