rev |
line source |
pankso@6
|
1 #!/bin/sh
|
pankso@646
|
2 #
|
pankso@646
|
3 # TazPKG - Tiny autonomous zone packages manager.
|
pankso@6
|
4 #
|
paul@662
|
5 # This is a lightweight packages manager for *.tazpkg files written in SHell
|
pankso@646
|
6 # script. It works well with Busybox ash shell and bash. TazPKG lets you
|
pankso@646
|
7 # list, install, remove, download or get information about a package. You
|
pankso@646
|
8 # can use 'tazpkg usage' to get a list of commands with short descriptions.
|
pankso@646
|
9 # TazPKG also resolves dependencies and can upgrade packages from a mirror.
|
pankso@6
|
10 #
|
pankso@646
|
11 # (C) 2007-2014 SliTaz - GNU General Public License v3.
|
pankso@6
|
12 #
|
al@633
|
13 # Authors: See the AUTHORS files
|
pankso@27
|
14 #
|
pankso@6
|
15
|
pankso@6
|
16 ####################
|
pankso@6
|
17 # Script variables #
|
pankso@6
|
18 ####################
|
pankso@6
|
19
|
pankso@653
|
20 # TazPKG version
|
pascal@703
|
21 VERSION=5.3.3
|
pankso@586
|
22
|
slaxemulator@588
|
23 . /etc/slitaz/slitaz.conf
|
pankso@307
|
24 . /etc/slitaz/tazpkg.conf
|
pankso@6
|
25
|
pankso@590
|
26 . /lib/libtaz.sh
|
pankso@661
|
27 . /usr/lib/slitaz/libpkg.sh
|
al@695
|
28 . /usr/lib/tazpkg/tazpkg-find-depends
|
pankso@590
|
29
|
pankso@595
|
30 # Internationalization.
|
al@694
|
31 export TEXTDOMAIN='tazpkg'
|
al@707
|
32 _() { local T="$1"; shift; printf "$(gettext "$T")" "$@"; echo; }
|
al@707
|
33 _n() { local T="$1"; shift; printf "$(gettext "$T")" "$@"; }
|
al@707
|
34 _p() {
|
al@707
|
35 local S="$1" P="$2" N="$3"; shift; shift; shift;
|
al@707
|
36 printf "$(ngettext "$S" "$P" "$N")" "$@"; }
|
al@694
|
37
|
pankso@343
|
38
|
al@603
|
39 #
|
al@603
|
40 # Functions set for translate categories
|
al@603
|
41 #
|
pankso@646
|
42
|
al@694
|
43
|
al@603
|
44 # Make array of pre-translated categories
|
al@694
|
45
|
al@603
|
46 cat_i18n=""
|
al@707
|
47 for c in "base-system" "x-window" "utilities" "network" "graphics" \
|
al@707
|
48 "multimedia" "office" "development" "system-tools" "security" "games" \
|
al@707
|
49 "misc" "meta" "non-free"; do
|
al@603
|
50 cat_i18n="$cat_i18n
|
al@603
|
51 $(gettext "$c") $c"
|
al@603
|
52 done
|
al@694
|
53
|
al@694
|
54
|
al@701
|
55 # Translate category names (must be last in line)
|
al@701
|
56
|
al@701
|
57 translate_category()
|
al@701
|
58 {
|
al@701
|
59 sed "s|base-system$|$(_ base-system)|g; s|x-window$|$(_ x-window)|g;
|
al@701
|
60 s|utilities$|$(_ utilities)|g; s|network$|$(_ network)|g;
|
al@701
|
61 s|graphics$|$(_ graphics)|g; s|multimedia$|$(_ multimedia)|g;
|
al@701
|
62 s|office$|$(_ office)|g; s|development$|$(_ development)|g;
|
al@701
|
63 s|system-tools$|$(_ system-tools)|g; s|security$|$(_ security)|g;
|
al@701
|
64 s|games$|$(_ games)|g; s|misc$|$(_ misc)|g; s|meta$|$(_ meta)|g;
|
al@701
|
65 s|non-free$|$(_ non-free)|g"
|
al@701
|
66 }
|
al@701
|
67
|
al@701
|
68
|
al@603
|
69 # If category is not one of those translated in native language, keep it
|
al@603
|
70 # untranslated. This allows both native and english language support.
|
al@603
|
71 # This also supports custom categories.
|
al@603
|
72 # And now we support spaces in translated categories
|
al@694
|
73
|
al@603
|
74 reverse_translate_category()
|
al@603
|
75 {
|
al@603
|
76 echo "$cat_i18n" | awk "BEGIN{FS=\" \"}{if (/^$@ /) a=\$2}END{if (a==\"\") a=\"$@\"; print a}"
|
al@603
|
77 }
|
al@603
|
78
|
al@694
|
79
|
al@694
|
80
|
al@603
|
81 #
|
pankso@653
|
82 # TazPKG output functions
|
al@603
|
83 #
|
al@694
|
84
|
al@694
|
85
|
al@603
|
86 # Print localized title
|
al@694
|
87
|
al@702
|
88 title() { newline; boldify "$(_ "$@")"; separator; }
|
al@694
|
89
|
al@694
|
90
|
al@603
|
91 # Print footer
|
al@694
|
92
|
al@694
|
93 footer() { separator; echo "$1"; [ -n "$1" ] && newline; }
|
al@694
|
94
|
al@694
|
95
|
al@603
|
96 # Print current action in brown color (separate from any other msgs)
|
al@694
|
97
|
al@603
|
98 action() {
|
al@603
|
99 case $output in
|
psychomaniak@708
|
100 raw|gtk|html) _n "$@" ;;
|
al@702
|
101 *) echo -ne "\033[0;33m"$(_ "$@")"\033[0m" ;;
|
al@603
|
102 esac
|
al@603
|
103 }
|
al@603
|
104
|
al@694
|
105
|
pankso@307
|
106 # Initialize some variables to use words rather than numbers for functions
|
pankso@307
|
107 # and actions.
|
pankso@6
|
108 COMMAND=$1
|
pascal@427
|
109 PACKAGE=${2%/}
|
slaxemulator@530
|
110 PACKAGE_DIR="$(cd $(dirname $PACKAGE 2>/dev/null) 2>/dev/null; pwd)"
|
al@694
|
111 [ -n "$PACKAGE" ] && PACKAGE_FILE="$PACKAGE_DIR/${PACKAGE##*/}"
|
pascal@427
|
112 if [ -f "$PACKAGE" ]; then
|
pankso@10
|
113 # Set pkg basename for install, extract
|
al@694
|
114 PACKAGE=$(basename $PACKAGE .tazpkg 2>/dev/null)
|
pankso@10
|
115 else
|
pankso@10
|
116 # Pkg name for remove, search and all other cmds
|
pascal@427
|
117 PACKAGE=${PACKAGE%.tazpkg}
|
pankso@10
|
118 fi
|
pankso@6
|
119 TARGET_DIR=$3
|
al@694
|
120 TOP_DIR=$(pwd)
|
al@605
|
121 TMP_DIR=/tmp/$RANDOM
|
pankso@307
|
122 INSTALL_LIST=""
|
gokhlayeh@419
|
123 SAVE_CACHE_DIR="$CACHE_DIR"
|
pankso@6
|
124
|
pankso@6
|
125 # Path to tazpkg used dir and configuration files
|
al@700
|
126 MIRROR=$PKGS_DB/mirror
|
al@700
|
127 BLOCKED=$PKGS_DB/blocked-packages.list
|
al@700
|
128 UP_LIST=$PKGS_DB/packages.up
|
slaxemulator@588
|
129 DEFAULT_MIRROR="$ONLINE_PKGS"
|
pankso@6
|
130
|
pascal@515
|
131
|
al@694
|
132
|
al@694
|
133
|
pankso@6
|
134 ####################
|
pankso@6
|
135 # Script functions #
|
pankso@6
|
136 ####################
|
pankso@6
|
137
|
al@694
|
138
|
pankso@6
|
139 # Print the usage.
|
al@694
|
140
|
al@603
|
141 usage () {
|
al@603
|
142 cat << EOT
|
pankso@600
|
143
|
al@702
|
144 $(_ 'SliTaz package manager - Version: %s' $(colorize 34 $VERSION))
|
al@694
|
145
|
al@694
|
146 $(boldify "$(_ 'Usage:')")
|
al@694
|
147 $(_ 'tazpkg [command] [package|dir|pattern|list|cat|--opt] [dir|--opt]')
|
al@694
|
148
|
al@694
|
149 $(boldify "$(_ 'SHell:')") tazpkg shell
|
al@694
|
150
|
al@694
|
151 $(boldify "$(_ 'Commands:')")
|
al@707
|
152 $(optlist "\
|
al@707
|
153 usage $(_ 'Print this short usage')
|
al@707
|
154 bugs $(_ 'Show known bugs in packages')
|
al@707
|
155 -a activity $(_ 'Show TazPkg activity log')
|
al@707
|
156 -l list $(_ 'List installed packages on the system')
|
al@707
|
157 -lm list-mirror $(_ 'List all available packages on the mirror')
|
al@707
|
158 info $(_ 'Print information about a package')
|
al@707
|
159 desc $(_ 'Print description of a package')
|
al@707
|
160 -lf list-files $(_ 'List the files installed with a package')
|
al@707
|
161 list-config $(_ 'List the configuration files')
|
al@707
|
162
|
al@707
|
163 -s search $(_ 'Search for a package by pattern or name')
|
al@707
|
164 search-pkgname $(_ 'Search on mirror for package having a particular file')
|
al@707
|
165 -sf search-file $(_ 'Search for file in all installed packages files')
|
al@707
|
166
|
al@707
|
167 get $(_ 'Download a package into the current directory')
|
al@707
|
168 -gi get-install $(_ 'Download and install a package from the mirror')
|
al@707
|
169 get-install-list $(_ 'Download and install a list of packages from the mirror')
|
al@707
|
170 -i install $(_ 'Install a local package')
|
al@707
|
171 install-list $(_ 'Install all packages from a list of packages')
|
al@707
|
172 -r remove $(_ 'Remove the specified package and all installed files')
|
al@707
|
173 -e extract $(_ 'Extract a (*.tazpkg) package into a directory')
|
al@707
|
174 pack $(_ 'Pack an unpacked or prepared package tree')
|
al@707
|
175
|
al@707
|
176 recharge $(_ 'Recharge your packages.list from the mirror')
|
al@707
|
177 up|help-up $(_ 'Check packages %s to list and install latest upgrades' $CHECKSUM)
|
al@707
|
178
|
al@707
|
179 repack $(_ 'Create a package archive from an installed package')
|
al@707
|
180 repack-config $(_ 'Create a package archive with configuration files')
|
al@707
|
181 recompress $(_ 'Rebuild a package with a better compression ratio')
|
al@707
|
182 block|unblock $(_ 'Block an installed package version or unblock it for upgrade')
|
al@707
|
183 check $(_ 'Verify consistency of installed packages')
|
al@707
|
184
|
al@707
|
185 add-flavor $(_ 'Install the flavor list of packages')
|
al@707
|
186 install-flavor $(_ 'Install the flavor list of packages and remove other ones')
|
al@707
|
187
|
al@707
|
188 set-release $(_ 'Change release and update packages')
|
al@707
|
189 -cc clean-cache $(_ 'Clean all packages downloaded in cache directory')
|
al@707
|
190
|
al@707
|
191 depends $(_ 'Display dependencies tree')
|
al@707
|
192 rdepends $(_ 'Display reverse dependencies tree')
|
al@707
|
193
|
al@707
|
194 convert $(_ 'Convert alien package to tazpkg')
|
al@707
|
195 link $(_ 'Link a package from another slitaz installation')
|
al@707
|
196
|
al@707
|
197 -sm setup-mirror $(_ 'Change the mirror url configuration')
|
al@707
|
198 list-undigest $(_ 'List undigest mirrors')
|
al@707
|
199 remove-undigest $(_ 'Remove an undigest mirror')
|
al@707
|
200 add-undigest $(_ 'Add an undigest mirror')
|
al@707
|
201 setup-undigest $(_ 'Update an undigest mirror')
|
al@707
|
202
|
al@707
|
203 reconfigure $(_ 'Replay post install script from package')
|
al@707
|
204 ")
|
al@603
|
205 EOT
|
pankso@6
|
206 }
|
pankso@6
|
207
|
al@694
|
208
|
pankso@464
|
209 usage_up() {
|
al@603
|
210 cat << EOT
|
al@694
|
211 $(emsg "<b>$(_ 'Usage for command up:')</b>") tazpkg up [$(_ 'option')]
|
al@694
|
212
|
al@707
|
213 * $(longline "$(_ 'Without options run in interactive mode and ask before install')")
|
al@694
|
214
|
al@694
|
215 $(boldify "$(_ 'Where options are:')")
|
al@707
|
216 $(optlist "\
|
al@707
|
217 -c --check $(_ 'Check only for available upgrades')
|
al@707
|
218 -r --recharge $(_ 'Force recharge of packages list and check')
|
al@707
|
219 -i --install $(_ 'Check for upgrades and install them all')
|
al@707
|
220 ")
|
al@694
|
221
|
al@694
|
222 $(boldify "$(_ 'Example:')")
|
pankso@464
|
223 tazpkg up --recharge --install
|
pankso@464
|
224 tazpkg up -c -r
|
al@603
|
225 EOT
|
pankso@464
|
226 }
|
pankso@464
|
227
|
al@694
|
228
|
paul@662
|
229 # Check if dir exists
|
al@694
|
230
|
pankso@584
|
231 check_dir()
|
pankso@584
|
232 {
|
pankso@584
|
233 if ! [ -d "$1" ]; then
|
al@707
|
234 action 'Creating folder "%s"...' "$1"
|
al@707
|
235 mkdir -p "$1"
|
pankso@584
|
236 status
|
pankso@584
|
237 return 1
|
pankso@584
|
238 fi
|
pankso@584
|
239 }
|
pankso@584
|
240
|
al@694
|
241
|
pankso@653
|
242 # Check if the directories and files used by TazPKG
|
pankso@590
|
243 # exist. If not and user is root we create them.
|
al@694
|
244
|
pankso@590
|
245 check_base_dir()
|
pankso@590
|
246 {
|
al@603
|
247 if [ "$(id -u)" = "0" ]; then
|
pankso@590
|
248 check_dir $1$CACHE_DIR
|
pankso@590
|
249 check_dir $1$INSTALLED
|
pankso@594
|
250 check_dir $1$SLITAZ_LOGS
|
al@700
|
251 if [ ! -f "$1$PKGS_DB/mirror" ]; then
|
al@700
|
252 echo "${DEFAULT_MIRROR%/}/" > $1$PKGS_DB/mirror
|
al@700
|
253 [ -n "$1" ] && cp $PKGS_DB/packages.* $1$PKGS_DB/
|
pankso@590
|
254 fi
|
pankso@590
|
255 fi
|
pankso@590
|
256 }
|
pankso@590
|
257 check_base_dir
|
pankso@590
|
258
|
al@694
|
259
|
pankso@6
|
260 # Check for a package name on cmdline.
|
al@694
|
261
|
pankso@6
|
262 check_for_package_on_cmdline()
|
pankso@6
|
263 {
|
pankso@6
|
264 if [ -z "$PACKAGE" ]; then
|
pankso@600
|
265 newline
|
al@694
|
266 _ 'Please specify a package name on the command line.'
|
pankso@600
|
267 newline
|
al@707
|
268 exit 1
|
pankso@6
|
269 fi
|
pankso@6
|
270 }
|
pankso@6
|
271
|
al@694
|
272
|
paul@437
|
273 # Check if the package (*.tazpkg) exists before installing or extracting.
|
al@694
|
274
|
pankso@6
|
275 check_for_package_file()
|
pankso@6
|
276 {
|
pankso@9
|
277 if [ ! -f "$PACKAGE_FILE" ]; then
|
pankso@600
|
278 newline
|
al@702
|
279 _ 'Unable to find file "%s"' $PACKAGE_FILE
|
al@603
|
280 newline
|
al@707
|
281 exit 1
|
pankso@6
|
282 fi
|
pankso@6
|
283 }
|
pankso@6
|
284
|
al@694
|
285
|
pankso@6
|
286 # Check for the receipt of an installed package.
|
al@694
|
287
|
pankso@6
|
288 check_for_receipt()
|
pankso@6
|
289 {
|
al@707
|
290 if [ ! -f "$1$INSTALLED/$PACKAGE/receipt" ]; then
|
pankso@600
|
291 newline
|
al@707
|
292 _ 'Unable to find the receipt "%s"' "$1$INSTALLED/$PACKAGE/receipt"
|
al@603
|
293 newline
|
al@707
|
294 exit 1
|
pankso@6
|
295 fi
|
pankso@6
|
296 }
|
pankso@6
|
297
|
al@694
|
298
|
al@700
|
299 # Get repositories priority using $PKGS_DB/priority.
|
gokhlayeh@386
|
300 # In this files, undigest are called by their name and main mirror
|
al@633
|
301 # by main. Sort order: priority
|
al@694
|
302
|
gokhlayeh@386
|
303 look_for_priority()
|
gokhlayeh@386
|
304 {
|
al@700
|
305 [ -s $PKGS_DB/priority ] && priority=$(cat $PKGS_DB/priority)
|
al@700
|
306 for rep in main $(ls $PKGS_DB/undigest 2>/dev/null); do
|
al@700
|
307 if [ ! -s $PKGS_DB/priority ] || \
|
al@700
|
308 ! grep -q ^$rep$ $PKGS_DB/priority; then
|
al@694
|
309 priority=$(echo -e "$priority\n$rep")
|
al@694
|
310 fi
|
al@694
|
311 done
|
al@694
|
312 priority=$(echo "$priority" | sed '/^$/d' | \
|
al@694
|
313 while read line; do
|
al@694
|
314 if [ "$line" = main ]; then
|
al@700
|
315 echo $PKGS_DB
|
al@694
|
316 else
|
al@700
|
317 echo $PKGS_DB/undigest/$line
|
al@694
|
318 fi
|
al@694
|
319 done)
|
gokhlayeh@386
|
320 }
|
gokhlayeh@386
|
321
|
al@694
|
322
|
pascal@110
|
323 # Get package name in a directory
|
al@694
|
324
|
pascal@110
|
325 package_fullname_in_dir()
|
pascal@110
|
326 {
|
gokhlayeh@407
|
327 [ -f $1/receipt ] || return
|
pascal@114
|
328 EXTRAVERSION=""
|
gokhlayeh@407
|
329 . $1/receipt
|
pascal@110
|
330 echo $PACKAGE-$VERSION$EXTRAVERSION
|
pascal@110
|
331 }
|
pascal@110
|
332
|
al@694
|
333
|
pascal@110
|
334 # Get package name that is already installed.
|
al@694
|
335
|
pascal@110
|
336 get_installed_package_pathname()
|
pascal@110
|
337 {
|
pascal@121
|
338 for i in $2$INSTALLED/${1%%-*}*; do
|
pascal@115
|
339 [ -d $i ] || continue
|
gokhlayeh@407
|
340 if [ "$1" = "$(package_fullname_in_dir $i)" ]; then
|
pascal@110
|
341 echo $i
|
pascal@110
|
342 return
|
pascal@110
|
343 fi
|
pascal@110
|
344 done
|
pascal@110
|
345 }
|
pascal@110
|
346
|
al@694
|
347
|
pankso@6
|
348 # Check if a package is already installed.
|
al@694
|
349
|
pankso@6
|
350 check_for_installed_package()
|
pankso@6
|
351 {
|
pascal@121
|
352 if [ -n "$(get_installed_package_pathname $PACKAGE $1)" ]; then
|
pankso@600
|
353 newline
|
al@702
|
354 _ '"%s" package is already installed.' $(colorize 34 $PACKAGE)
|
al@707
|
355 longline "$(_ 'You can use the --forced option to force installation.')"
|
al@603
|
356 newline
|
al@603
|
357 exit 0
|
pankso@6
|
358 fi
|
pankso@6
|
359 }
|
pankso@6
|
360
|
al@694
|
361
|
pankso@6
|
362 # Check for packages.list to download and install packages.
|
al@694
|
363
|
pankso@6
|
364 check_for_packages_list()
|
pankso@6
|
365 {
|
al@700
|
366 list_path="$PKGS_DB/packages.list"
|
al@633
|
367 if [ ! -f "$list_path" ]; then
|
pankso@71
|
368 if test $(id -u) = 0 ; then
|
pankso@71
|
369 tazpkg recharge
|
pankso@71
|
370 else
|
pankso@600
|
371 newline
|
al@702
|
372 _ 'Unable to find the list "%s"' $list_path
|
al@694
|
373 _ \
|
pankso@344
|
374 "You must probably run 'tazpkg recharge' as root to get the latest list of
|
al@694
|
375 packages available on the mirror."
|
al@603
|
376 newline
|
al@603
|
377 exit 0
|
pankso@71
|
378 fi
|
pankso@6
|
379 fi
|
pankso@6
|
380 }
|
pankso@6
|
381
|
al@694
|
382
|
al@701
|
383 # Check for installed.info - local file with format of packages.info
|
al@707
|
384 # "installed.info" is absent on not clean installs; check it and re-generate if needed.
|
al@701
|
385
|
al@701
|
386 check_for_installed_info()
|
al@701
|
387 {
|
al@701
|
388 info_path="$PKGS_DB/installed.info"
|
al@701
|
389 if [ ! -f "$info_path" ]; then
|
al@701
|
390 if [ "$(id -u)" == "0" ]; then
|
al@702
|
391 _ 'File "%s" generated. Please wait...' installed.info
|
al@701
|
392 for pkg in $PKGS_DB/installed/*/receipt; do
|
al@701
|
393 unset_receipt
|
al@701
|
394 . $pkg
|
al@701
|
395 SIZES=$(echo $PACKED_SIZE $UNPACKED_SIZE | sed 's|\.0||g')
|
al@701
|
396 DEPENDS=$(echo $DEPENDS) # remove newlines from some receipts
|
al@701
|
397 cat >> $info_path << EOT
|
al@701
|
398 $PACKAGE $VERSION$EXTRAVERSION $CATEGORY $SHORT_DESC $WEB_SITE $TAGS $SIZES $DEPENDS
|
al@701
|
399 EOT
|
al@701
|
400 done
|
al@701
|
401 else
|
al@702
|
402 _ 'Unable to find file "%s"' installed.info
|
al@701
|
403 _ 'Please run tazpkg as root.'
|
al@701
|
404 exit 1
|
al@701
|
405 fi
|
al@701
|
406 fi
|
al@701
|
407 }
|
al@701
|
408
|
al@701
|
409
|
gokhlayeh@419
|
410 get_cache_dir()
|
gokhlayeh@419
|
411 {
|
gokhlayeh@419
|
412 echo $rep > $tmp/rep
|
al@700
|
413 if [ "$rep" = "$PKGS_DB" ]; then
|
pankso@586
|
414 CACHE_DIR="$SAVE_CACHE_DIR/$SLITAZ_RELEASE/packages"
|
gokhlayeh@419
|
415 elif [ "${rep%-incoming}" = "$rep" ]; then
|
gokhlayeh@419
|
416 CACHE_DIR="$SAVE_CACHE_DIR/${rep##*/}/packages"
|
gokhlayeh@419
|
417 else
|
gokhlayeh@419
|
418 rep="${rep%-incoming}"
|
gokhlayeh@419
|
419 CACHE_DIR="$SAVE_CACHE_DIR/${rep##*/}/packages-incoming"
|
gokhlayeh@419
|
420 fi
|
gokhlayeh@419
|
421 [ -d "$CACHE_DIR" ] || mkdir -p $CACHE_DIR
|
gokhlayeh@419
|
422 echo $CACHE_DIR > $tmp/cachedir
|
gokhlayeh@419
|
423 }
|
gokhlayeh@419
|
424
|
al@694
|
425
|
pascal@261
|
426 # get an already installed package from packages.equiv
|
al@694
|
427
|
pascal@226
|
428 equivalent_pkg()
|
pascal@226
|
429 {
|
al@700
|
430 for i in $(grep -hs "^$1=" $PKGS_DB/packages.equiv \
|
al@700
|
431 $PKGS_DB/undigest/*/packages.equiv | sed "s/^$1=//"); do
|
gokhlayeh@409
|
432 if echo $i | fgrep -q : ; then
|
pascal@226
|
433 # format 'alternative:newname'
|
pascal@226
|
434 # if alternative is installed then substitute newname
|
pascal@226
|
435 if [ -f $2$INSTALLED/${i%:*}/receipt ]; then
|
paul@662
|
436 # substitute package dependency
|
pascal@226
|
437 echo ${i#*:}
|
pascal@226
|
438 return
|
pascal@226
|
439 fi
|
pascal@226
|
440 else
|
pascal@226
|
441 # if alternative is installed then nothing to install
|
pascal@241
|
442 if [ -f $2$INSTALLED/$i/receipt ]; then
|
pascal@226
|
443 # substitute installed package
|
pascal@226
|
444 echo $i
|
pascal@226
|
445 return
|
pascal@226
|
446 fi
|
pascal@226
|
447 fi
|
pascal@226
|
448 done
|
pascal@226
|
449 # if not found in packages.equiv then no substitution
|
pascal@226
|
450 echo $1
|
pascal@226
|
451 }
|
pascal@226
|
452
|
al@694
|
453
|
pascal@261
|
454 # get a virtual package from packages.equiv
|
al@694
|
455
|
pascal@261
|
456 virtual_pkg()
|
pascal@261
|
457 {
|
pankso@598
|
458 for i in $(for rep in $priority; do
|
gokhlayeh@386
|
459 grep -hs "^$1=" $rep/packages.equiv
|
gokhlayeh@386
|
460 done | sed "s/^$1=//"); do
|
gokhlayeh@409
|
461 if echo $i | fgrep -q : ; then
|
pascal@261
|
462 # format 'alternative:newname'
|
pascal@261
|
463 # if alternative is installed then substitute newname
|
pascal@261
|
464 if [ -f $2$INSTALLED/${i%:*}/receipt ]; then
|
paul@662
|
465 # substitute package dependency
|
pascal@261
|
466 echo ${i#*:}
|
pascal@261
|
467 return
|
pascal@261
|
468 fi
|
pascal@261
|
469 else
|
pascal@262
|
470 # unconditional substitution
|
pascal@261
|
471 echo $i
|
pascal@261
|
472 return
|
pascal@261
|
473 fi
|
pascal@261
|
474 done
|
pascal@261
|
475 }
|
pascal@261
|
476
|
al@694
|
477
|
pascal@190
|
478 # Get package filename available on the mirror
|
al@694
|
479
|
pascal@190
|
480 get_package_filename()
|
pascal@190
|
481 {
|
pascal@190
|
482 local pkg
|
gokhlayeh@386
|
483 for rep in $priority; do
|
al@694
|
484 pkg=$(grep -A 1 -sh "^$1$" $rep/packages.txt | tail -1 | sed 's/^ *//')
|
al@694
|
485 [ "$pkg" ] && pkg=$(grep -sh "^$1-$pkg" $rep/packages.list | head -1)
|
pankso@598
|
486
|
gokhlayeh@387
|
487 # Allow user to call a package with his version number.
|
gokhlayeh@387
|
488 [ "$pkg" ] || pkg=$(grep -sh "^$1$" $rep/packages.list | head -1)
|
pankso@598
|
489
|
al@694
|
490 [ "$pkg" ] || pkg=$(grep -sh "^$1-[0-9]" $rep/packages.list | head -1)
|
al@694
|
491 [ "$pkg" ] || pkg=$(grep -sh "^$1-.[\.0-9]" $rep/packages.list | head -1)
|
gokhlayeh@419
|
492 [ "$pkg" ] && get_cache_dir && break
|
gokhlayeh@386
|
493 done
|
pascal@226
|
494 if [ -z "$pkg" ]; then
|
paul@662
|
495 # Check for virtual package
|
pascal@226
|
496 local equiv
|
pascal@261
|
497 equiv=$(virtual_pkg $1)
|
pascal@226
|
498 if [ "$equiv" != "$1" ]; then
|
pascal@226
|
499 PACKAGE=$equiv
|
pascal@226
|
500 get_package_filename $PACKAGE
|
pascal@226
|
501 return
|
pascal@226
|
502 fi
|
pascal@226
|
503 fi
|
pascal@190
|
504 echo $pkg
|
pascal@190
|
505 }
|
pascal@190
|
506
|
al@694
|
507
|
pankso@6
|
508 # Check for a package in packages.list. Used by get and get-install to grep
|
pankso@6
|
509 # package basename.
|
al@694
|
510
|
pankso@6
|
511 check_for_package_in_list()
|
pankso@6
|
512 {
|
pascal@190
|
513 local filename
|
pascal@202
|
514 local check_only
|
pascal@202
|
515 check_only="$1"
|
gokhlayeh@416
|
516 filename=$(get_package_filename $PACKAGE)
|
gokhlayeh@419
|
517 if [ "$filename" ]; then
|
pascal@190
|
518 PACKAGE=$filename
|
gokhlayeh@419
|
519 CACHE_DIR=$(cat $tmp/cachedir)
|
gokhlayeh@419
|
520 rep=$(cat $tmp/rep)
|
gokhlayeh@419
|
521 rm -f $tmp/rep $tmp/cachedir
|
pankso@6
|
522 else
|
pankso@600
|
523 newline
|
al@702
|
524 _ 'Unable to find package "%s" in the mirrored packages list.' $PACKAGE
|
pankso@600
|
525 newline
|
pascal@202
|
526 [ -n "$check_only" ] && return 1
|
pankso@6
|
527 exit 0
|
pankso@6
|
528 fi
|
pankso@6
|
529 }
|
pankso@6
|
530
|
al@694
|
531
|
pascal@183
|
532 # Log this activity
|
al@603
|
533 # (there log_pkg because we have log() in libtaz.sh)
|
al@694
|
534
|
al@603
|
535 log_pkg()
|
pascal@183
|
536 {
|
pascal@207
|
537 local extra
|
al@694
|
538
|
pascal@207
|
539 [ "$1" = "Installed" ] && \
|
al@700
|
540 extra=" - $(fgrep $PACKAGE-$VERSION $PKGS_DB/installed.$SUM | awk '{ print $1 }')"
|
al@694
|
541
|
pascal@183
|
542 [ -e $LOG ] || touch $LOG
|
al@694
|
543
|
pankso@279
|
544 [ -w $LOG ] &&
|
al@694
|
545 echo "$(date +'%F %T') - $1 - $PACKAGE ($VERSION$EXTRAVERSION)$extra" >> $LOG
|
pascal@183
|
546 }
|
pascal@183
|
547
|
al@694
|
548
|
pascal@648
|
549 # Download a get-package script from this mirror
|
al@694
|
550
|
pascal@648
|
551 download_get_script()
|
pascal@648
|
552 {
|
pascal@648
|
553 local p
|
pascal@648
|
554 for p in $priority ; do
|
pascal@648
|
555 local i
|
pascal@648
|
556 for i in $(cat $p/mirror) ; do
|
pascal@648
|
557 case "$i" in
|
al@694
|
558 http://*|ftp://*)
|
al@694
|
559 wget -O $2 ${i%packages/*}packages/get/$1 && return 0 ;;
|
pascal@648
|
560 esac
|
pascal@648
|
561 done
|
pascal@648
|
562 done
|
pascal@648
|
563 return 1
|
pascal@648
|
564 }
|
pascal@648
|
565
|
al@694
|
566
|
pascal@187
|
567 # Download a file from this mirror
|
al@694
|
568
|
pascal@187
|
569 download_from()
|
pascal@187
|
570 {
|
pascal@187
|
571 local i
|
pascal@187
|
572 local mirrors
|
pascal@187
|
573 mirrors="$1"
|
pascal@187
|
574 shift
|
pascal@187
|
575 for i in $mirrors; do
|
pascal@187
|
576 case "$i" in
|
pankso@580
|
577 # Mirror URL can have a trailing slash or not.
|
al@694
|
578 http://*|ftp://*)
|
al@694
|
579 busybox wget -c ${i%/}/$@ && break ;;
|
al@699
|
580 https://*)
|
al@699
|
581 echo 'Sorry, https not supported' ;;
|
al@694
|
582 *)
|
al@694
|
583 ln -sf $i/$1 . && break ;;
|
pascal@187
|
584 esac
|
pascal@187
|
585 done
|
pascal@187
|
586 }
|
pascal@187
|
587
|
al@694
|
588
|
pascal@17
|
589 # Download a file trying all mirrors
|
al@694
|
590
|
pascal@17
|
591 download()
|
pascal@17
|
592 {
|
pascal@187
|
593 local i
|
pascal@225
|
594 case "$1" in
|
pascal@225
|
595 *.tazpkg)
|
gokhlayeh@386
|
596 for i in $priority ; do
|
gokhlayeh@386
|
597 grep -q "^${1%.tazpkg}$" $i/packages.list 2>/dev/null || continue
|
pascal@225
|
598 download_from "$(cat $i/mirror)" "$@" && return
|
pascal@225
|
599 done
|
pascal@225
|
600 esac
|
al@694
|
601 for i in $(cat $(for rep in $priority; do echo $rep/mirror; done) 2>/dev/null); do
|
pascal@191
|
602 download_from "$i" "$@" && break
|
pascal@17
|
603 done
|
pascal@17
|
604 }
|
pascal@17
|
605
|
al@694
|
606
|
pascal@297
|
607 # Extract a package with cpio and gzip/lzma.
|
al@694
|
608
|
pankso@6
|
609 extract_package()
|
pankso@6
|
610 {
|
al@702
|
611 action 'Extracting package...'
|
gokhlayeh@414
|
612 cpio -idm --quiet < ${PACKAGE_FILE##*/} && rm -f ${PACKAGE_FILE##*/}
|
gokhlayeh@383
|
613 status
|
pascal@297
|
614 if [ -f fs.cpio.lzma ]; then
|
gokhlayeh@383
|
615 unlzma -c fs.cpio.lzma | cpio -idm --quiet && rm fs.cpio.lzma
|
gokhlayeh@355
|
616 elif [ -f fs.cpio.gz ]; then
|
gokhlayeh@383
|
617 zcat fs.cpio.gz | cpio -idm --quiet && rm fs.cpio.gz
|
pascal@297
|
618 fi
|
pankso@6
|
619 }
|
pankso@6
|
620
|
al@694
|
621
|
pascal@299
|
622 remove_with_path()
|
pascal@299
|
623 {
|
gokhlayeh@385
|
624 # Avoid dirname errors by checking for argument.
|
gokhlayeh@385
|
625 [ "$1" ] || return
|
pankso@598
|
626
|
pascal@299
|
627 local dir
|
pascal@299
|
628 rm -f $1 2>/dev/null
|
pascal@299
|
629 dir="$1"
|
pascal@299
|
630 while [ "$dir" != "/" ]; do
|
pascal@299
|
631 dir="$(dirname $dir)"
|
pascal@299
|
632 rmdir $dir 2> /dev/null || break
|
pascal@299
|
633 done
|
pascal@299
|
634 }
|
pascal@299
|
635
|
al@694
|
636
|
pascal@377
|
637 grepesc()
|
pascal@377
|
638 {
|
pascal@377
|
639 sed 's/\[/\\[/g'
|
pascal@377
|
640 }
|
pascal@377
|
641
|
al@694
|
642
|
MikeDSmith25@135
|
643 # This function installs a package in the rootfs.
|
al@694
|
644
|
pankso@6
|
645 install_package()
|
pankso@6
|
646 {
|
pascal@20
|
647 ROOT=$1
|
pascal@20
|
648 if [ -n "$ROOT" ]; then
|
al@694
|
649 # Get absolute path
|
al@694
|
650 ROOT=$(realpath $ROOT)
|
pascal@20
|
651 fi
|
gokhlayeh@408
|
652 {
|
MikeDSmith25@134
|
653 # Create package path early to avoid dependencies loop
|
pascal@122
|
654 mkdir -p $TMP_DIR
|
gokhlayeh@408
|
655 { cd $TMP_DIR ; cpio --quiet -i receipt > /dev/null 2>&1; } < $PACKAGE_FILE
|
pascal@122
|
656 . $TMP_DIR/receipt
|
al@701
|
657 # FIXME: legacy?
|
pascal@224
|
658 if grep -q ^pre_depends $TMP_DIR/receipt; then
|
pascal@224
|
659 pre_depends $ROOT
|
pascal@224
|
660 fi
|
al@694
|
661
|
paul@662
|
662 # Keep modifiers and file list on upgrade
|
pascal@273
|
663 cp $ROOT$INSTALLED/$PACKAGE/modifiers \
|
pascal@273
|
664 $ROOT$INSTALLED/$PACKAGE/files.list $TMP_DIR 2> /dev/null
|
pascal@249
|
665 rm -rf $ROOT$INSTALLED/$PACKAGE 2> /dev/null
|
al@694
|
666
|
pascal@122
|
667 # Make the installed package data dir to store
|
pascal@122
|
668 # the receipt and the files list.
|
pascal@122
|
669 mkdir -p $ROOT$INSTALLED/$PACKAGE
|
pascal@249
|
670 cp $TMP_DIR/modifiers $ROOT$INSTALLED/$PACKAGE 2> /dev/null
|
pascal@273
|
671 cp $TMP_DIR/files.list $ROOT$INSTALLED/$PACKAGE 2> /dev/null
|
pascal@249
|
672 rm -rf $TMP_DIR 2> /dev/null
|
pascal@195
|
673 sed -i "/ $(basename $PACKAGE_FILE)$/d" \
|
al@700
|
674 $ROOT$PKGS_DB/installed.$SUM 2> /dev/null
|
pascal@195
|
675 cd $(dirname $PACKAGE_FILE)
|
al@700
|
676 $CHECKSUM $(basename $PACKAGE_FILE) >> $ROOT$PKGS_DB/installed.$SUM
|
gokhlayeh@408
|
677 }
|
al@694
|
678
|
MikeDSmith25@134
|
679 # Resolve package deps.
|
pascal@120
|
680 check_for_deps $ROOT
|
al@694
|
681 if [ -n "$MISSING_PACKAGE" ]; then
|
pascal@120
|
682 install_deps $ROOT
|
pascal@120
|
683 fi
|
pankso@6
|
684 mkdir -p $TMP_DIR
|
al@700
|
685 [ -n "$INSTALL_LIST" ] && echo "$PACKAGE_FILE" >> $ROOT$PKGS_DB/$INSTALL_LIST-processed
|
al@694
|
686
|
al@702
|
687 title 'Installation of package "%s"' $PACKAGE
|
al@702
|
688
|
al@702
|
689 action 'Copying package...'
|
pankso@9
|
690 cp $PACKAGE_FILE $TMP_DIR
|
pankso@6
|
691 status
|
al@694
|
692
|
pankso@6
|
693 cd $TMP_DIR
|
pankso@6
|
694 extract_package
|
pascal@20
|
695 SELF_INSTALL=0
|
pascal@114
|
696 EXTRAVERSION=""
|
pascal@144
|
697 CONFIG_FILES=""
|
al@694
|
698
|
pankso@6
|
699 # Include temporary receipt to get the right variables.
|
pankso@6
|
700 . $PWD/receipt
|
pascal@273
|
701 cd $ROOT$INSTALLED
|
al@694
|
702
|
al@701
|
703 # FIXME: legacy?
|
pascal@20
|
704 if [ $SELF_INSTALL -ne 0 -a -n "$ROOT" ]; then
|
al@603
|
705 action "Checking post install dependencies..."
|
pascal@125
|
706 [ -f $INSTALLED/$PACKAGE/receipt ]
|
pascal@20
|
707 if ! status; then
|
al@702
|
708 _ 'Please run "%s" in / and retry.' "tazpkg install $PACKAGE_FILE"
|
pascal@273
|
709 rm -rf $TMP_DIR
|
pascal@20
|
710 exit 1
|
pascal@20
|
711 fi
|
pascal@20
|
712 fi
|
al@694
|
713
|
pascal@273
|
714 # Get files to remove if upgrading
|
pascal@273
|
715 if [ -f $PACKAGE/files.list ]; then
|
pascal@273
|
716 while read file; do
|
pascal@377
|
717 grep -q "^$(echo $file | grepesc)$" $TMP_DIR/files.list && continue
|
pankso@279
|
718 for i in $(cat $PACKAGE/modifiers 2> /dev/null ;
|
gokhlayeh@409
|
719 fgrep -sl $PACKAGE */modifiers | cut -d/ -f1 ); do
|
pascal@377
|
720 grep -qs "^$(echo $file | grepesc)$" $i/files.list && continue 2
|
pascal@273
|
721 done
|
pascal@273
|
722 echo $file
|
pascal@273
|
723 done < $PACKAGE/files.list > $TMP_DIR/files2remove.list
|
pascal@273
|
724 fi
|
al@694
|
725
|
pascal@21
|
726 # Remember modified packages
|
al@694
|
727 {
|
al@694
|
728 check=false
|
al@694
|
729 for i in $(fgrep -v [ $TMP_DIR/files.list); do
|
al@694
|
730 [ -e "$ROOT$i" ] || continue
|
al@694
|
731 [ -d "$ROOT$i" ] && continue
|
al@694
|
732 echo "- $i"
|
al@694
|
733 check=true
|
al@694
|
734 done ;
|
al@694
|
735 $check && \
|
al@694
|
736 for i in *; do
|
al@694
|
737 [ "$i" == "$PACKAGE" ] && continue
|
al@694
|
738 [ -s $i/files.list ] || continue
|
al@694
|
739 awk "{ printf \"$i %s\\n\",\$1 }" < $i/files.list
|
al@694
|
740 done;
|
al@694
|
741 } | awk '
|
pascal@299
|
742 {
|
pascal@299
|
743 if ($1 == "-" || file[$2] != "") {
|
pascal@299
|
744 file[$2] = file[$2] " " $1
|
pascal@299
|
745 if ($1 != "-") {
|
pascal@299
|
746 if (pkg[$1] == "") all = all " " $1
|
pascal@299
|
747 pkg[$1] = pkg[$1] " " $2
|
pascal@299
|
748 }
|
pascal@299
|
749 }
|
pascal@299
|
750 }
|
pascal@299
|
751 END {
|
pascal@299
|
752 for (i = split(all, p, " "); i > 0; i--)
|
pascal@299
|
753 for (j = split(pkg[p[i]], f, " "); j > 0; j--)
|
pascal@299
|
754 printf "%s %s\n",p[i],f[j];
|
pascal@299
|
755 }
|
pascal@299
|
756 ' | while read dir file; do
|
pascal@299
|
757 if grep -qs ^$dir$ $PACKAGE/modifiers; then
|
pascal@299
|
758 # Do not overload an overloaded file !
|
pascal@299
|
759 rm $TMP_DIR$file 2> /dev/null
|
pascal@299
|
760 continue
|
pascal@299
|
761 fi
|
pascal@299
|
762 grep -qs ^$PACKAGE$ $dir/modifiers && continue
|
pascal@299
|
763 if [ -s "$dir/volatile.cpio.gz" ]; then
|
pascal@299
|
764 # We can modify backed up files without notice
|
gokhlayeh@383
|
765 zcat $dir/volatile.cpio.gz | cpio -t --quiet | \
|
pascal@299
|
766 grep -q "^${file#/}$" && continue
|
pascal@299
|
767 fi
|
pascal@299
|
768 echo "$PACKAGE" >> $dir/modifiers
|
pascal@21
|
769 done
|
pascal@299
|
770
|
pascal@273
|
771 cd $TMP_DIR
|
pascal@20
|
772 cp receipt files.list $ROOT$INSTALLED/$PACKAGE
|
al@694
|
773
|
pascal@20
|
774 # Copy the description if found.
|
pankso@6
|
775 if [ -f "description.txt" ]; then
|
pascal@20
|
776 cp description.txt $ROOT$INSTALLED/$PACKAGE
|
pankso@6
|
777 fi
|
al@694
|
778
|
pascal@128
|
779 # Copy the md5sum if found.
|
slaxemulator@588
|
780 if [ -f "$CHECKSUM" ]; then
|
slaxemulator@588
|
781 cp $CHECKSUM $ROOT$INSTALLED/$PACKAGE
|
pascal@128
|
782 fi
|
al@694
|
783
|
pankso@38
|
784 # Pre install commands.
|
pankso@38
|
785 if grep -q ^pre_install $ROOT$INSTALLED/$PACKAGE/receipt; then
|
pascal@20
|
786 pre_install $ROOT
|
pankso@6
|
787 fi
|
al@712
|
788
|
al@712
|
789 if [ -n "$CONFIG_FILES" ]; then
|
pascal@144
|
790 # save 'official' configuration files
|
al@702
|
791 action 'Saving configuration files...'
|
pascal@144
|
792 for i in $CONFIG_FILES; do
|
pascal@539
|
793 { cd fs ; find ${i#/} -type f 2> /dev/null; cd ..; }
|
gokhlayeh@416
|
794 done | { cd fs ; cpio -o -H newc --quiet | gzip -9; cd ..; } > \
|
pascal@144
|
795 $ROOT$INSTALLED/$PACKAGE/volatile.cpio.gz
|
al@694
|
796
|
al@712
|
797 if [ -z "$newconf" ]; then
|
al@712
|
798 # keep user configuration files
|
al@712
|
799 for i in $CONFIG_FILES; do
|
al@712
|
800 { cd fs ; find ${i#/} -type f 2> /dev/null; cd ..; }
|
al@712
|
801 done | while read i; do
|
al@712
|
802 [ -e $ROOT/$i ] || continue
|
al@712
|
803 cp -a $ROOT/$i fs/$i
|
al@712
|
804 done
|
al@712
|
805 fi
|
pascal@144
|
806 status
|
pascal@144
|
807 fi
|
al@694
|
808
|
al@702
|
809 action 'Installing package...'
|
al@677
|
810 [ "$(busybox ls fs/* 2> /dev/null)" ] && cp -a fs/* $ROOT/
|
pankso@6
|
811 status
|
al@694
|
812
|
pascal@273
|
813 if [ -s files2remove.list ]; then
|
al@702
|
814 action 'Removing old package...'
|
pascal@273
|
815 while read file; do
|
pascal@299
|
816 remove_with_path $ROOT$file
|
pascal@273
|
817 done < files2remove.list
|
pascal@299
|
818 true
|
pascal@273
|
819 status
|
pascal@273
|
820 fi
|
al@694
|
821
|
pankso@6
|
822 # Remove the temporary random directory.
|
al@603
|
823 action "Removing all tmp files..."
|
al@694
|
824 cd ..; rm -rf $TMP_DIR
|
pankso@6
|
825 status
|
al@694
|
826
|
pankso@38
|
827 # Post install commands.
|
pankso@38
|
828 if grep -q ^post_install $ROOT$INSTALLED/$PACKAGE/receipt; then
|
pascal@20
|
829 post_install $ROOT
|
pankso@6
|
830 fi
|
al@694
|
831
|
al@694
|
832 # Update-desktop-database if needed.
|
gokhlayeh@409
|
833 if [ "$(fgrep .desktop $ROOT$INSTALLED/$PACKAGE/files.list | fgrep /usr/share/applications/)" ]; then
|
gokhlayeh@356
|
834 updatedesktopdb=yes
|
gokhlayeh@356
|
835 fi
|
al@694
|
836
|
slaxemulator@369
|
837 # Update-mime-database if needed.
|
gokhlayeh@409
|
838 if [ "$(fgrep /usr/share/mime $ROOT$INSTALLED/$PACKAGE/files.list)" ]; then
|
slaxemulator@369
|
839 updatemimedb=yes
|
slaxemulator@369
|
840 fi
|
al@694
|
841
|
slaxemulator@567
|
842 # Update-icon-database
|
slaxemulator@567
|
843 if [ "$(fgrep /usr/share/icon/hicolor $ROOT$INSTALLED/$PACKAGE/files.list)" ]; then
|
slaxemulator@567
|
844 updateicondb=yes
|
slaxemulator@567
|
845 fi
|
al@694
|
846
|
slaxemulator@534
|
847 # Compile glib schemas if needed.
|
slaxemulator@534
|
848 if [ "$(fgrep /usr/share/glib-2.0/schemas $ROOT$INSTALLED/$PACKAGE/files.list)" ]; then
|
slaxemulator@534
|
849 compile_schemas=yes
|
slaxemulator@534
|
850 fi
|
al@694
|
851
|
slaxemulator@588
|
852 # Update depmod list
|
slaxemulator@591
|
853 if [ "$(fgrep /lib/modules $ROOT$INSTALLED/$PACKAGE/files.list)" ]; then
|
slaxemulator@588
|
854 updatedepmod=yes
|
slaxemulator@588
|
855 fi
|
al@694
|
856
|
al@701
|
857 # Update installed.info
|
al@701
|
858 SIZES=$(echo $PACKED_SIZE $UNPACKED_SIZE | sed 's|\.0||g')
|
al@701
|
859 DEPENDS=$(echo $DEPENDS) # remove newlines from some receipts
|
al@707
|
860 II=$PKGS_DB/installed.info
|
al@707
|
861 sed -i "/^$PACKAGE /d" $II # remove old entry
|
al@707
|
862 cat >> $II << EOT
|
al@701
|
863 $PACKAGE $VERSION$EXTRAVERSION $CATEGORY $SHORT_DESC $WEB_SITE $TAGS $SIZES $DEPENDS
|
al@701
|
864 EOT
|
al@707
|
865 TEMP_FILE=$(mktemp)
|
al@707
|
866 sort $II > $TEMP_FILE; mv -f $TEMP_FILE $II; chmod a+r $II; unset II
|
al@701
|
867
|
pankso@6
|
868 cd $TOP_DIR
|
al@702
|
869 footer "$(_ 'Package "%s" (%s) is installed.' $PACKAGE $VERSION$EXTRAVERSION)"
|
al@694
|
870
|
pascal@183
|
871 # Log this activity
|
al@603
|
872 [ -n "$ROOT" ] || log_pkg Installed
|
pankso@6
|
873 }
|
pankso@6
|
874
|
al@694
|
875
|
pascal@648
|
876 # This function may be called by a get script.
|
al@694
|
877
|
pascal@648
|
878 abort_package()
|
pascal@648
|
879 {
|
pascal@648
|
880 cd $CUR_DIR
|
pascal@648
|
881 rm -rf $TMP_DIR
|
pascal@648
|
882 echo "${1:-Abort $PACKAGE.}"
|
pascal@648
|
883 exit 1
|
pascal@648
|
884 }
|
pascal@648
|
885
|
al@694
|
886
|
paul@662
|
887 # This function installs a package from a get script in the rootfs.
|
al@694
|
888
|
pascal@648
|
889 install_package_from_get_script()
|
pascal@648
|
890 {
|
pascal@648
|
891 SCRIPT="$1"
|
pascal@648
|
892 ROOT="$2"
|
pascal@648
|
893 [ -d $ROOT$INSTALLED/$PACKAGE ] && exit 1
|
pascal@648
|
894
|
pascal@648
|
895 grep -q no-check-certificate $SCRIPT &&
|
pascal@648
|
896 [ ! -d $INSTALLED/wget ] && tazpkg get-install wget
|
pascal@648
|
897
|
pascal@648
|
898 mkdir -p $TMP_DIR && cd $TMP_DIR
|
pascal@679
|
899 saved=$PACKAGE
|
pankso@661
|
900 unset_receipt
|
pascal@679
|
901 PACKAGE=$saved
|
pankso@661
|
902
|
pascal@648
|
903 set -e
|
pascal@648
|
904 . $SCRIPT
|
pascal@659
|
905 set +e
|
pascal@697
|
906 cd $TMP_DIR
|
pascal@697
|
907 [ -d $PACKAGE-$VERSION ] || abort_package \
|
al@702
|
908 "$(_ 'Could not download "%s" from "%s". Exiting.' ${TARBALL:-$PACKAGE} ${WGET_URL:-$WEB_SITE})"
|
al@702
|
909
|
pascal@648
|
910 if [ ! -s $PACKAGE-$VERSION/receipt ]; then
|
pascal@648
|
911 cat > $PACKAGE-$VERSION/receipt <<EOT
|
pascal@648
|
912 # SliTaz package receipt.
|
pascal@648
|
913
|
pascal@648
|
914 PACKAGE="$PACKAGE"
|
pascal@667
|
915 VERSION="${VERSION:-unknown}"
|
pascal@648
|
916 CATEGORY="${CATEGORY:-non-free}"
|
pascal@648
|
917 WEB_SITE="$WEB_SITE"
|
pascal@648
|
918 SHORT_DESC="${SHORT_DESC:-$PACKAGE}"
|
pascal@648
|
919 MAINTAINER="${MAINTAINER:-nobody@slitaz.org}"
|
pascal@648
|
920 EOT
|
pascal@648
|
921 for i in LICENSE TARBALL WGET_URL CONFIG_FILES SUGGESTED \
|
pascal@697
|
922 PROVIDE DEPENDS HOST_ARCH TAGS EXTRA_SOURCE_FILES ; do
|
pascal@648
|
923 eval "[ -n \"\$$i\" ] && echo \"$i=\\\"\$$i\\\"\""
|
pascal@648
|
924 done >> $PACKAGE-$VERSION/receipt
|
pascal@648
|
925 fi
|
pascal@648
|
926
|
pascal@659
|
927 DEPENDS="$(unset DEPENDS; . $PACKAGE-$VERSION/receipt ; echo $DEPENDS)"
|
pascal@659
|
928 for i in $(find_depends $PACKAGE-$VERSION/fs); do
|
pascal@659
|
929 case " $DEPENDS " in
|
al@694
|
930 *\ $i\ *) continue;;
|
pascal@659
|
931 esac
|
pascal@659
|
932 grep -q '^DEPENDS="' $PACKAGE-$VERSION/receipt ||
|
pascal@659
|
933 echo 'DEPENDS=""' >> $PACKAGE-$VERSION/receipt
|
pascal@659
|
934 sed -i "s/^DEPENDS=\"/&$i /" $PACKAGE-$VERSION/receipt
|
pascal@659
|
935 done
|
pascal@659
|
936
|
pascal@648
|
937 tazpkg pack $PACKAGE-$VERSION
|
pascal@648
|
938
|
pascal@648
|
939 # Clean to save RAM memory before installation
|
pascal@648
|
940 rm -rf $PACKAGE-$VERSION
|
pascal@648
|
941
|
pascal@648
|
942 # Install pseudo package
|
pascal@648
|
943 tazpkg install $PACKAGE-$VERSION.tazpkg --root=$ROOT
|
pascal@648
|
944 mv $PACKAGE-$VERSION.tazpkg $CACHE_DIR
|
pascal@648
|
945
|
pascal@648
|
946 # Clean
|
pascal@648
|
947 cd $TOP_DIR
|
pascal@648
|
948 rm -rf $TMP_DIR
|
pascal@648
|
949 }
|
pascal@648
|
950
|
al@694
|
951
|
pascal@122
|
952 # Check for loop in deps tree.
|
al@694
|
953
|
pascal@122
|
954 check_for_deps_loop()
|
pascal@122
|
955 {
|
pascal@122
|
956 local list
|
pascal@122
|
957 local pkg
|
pascal@122
|
958 local deps
|
pascal@122
|
959 pkg=$1
|
pascal@122
|
960 shift
|
pascal@122
|
961 [ -n "$1" ] || return
|
pascal@122
|
962 list=""
|
al@694
|
963
|
pascal@122
|
964 # Filter out already processed deps
|
pascal@122
|
965 for i in $@; do
|
pascal@122
|
966 case " $ALL_DEPS" in
|
al@702
|
967 *\ $i\ *) ;;
|
al@702
|
968 *) list="$list $i";;
|
pascal@122
|
969 esac
|
pascal@122
|
970 done
|
pascal@122
|
971 ALL_DEPS="$ALL_DEPS$list "
|
pascal@122
|
972 for i in $list; do
|
pascal@122
|
973 [ -f $i/receipt ] || continue
|
pascal@122
|
974 deps="$(DEPENDS=""; . $i/receipt; echo $DEPENDS)"
|
pascal@122
|
975 case " $deps " in
|
al@702
|
976 *\ $pkg\ *) echo -e "$MSG $i"; MSG="";;
|
al@702
|
977 *) check_for_deps_loop $pkg $deps;;
|
pascal@122
|
978 esac
|
pascal@122
|
979 done
|
pascal@122
|
980 }
|
pascal@122
|
981
|
al@694
|
982
|
pankso@6
|
983 # Check for missing deps listed in a receipt packages.
|
al@694
|
984
|
pankso@6
|
985 check_for_deps()
|
pankso@6
|
986 {
|
pascal@116
|
987 local saved;
|
pascal@116
|
988 saved=$PACKAGE
|
pascal@116
|
989 mkdir -p $TMP_DIR
|
gokhlayeh@408
|
990 { cd $TMP_DIR ; cpio --quiet -i receipt > /dev/null 2>&1; } < $PACKAGE_FILE
|
pascal@116
|
991 . $TMP_DIR/receipt
|
pascal@116
|
992 PACKAGE=$saved
|
pascal@116
|
993 rm -rf $TMP_DIR
|
al@633
|
994
|
al@633
|
995 num=0
|
al@694
|
996 for pkgorg in $DEPENDS; do
|
pascal@164
|
997 i=$(equivalent_pkg $pkgorg $1)
|
pascal@120
|
998 if [ ! -d "$1$INSTALLED/$i" ]; then
|
pankso@6
|
999 MISSING_PACKAGE=$i
|
al@633
|
1000 num=$(($num+1))
|
pascal@122
|
1001 elif [ ! -f "$1$INSTALLED/$i/receipt" ]; then
|
al@702
|
1002 _ 'WARNING! Dependency loop between "%s" and "%s".' $PACKAGE $i
|
pankso@6
|
1003 fi
|
pankso@6
|
1004 done
|
al@633
|
1005
|
al@707
|
1006 if [ -n "$MISSING_PACKAGE" ]; then
|
al@702
|
1007 title "$(_ 'Tracking dependencies for package "%s"' $PACKAGE)"
|
al@694
|
1008 for pkgorg in $DEPENDS; do
|
pascal@164
|
1009 i=$(equivalent_pkg $pkgorg $1)
|
pascal@120
|
1010 if [ ! -d "$1$INSTALLED/$i" ]; then
|
pankso@6
|
1011 MISSING_PACKAGE=$i
|
al@702
|
1012 _ 'Missing package "%s"' $MISSING_PACKAGE
|
pankso@6
|
1013 fi
|
pankso@6
|
1014 done
|
al@707
|
1015 footer "$(_p \
|
al@707
|
1016 '%s missing package to install.' \
|
al@707
|
1017 '%s missing packages to install.' $num \
|
al@707
|
1018 $num)"
|
pankso@6
|
1019 fi
|
pankso@6
|
1020 }
|
pankso@6
|
1021
|
al@694
|
1022
|
pankso@598
|
1023 # Install all missing deps. Auto install or ask user then install all missing
|
pankso@308
|
1024 # deps from local dir, cdrom, media or from the mirror. In case we want to
|
pankso@6
|
1025 # install packages from local, we need a packages.list to find the version.
|
al@694
|
1026
|
pankso@6
|
1027 install_deps()
|
pankso@6
|
1028 {
|
pascal@120
|
1029 local root
|
pascal@120
|
1030 root=""
|
pascal@121
|
1031 [ -n "$1" ] && root="--root=$1"
|
pankso@308
|
1032 if [ "$AUTO_INSTALL_DEPS" == "yes" ]; then
|
al@603
|
1033 answer=0
|
pankso@308
|
1034 else
|
pankso@600
|
1035 newline
|
al@696
|
1036 confirm "$(_ 'Install all missing dependencies? (y/N)')"
|
al@603
|
1037 answer=$?
|
pankso@600
|
1038 newline
|
pankso@308
|
1039 fi
|
psychomaniak@709
|
1040 if [ $answer = 0 ] && ! [ "$nodeps" ]; then
|
al@694
|
1041 for pkgorg in $DEPENDS; do
|
pascal@164
|
1042 pkg=$(equivalent_pkg $pkgorg $1)
|
pascal@120
|
1043 if [ ! -d "$1$INSTALLED/$pkg" ]; then
|
pascal@121
|
1044 local list
|
pascal@121
|
1045 list="$INSTALL_LIST"
|
pascal@121
|
1046 [ -n "$list" ] || list="$TOP_DIR/packages.list"
|
pankso@6
|
1047 # We can install packages from a local dir by greping
|
pankso@6
|
1048 # the TAZPKG_BASENAME in the local packages.list.
|
pascal@153
|
1049 found=0
|
pascal@121
|
1050 if [ -f "$list" ]; then
|
al@702
|
1051 _ 'Checking if package "%s" exists in local list...' $pkg
|
pascal@110
|
1052 mkdir $TMP_DIR
|
pascal@110
|
1053 for i in $pkg-*.tazpkg; do
|
pascal@124
|
1054 [ -f $i ] || continue
|
gokhlayeh@408
|
1055 { cd $TMP_DIR ; cpio --quiet -i receipt > /dev/null 2>&1; } < $i
|
pascal@153
|
1056 [ "$(. $TMP_DIR/receipt; echo $PACKAGE)" = "$pkg" ] || continue
|
pascal@121
|
1057 if grep -q ^$(package_fullname_in_dir $TMP_DIR).tazpkg$ $list
|
pascal@110
|
1058 then
|
pascal@153
|
1059 found=1
|
pascal@121
|
1060 tazpkg install $i $root --list=$list
|
pascal@110
|
1061 break
|
pascal@110
|
1062 fi
|
pascal@110
|
1063 done
|
pascal@110
|
1064 rm -rf $TMP_DIR
|
pascal@153
|
1065 fi
|
pankso@6
|
1066 # Install deps from the mirror.
|
pascal@153
|
1067 if [ $found -eq 0 ]; then
|
al@700
|
1068 if [ ! -f "$PKGS_DB/packages.list" ]; then
|
pankso@6
|
1069 tazpkg recharge
|
pankso@6
|
1070 fi
|
pascal@120
|
1071 tazpkg get-install $pkg $root
|
pankso@6
|
1072 fi
|
pankso@6
|
1073 fi
|
pankso@6
|
1074 done
|
pankso@6
|
1075 else
|
pankso@600
|
1076 newline
|
al@702
|
1077 _ 'Leaving dependencies for package "%s" unresolved.' $PACKAGE
|
al@702
|
1078 _ 'The package is installed but will probably not work.'
|
pankso@600
|
1079 newline
|
pankso@6
|
1080 fi
|
pankso@6
|
1081 }
|
pankso@6
|
1082
|
al@694
|
1083
|
pankso@279
|
1084 # Search pattern in installed packages.
|
al@694
|
1085
|
pankso@54
|
1086 search_in_installed_packages()
|
pankso@54
|
1087 {
|
al@694
|
1088 _ 'Installed packages'
|
slaxemulator@475
|
1089 separator
|
al@633
|
1090 num=0
|
al@702
|
1091 for pkg in $(ls -1 $INSTALLED | grep -i "$PATTERN"); do
|
pascal@114
|
1092 EXTRAVERSION=""
|
pascal@122
|
1093 [ -f $INSTALLED/$pkg/receipt ] || continue
|
pankso@54
|
1094 . $INSTALLED/$pkg/receipt
|
al@694
|
1095 emsg "$PACKAGE<i 24> $VERSION$EXTRAVERSION<i 42> $(_n $CATEGORY)"
|
al@633
|
1096 num=$(($num+1))
|
pankso@54
|
1097 done
|
al@694
|
1098
|
al@707
|
1099 footer "$(_p \
|
al@707
|
1100 '%s installed package found for "%s"' \
|
al@707
|
1101 '%s installed packages found for "%s"' $num \
|
al@707
|
1102 $num "$PATTERN")"
|
pankso@54
|
1103 }
|
pankso@54
|
1104
|
al@694
|
1105
|
pankso@279
|
1106 # Search in packages.list for available pkgs.
|
al@694
|
1107
|
pankso@54
|
1108 search_in_packages_list()
|
pankso@54
|
1109 {
|
al@707
|
1110 _ 'Available packages'
|
slaxemulator@475
|
1111 separator
|
al@633
|
1112 num=0
|
al@694
|
1113 BPATTERN="$(emsg "<b>$PATTERN</b>")"
|
al@700
|
1114 for i in $PKGS_DB/packages.list $PKGS_DB/undigest/*/packages.list; do
|
al@694
|
1115 grep -is "$PATTERN" $i | sed "s|$PATTERN|$BPATTERN|"
|
al@633
|
1116 num=$(($num + `grep -is "$PATTERN" $i | wc -l`))
|
pascal@187
|
1117 done
|
al@700
|
1118 if [ ! -f "$PKGS_DB/packages.list" ]; then
|
pankso@600
|
1119 newline
|
al@707
|
1120 longline "$(_ \
|
al@707
|
1121 "No \"%s\" found to check for mirrored packages. For more results, please run \
|
al@707
|
1122 \"%s\" once as root before searching." packages.list 'tazpkg recharge')"
|
pankso@600
|
1123 newline
|
pankso@54
|
1124 fi
|
al@707
|
1125 footer "$(_p \
|
al@707
|
1126 '%s available package found for "%s"' \
|
al@707
|
1127 '%s available packages found for "%s"' $num \
|
al@707
|
1128 $num $PATTERN)"
|
pankso@54
|
1129 }
|
pankso@54
|
1130
|
al@694
|
1131
|
pankso@279
|
1132 # search --mirror: Search in packages.txt for available pkgs and give more
|
pankso@279
|
1133 # info than --list or default.
|
al@694
|
1134
|
pankso@54
|
1135 search_in_packages_txt()
|
pankso@54
|
1136 {
|
al@694
|
1137 _ 'Matching packages name with version and desc'
|
slaxemulator@475
|
1138 separator
|
al@633
|
1139 num=0
|
al@700
|
1140 for i in $PKGS_DB/packages.txt $PKGS_DB/undigest/*/packages.txt; do
|
pascal@187
|
1141 grep -is -A 2 "^$PATTERN" $i
|
al@633
|
1142 num=$(($num + `grep -is "^$PATTERN" $i | wc -l`))
|
pascal@187
|
1143 done
|
al@700
|
1144 if [ ! -f "$PKGS_DB/packages.txt" ]; then
|
pankso@600
|
1145 newline
|
al@707
|
1146 longline "$(_ \
|
al@707
|
1147 "No \"%s\" found to check for mirrored packages. For more results, please run \
|
al@707
|
1148 \"%s\" once as root before searching." packages.txt 'tazpkg recharge')"
|
pankso@600
|
1149 newline
|
pankso@54
|
1150 fi
|
al@707
|
1151 footer "$(_p \
|
al@707
|
1152 '%s available package found for "%s"' \
|
al@707
|
1153 '%s available packages found for "%s"' $num \
|
al@707
|
1154 $num $PATTERN)"
|
pankso@54
|
1155 }
|
pankso@54
|
1156
|
al@694
|
1157
|
pascal@74
|
1158 # Install package-list from a flavor
|
al@694
|
1159
|
pascal@74
|
1160 install_flavor()
|
pascal@74
|
1161 {
|
al@603
|
1162 check_root $@
|
pankso@598
|
1163
|
gokhlayeh@386
|
1164 # Get repositories priority list.
|
gokhlayeh@386
|
1165 look_for_priority
|
pankso@598
|
1166
|
pascal@74
|
1167 FLAVOR=$1
|
pascal@74
|
1168 ARG=$2
|
pascal@74
|
1169 mkdir -p $TMP_DIR
|
pascal@74
|
1170 [ -f $FLAVOR.flavor ] && cp $FLAVOR.flavor $TMP_DIR
|
pascal@74
|
1171 cd $TMP_DIR
|
pascal@74
|
1172 if [ -f $FLAVOR.flavor ] || download $FLAVOR.flavor; then
|
pascal@643
|
1173 zcat < $FLAVOR.flavor | cpio --quiet -i >/dev/null
|
al@694
|
1174
|
pascal@74
|
1175 while read file; do
|
pascal@74
|
1176 for pkg in $(ls -d $INSTALLED/${file%%-*}*); do
|
pascal@122
|
1177 [ -f $pkg/receipt ] || continue
|
pascal@114
|
1178 EXTRAVERSION=""
|
pascal@74
|
1179 . $pkg/receipt
|
pascal@114
|
1180 [ "$PACKAGE-$VERSION$EXTRAVERSION" = "$file" ] && break
|
pascal@74
|
1181 done
|
pascal@114
|
1182 [ "$PACKAGE-$VERSION$EXTRAVERSION" = "$file" ] && continue
|
pascal@74
|
1183 cd $CACHE_DIR
|
pascal@74
|
1184 download $file.tazpkg
|
pascal@74
|
1185 cd $TMP_DIR
|
al@694
|
1186 tazpkg install $CACHE_DIR/$file.tazpkg --forced
|
pascal@74
|
1187 done < $FLAVOR.pkglist
|
al@694
|
1188
|
pascal@75
|
1189 [ -f $FLAVOR.nonfree ] && while read pkg; do
|
pascal@75
|
1190 [ -d $INSTALLED/$pkg ] || continue
|
pascal@75
|
1191 [ -d $INSTALLED/get-$pkg ] && tazpkg get-install get-$pkg
|
pascal@75
|
1192 get-$pkg
|
pascal@75
|
1193 done < $FLAVOR.nonfree
|
al@694
|
1194
|
pascal@74
|
1195 [ "$ARG" == "--purge" ] && for pkg in $(ls $INSTALLED); do
|
pascal@122
|
1196 [ -f $INSTALLED/$pkg/receipt ] || continue
|
pascal@114
|
1197 EXTRAVERSION=""
|
pascal@74
|
1198 . $INSTALLED/$pkg/receipt
|
pascal@114
|
1199 grep -q ^$PACKAGE-$VERSION$EXTRAVERSION$ $FLAVOR.pkglist && continue
|
pascal@75
|
1200 grep -qs ^$PACKAGE$ $FLAVOR.nonfree && continue
|
pascal@74
|
1201 tazpkg remove $PACKAGE
|
pascal@74
|
1202 done
|
pascal@74
|
1203 else
|
al@702
|
1204 _ "Can't find flavor \"%s\". Abort." $FLAVOR
|
pascal@74
|
1205 fi
|
pascal@74
|
1206 cd $TOP_DIR
|
pascal@74
|
1207 rm -rf $TMP_DIR
|
pascal@74
|
1208 }
|
pascal@74
|
1209
|
al@694
|
1210
|
pascal@187
|
1211 # Update mirror urls
|
al@694
|
1212
|
pascal@187
|
1213 setup_mirror()
|
pascal@187
|
1214 {
|
pascal@187
|
1215 # Backup old list.
|
pascal@187
|
1216 if [ -f "$1/mirror" ]; then
|
pascal@187
|
1217 cp -f $1/mirror $1/mirror.bak
|
pascal@187
|
1218 fi
|
al@603
|
1219 title 'Current mirror(s)'
|
pascal@187
|
1220 echo " `cat $1/mirror 2> /dev/null`"
|
al@707
|
1221 longline "$(_ \
|
al@707
|
1222 "Please enter URL of the new mirror (http, ftp or local path). You must specify \
|
al@707
|
1223 the complete address to the directory of the packages and packages.list file.")"
|
pankso@600
|
1224 newline
|
al@694
|
1225 _n 'New mirror(s) URL: '
|
pascal@187
|
1226 NEW_MIRROR_URL=$2
|
pascal@187
|
1227 if [ -n "$NEW_MIRROR_URL" ]; then
|
pascal@187
|
1228 echo $NEW_MIRROR_URL
|
pascal@187
|
1229 else
|
pascal@187
|
1230 read NEW_MIRROR_URL
|
pascal@187
|
1231 fi
|
pascal@187
|
1232 if [ "$NEW_MIRROR_URL" = "" ]; then
|
al@694
|
1233 _ 'Nothing has been changed.'
|
pascal@187
|
1234 else
|
al@702
|
1235 _ 'Setting mirror(s) to: "%s"' $NEW_MIRROR_URL
|
pascal@187
|
1236 rm -f $1/mirror
|
pascal@187
|
1237 for i in $NEW_MIRROR_URL; do
|
pascal@685
|
1238 echo "${i%/}/" >> $1/mirror
|
pankso@279
|
1239 done
|
pascal@187
|
1240 fi
|
pankso@600
|
1241 newline
|
pascal@187
|
1242 }
|
pascal@187
|
1243
|
al@694
|
1244
|
paul@247
|
1245 # recursive dependencies scan
|
al@694
|
1246
|
pascal@205
|
1247 dep_scan()
|
pascal@205
|
1248 {
|
al@694
|
1249 for i in $1; do
|
al@694
|
1250 case " $ALL_DEPS " in
|
al@694
|
1251 *\ $i\ *) continue;;
|
al@694
|
1252 esac
|
al@694
|
1253 ALL_DEPS="$ALL_DEPS $i"
|
al@700
|
1254 [ -n "$2" ] && echo "$2$i ($(fgrep -A 3 $i $PKGS_DB/packages.txt | \
|
al@694
|
1255 tail -1 | sed 's/.*(\([^ ]*\).*/\1/'))"
|
al@694
|
1256 [ -f $i/receipt ] || continue
|
al@694
|
1257 DEPENDS=""
|
al@694
|
1258 . $i/receipt
|
al@694
|
1259 [ -n "$DEPENDS" ] && dep_scan "$DEPENDS" "$2 "
|
al@694
|
1260 done
|
pascal@205
|
1261 }
|
pascal@205
|
1262
|
al@694
|
1263
|
paul@247
|
1264 # recursive reverse dependencies scan
|
al@694
|
1265
|
pascal@205
|
1266 rdep_scan()
|
pascal@205
|
1267 {
|
al@694
|
1268 SEARCH=$1
|
al@694
|
1269
|
al@694
|
1270 for i in * ; do
|
al@694
|
1271 DEPENDS=""
|
al@694
|
1272 . $i/receipt
|
al@694
|
1273 echo "$i $(echo $DEPENDS)"
|
al@694
|
1274 done | busybox awk -v search=$SEARCH '
|
pascal@260
|
1275 function show_deps(deps, all_deps, pkg, space)
|
pascal@260
|
1276 {
|
pascal@260
|
1277 if (all_deps[pkg] == 1) return
|
pascal@260
|
1278 all_deps[pkg] = 1
|
pascal@304
|
1279 if (space != "") printf "%s %s\n",space,pkg
|
pascal@299
|
1280 for (i = 1, n = split(deps[pkg], mydeps, " "); i <= n; i++) {
|
pascal@304
|
1281 show_deps(deps, all_deps, mydeps[i],"==" space)
|
pascal@260
|
1282 }
|
pascal@260
|
1283 }
|
pascal@260
|
1284
|
pascal@260
|
1285 {
|
pascal@260
|
1286 all_deps[$1] = 0
|
pascal@260
|
1287 for (i = 2; i <= NF; i++)
|
pascal@260
|
1288 deps[$i] = deps[$i] " " $1
|
pascal@260
|
1289 }
|
pascal@260
|
1290
|
pascal@260
|
1291 END {
|
pascal@260
|
1292 show_deps(deps, all_deps, search, "")
|
pascal@260
|
1293 }
|
pascal@304
|
1294 ' | while read spc pkg; do
|
al@694
|
1295 echo -n $spc | sed 's/=/ /g'
|
al@694
|
1296 echo -n $pkg
|
al@694
|
1297 echo -n ' ('
|
al@700
|
1298 fgrep -A 3 $pkg $PKGS_DB/packages.txt | tail -1 | \
|
al@694
|
1299 sed 's/.*(\([^ ]*\).*/\1)/'
|
al@694
|
1300 done
|
pascal@205
|
1301 }
|
pascal@205
|
1302
|
al@694
|
1303
|
gokhlayeh@356
|
1304 update_desktop_database()
|
gokhlayeh@356
|
1305 {
|
gokhlayeh@382
|
1306 if [ -f $1/usr/bin/update-desktop-database ] && [ -n "$updatedesktopdb" ]; then
|
pascal@578
|
1307 chroot "$1/" /usr/bin/update-desktop-database /usr/share/applications 2>/dev/null
|
gokhlayeh@356
|
1308 fi
|
gokhlayeh@356
|
1309 }
|
gokhlayeh@356
|
1310
|
al@694
|
1311
|
slaxemulator@369
|
1312 update_mime_database()
|
slaxemulator@369
|
1313 {
|
slaxemulator@394
|
1314 if [ -f $1/usr/bin/update-mime-database ] && [ -n "$updatemimedb" ]; then
|
pascal@578
|
1315 chroot "$1/" /usr/bin/update-mime-database /usr/share/mime
|
slaxemulator@369
|
1316 fi
|
slaxemulator@369
|
1317 }
|
slaxemulator@369
|
1318
|
al@694
|
1319
|
slaxemulator@567
|
1320 update_icon_database()
|
slaxemulator@567
|
1321 {
|
slaxemulator@567
|
1322 if [ -f $1/usr/bin/gtk-update-icon-cache ] && [ -n "$updateicondb" ]; then
|
pascal@578
|
1323 chroot "$1/" /usr/bin/gtk-update-icon-cache /usr/share/icons/hicolor
|
slaxemulator@567
|
1324 fi
|
slaxemulator@567
|
1325 }
|
slaxemulator@567
|
1326
|
al@694
|
1327
|
slaxemulator@534
|
1328 compile_glib_schemas()
|
slaxemulator@534
|
1329 {
|
slaxemulator@534
|
1330 if [ -f $1/usr/bin/glib-compile-schemas ] && [ -n "$compile_schemas" ]; then
|
pascal@578
|
1331 chroot "$1/" /usr/bin/glib-compile-schemas /usr/share/glib-2.0/schemas
|
slaxemulator@534
|
1332 fi
|
slaxemulator@534
|
1333 }
|
slaxemulator@534
|
1334
|
al@694
|
1335
|
slaxemulator@588
|
1336 update_kernel_modules()
|
slaxemulator@588
|
1337 {
|
slaxemulator@588
|
1338 if [ -f $1/sbin/depmod ] && [ -n "$updatedepmod" ]; then
|
slaxemulator@588
|
1339 chroot "$1/" /sbin/depmod -a
|
slaxemulator@588
|
1340 fi
|
slaxemulator@588
|
1341 }
|
slaxemulator@588
|
1342
|
al@694
|
1343
|
al@694
|
1344
|
al@694
|
1345
|
al@694
|
1346
|
pankso@6
|
1347 ###################
|
pankso@653
|
1348 # TazPKG commands #
|
pankso@6
|
1349 ###################
|
pankso@6
|
1350
|
pankso@6
|
1351 case "$COMMAND" in
|
pankso@504
|
1352 list|-l)
|
al@701
|
1353 # List all installed packages or a specific category.
|
al@603
|
1354 shift
|
al@701
|
1355 check_for_installed_info
|
al@701
|
1356
|
al@701
|
1357 case $1 in
|
al@701
|
1358 b|blocked)
|
al@701
|
1359 # Display the list of blocked packages.
|
al@701
|
1360 title 'Blocked packages'
|
al@701
|
1361 if [ -s "$BLOCKED" ];then
|
al@701
|
1362 cat $BLOCKED
|
al@701
|
1363 else
|
al@701
|
1364 _ 'No blocked packages found.'
|
pankso@6
|
1365 fi
|
al@701
|
1366 newline; exit 0
|
al@701
|
1367 ;;
|
al@701
|
1368 c|cat|categories)
|
al@701
|
1369 # Display the list of categories.
|
al@701
|
1370 title 'Packages categories'
|
al@701
|
1371 echo "$PKGS_CATEGORIES" | sed 's|[^a-z-]|\n|g; /^$/d' | \
|
al@701
|
1372 sed 's|\(.*\)|\1'$'\033''[15G \1|' | translate_category
|
al@701
|
1373 num=$(echo -n "$PKGS_CATEGORIES" | wc -l)
|
al@707
|
1374 footer "$(_p \
|
al@707
|
1375 '%s category' \
|
al@707
|
1376 '%s categories' $num \
|
al@707
|
1377 $num)"
|
al@701
|
1378 exit 0
|
al@701
|
1379 ;;
|
al@701
|
1380 '')
|
al@701
|
1381 # By default list all packages and versions.
|
al@701
|
1382 title 'List of all installed packages'
|
al@701
|
1383 TMPLIST=$(mktemp)
|
al@701
|
1384 awk -F$'\t' '{print $1"\033[35G "$2"\033[53G "$3}' \
|
al@701
|
1385 $PKGS_DB/installed.info | tee $TMPLIST | translate_category
|
al@701
|
1386
|
al@701
|
1387 packages=$(wc -l $TMPLIST | awk '{print $1}'); rm $TMPLIST
|
al@707
|
1388 footer "$(emsg $(_p \
|
al@707
|
1389 '%s package installed.' \
|
al@707
|
1390 '%s packages installed.' $packages \
|
al@707
|
1391 "<c 32>$packages</c>"))"
|
al@701
|
1392 ;;
|
al@701
|
1393 *)
|
al@701
|
1394 # Check for an asked category.
|
al@701
|
1395 ASKED_CATEGORY_I18N="$@"
|
al@701
|
1396 ASKED_CATEGORY=$(reverse_translate_category "$ASKED_CATEGORY_I18N")
|
al@702
|
1397 title 'Installed packages of category "%s"' $ASKED_CATEGORY_I18N
|
al@701
|
1398 TMPLIST=$(mktemp)
|
al@701
|
1399 awk -F$'\t' '
|
al@701
|
1400 {
|
al@701
|
1401 if ($3 == "'$ASKED_CATEGORY'")
|
al@701
|
1402 print $1"\033[35G "$2
|
al@701
|
1403 }' \
|
al@701
|
1404 $PKGS_DB/installed.info | tee $TMPLIST | translate_category
|
al@701
|
1405
|
al@701
|
1406 packages=$(wc -l $TMPLIST | awk '{print $1}'); rm $TMPLIST
|
al@707
|
1407 footer "$(emsg $(_p \
|
al@707
|
1408 '%s package installed of category "%s".' \
|
al@707
|
1409 '%s packages installed of category "%s".' $packages \
|
al@707
|
1410 "<c 32>$packages</c>" "<c 34>$ASKED_CATEGORY_I18N</c>"))"
|
al@701
|
1411 ;;
|
al@701
|
1412 esac ;;
|
al@694
|
1413
|
pankso@600
|
1414 list-mirror|-lm)
|
paul@247
|
1415 # List all available packages on the mirror. Option --diff displays
|
pankso@6
|
1416 # last mirrored packages diff (see recharge).
|
pankso@6
|
1417 check_for_packages_list
|
pankso@53
|
1418 case $2 in
|
pankso@53
|
1419 --diff)
|
al@700
|
1420 if [ -f "$PKGS_DB/packages.diff" ]; then
|
al@603
|
1421 title 'Mirrored packages diff'
|
al@700
|
1422 cat $PKGS_DB/packages.diff
|
al@700
|
1423 num=$(wc -l < $PKGS_DB/packages.diff)
|
al@707
|
1424 footer "$(_p \
|
al@707
|
1425 '%s new package listed on the mirror.' \
|
al@707
|
1426 '%s new packages listed on the mirror.' $num \
|
al@707
|
1427 $num)"
|
pankso@53
|
1428 else
|
pankso@600
|
1429 newline
|
al@694
|
1430 _ 'Unable to list anything, no packages.diff found.'
|
al@694
|
1431 _ 'Recharge your current list to create a first diff.'
|
pankso@600
|
1432 newline
|
al@694
|
1433 fi; exit 0 ;;
|
al@603
|
1434 --text|--txt|--raw|*)
|
al@603
|
1435 title 'List of available packages on the mirror'
|
al@700
|
1436 cat $PKGS_DB/packages.txt ;;
|
pankso@53
|
1437 esac
|
al@700
|
1438 pkgs=$(wc -l < $PKGS_DB/packages.list)
|
al@707
|
1439 footer "$(emsg "$(_p \
|
al@707
|
1440 '%s package in the last recharged list.' \
|
al@707
|
1441 '%s packages in the last recharged list.' $pkgs \
|
al@707
|
1442 "<c 32>$pkgs</c>")")"
|
al@603
|
1443 ;;
|
al@694
|
1444
|
al@694
|
1445
|
pankso@600
|
1446 list-files|-lf)
|
pankso@6
|
1447 # List files installed with the package.
|
pankso@6
|
1448 check_for_package_on_cmdline
|
pankso@6
|
1449 check_for_receipt
|
al@702
|
1450 title 'Installed files by "%s"' $PACKAGE
|
pascal@648
|
1451 sort < $INSTALLED/$PACKAGE/files.list
|
mojo@664
|
1452 files=$(wc -l < $INSTALLED/$PACKAGE/files.list)
|
al@707
|
1453 footer "$(emsg "$(_p \
|
al@707
|
1454 '%s file' '%s files' $files \
|
al@707
|
1455 "<c 32>$files</c>")")"
|
al@603
|
1456 ;;
|
al@694
|
1457
|
al@694
|
1458
|
pankso@6
|
1459 info)
|
pascal@119
|
1460 # Information about package.
|
pankso@6
|
1461 check_for_package_on_cmdline
|
pankso@6
|
1462 check_for_receipt
|
pascal@114
|
1463 EXTRAVERSION=""
|
pankso@6
|
1464 . $INSTALLED/$PACKAGE/receipt
|
pankso@653
|
1465 title 'TazPKG information'
|
al@622
|
1466 # Display localized short description
|
al@702
|
1467 for LC in $LANG ${LANG%_*}; do
|
al@702
|
1468 if [ -e "$PKGS_DB/packages-desc.$LC" ]; then
|
al@702
|
1469 LOCDESC=$(grep -e "^$PACKAGE " $PKGS_DB/packages-desc.$LC | cut -d' ' -f2)
|
al@702
|
1470 [ -n "$LOCDESC" ] && SHORT_DESC="$LOCDESC"
|
al@702
|
1471 fi
|
al@702
|
1472 done
|
al@702
|
1473 emsg "$(
|
al@702
|
1474 {
|
al@702
|
1475 _ 'Package : %s' "$PACKAGE"
|
al@702
|
1476 _ 'Version : %s' "$VERSION$EXTRAVERSION"
|
al@702
|
1477 _ 'Category : %s' "$(_ $CATEGORY)"
|
al@702
|
1478 _ 'Short desc : %s' "$SHORT_DESC"
|
al@702
|
1479 _ 'Maintainer : %s' "$MAINTAINER"
|
al@702
|
1480 _ 'License : %s' "$LICENSE"
|
al@702
|
1481 _ 'Depends : %s' "$DEPENDS"
|
al@702
|
1482 _ 'Suggested : %s' "$SUGGESTED"
|
al@702
|
1483 _ 'Build deps : %s' "$BUILD_DEPENDS"
|
al@702
|
1484 _ 'Wanted src : %s' "$WANTED"
|
al@702
|
1485 _ 'Web site : %s' "$WEB_SITE"
|
al@702
|
1486 _ 'Tags : %s' "$TAGS"
|
al@702
|
1487 } | sed '/: $/d; s|^\([^:]*\):|<b>\1:</b>|')"
|
pankso@654
|
1488 footer ;;
|
al@694
|
1489
|
al@694
|
1490
|
pankso@6
|
1491 desc)
|
pankso@6
|
1492 # Display package description.txt if available.
|
al@711
|
1493 if [ -n "$(grep -e "^$PACKAGE " $PKGS_DB/installed.info)" ]; then
|
al@702
|
1494 title 'Description of package "%s"' $PACKAGE
|
al@711
|
1495 if [ -f "$INSTALLED/$PACKAGE/description.txt" ]; then
|
al@711
|
1496 cat $INSTALLED/$PACKAGE/description.txt
|
al@711
|
1497 else
|
al@711
|
1498 awk -F$'\t' '{if ($1 == "'$PACKAGE'") print $4}' $PKGS_DB/installed.info
|
al@711
|
1499 fi
|
al@603
|
1500 footer
|
pankso@6
|
1501 else
|
al@711
|
1502 _ 'Package "%s" is not installed.' "$PACKAGE"
|
al@711
|
1503 fi
|
al@711
|
1504 ;;
|
al@694
|
1505
|
al@694
|
1506
|
pankso@654
|
1507 activity|log|-a)
|
pankso@654
|
1508 # Show activity log
|
pankso@654
|
1509 [ "$nb" ] || nb=18
|
pankso@654
|
1510 title 'TazPKG Activity'
|
pankso@654
|
1511 IFS=" "
|
al@694
|
1512 tail -n ${nb} ${LOG} | \
|
al@694
|
1513 while read date hour none action none pkg vers none; do
|
al@694
|
1514 case $action in
|
pankso@654
|
1515 Installed)
|
al@694
|
1516 action=$(colorize 32 $action) ;;
|
pankso@654
|
1517 Removed)
|
al@694
|
1518 action=$(colorize 31 $action) ;;
|
pankso@654
|
1519 *)
|
al@694
|
1520 action=$(boldify $action) ;;
|
pankso@654
|
1521 esac
|
al@694
|
1522 echo "$date $hour : $action $pkg $vers"
|
al@694
|
1523 done
|
al@694
|
1524 unset IFS
|
al@694
|
1525 footer ;;
|
al@694
|
1526
|
al@694
|
1527
|
pankso@504
|
1528 search|-s)
|
pankso@6
|
1529 # Search for a package by pattern or name.
|
pankso@54
|
1530 PATTERN="$2"
|
pankso@54
|
1531 if [ -z "$PATTERN" ]; then
|
pankso@600
|
1532 newline
|
al@694
|
1533 _ 'Please specify a pattern or package name to search for.'
|
al@694
|
1534 echo "$(_ 'Example:') 'tazpkg search paint'"
|
pankso@600
|
1535 newline
|
pankso@6
|
1536 exit 0
|
pankso@6
|
1537 fi
|
al@702
|
1538 title 'Search result for "%s"' $PATTERN
|
pankso@54
|
1539 # Default is to search in installed pkgs and the raw list.
|
pankso@654
|
1540 case "$3" in
|
pankso@54
|
1541 -i|--installed)
|
pankso@54
|
1542 search_in_installed_packages ;;
|
pankso@54
|
1543 -l|--list)
|
pankso@54
|
1544 search_in_packages_list ;;
|
pankso@54
|
1545 -m|--mirror)
|
pankso@54
|
1546 search_in_packages_txt ;;
|
pankso@54
|
1547 *)
|
pankso@54
|
1548 search_in_installed_packages
|
jozee@338
|
1549 search_in_packages_list ;;
|
pankso@309
|
1550 esac ;;
|
al@694
|
1551
|
al@694
|
1552
|
pankso@593
|
1553 search-file|-sf)
|
pankso@12
|
1554 # Search for a file by pattern or name in all files.list.
|
pankso@12
|
1555 if [ -z "$2" ]; then
|
pankso@600
|
1556 newline
|
al@694
|
1557 _ 'Please specify a pattern or file name to search for.'
|
al@694
|
1558 echo "$(_ 'Example:') 'tazpkg search-file libnss'"
|
pankso@600
|
1559 newline
|
pankso@12
|
1560 exit 0
|
pankso@12
|
1561 fi
|
al@702
|
1562 title 'Search result for file "%s"' $2
|
al@702
|
1563
|
al@702
|
1564 TMPLIST=$(mktemp)
|
pascal@98
|
1565 if [ "$3" == "--mirror" ]; then
|
pankso@279
|
1566
|
al@702
|
1567 for i in $PKGS_DB/files.list.lzma $PKGS_DB/undigest/*/files.list.lzma; do
|
al@694
|
1568 [ -f $i ] || continue
|
al@704
|
1569 lzcat $i | awk -F: -vP="$(gettext 'Package %s:')" -vT=$TMPLIST '
|
al@704
|
1570 BEGIN { last = "" }
|
al@702
|
1571 $2 ~ /'$2'/ {
|
al@702
|
1572 if (last != $1) {
|
al@702
|
1573 last = $1;
|
al@702
|
1574 PP = P;
|
al@702
|
1575 sub(/%s/, $1, PP);
|
al@702
|
1576 printf("\n\e[1;33m%s\e[0;39m\n", PP);
|
al@603
|
1577 }
|
al@702
|
1578 gsub(/'$2'/, "\e[0;32m'$2'\e[0;39m", $2);
|
al@704
|
1579 print $2;
|
al@704
|
1580 printf "%s" 1 >> T;
|
al@704
|
1581 }'
|
pascal@187
|
1582 done
|
pascal@98
|
1583
|
pascal@98
|
1584 else
|
pascal@98
|
1585
|
al@603
|
1586 # Check all pkg files.list in search match which specify the package
|
al@603
|
1587 # name and the full path to the file(s).
|
al@694
|
1588 for pkg in $INSTALLED/*; do
|
al@603
|
1589 if grep -qs "$2" $pkg/files.list; then
|
al@603
|
1590 . $pkg/receipt
|
al@603
|
1591 newline
|
al@702
|
1592 emsg "<c 33>$(_ 'Package %s:' $PACKAGE)</c>"
|
al@704
|
1593 awk -vT=$TMPLIST '
|
al@702
|
1594 /'$2'/ {
|
al@702
|
1595 gsub(/'$2'/, "\e[0;32m'$2'\e[0;39m", $0);
|
al@704
|
1596 print " "$0;
|
al@704
|
1597 printf "%s" 1 >> T;
|
al@702
|
1598 }
|
al@704
|
1599 ' $pkg/files.list
|
al@603
|
1600 fi
|
al@603
|
1601 done
|
pascal@98
|
1602
|
pascal@98
|
1603 fi
|
al@702
|
1604
|
al@704
|
1605 match=$(wc -m < $TMPLIST)
|
al@702
|
1606 rm $TMPLIST
|
al@702
|
1607
|
al@707
|
1608 footer "$(emsg "$(_p \
|
al@707
|
1609 '%s file' '%s files' $match \
|
al@707
|
1610 "<c 32>$match</c>")")"
|
al@603
|
1611 ;;
|
al@694
|
1612
|
al@694
|
1613
|
pankso@598
|
1614 search-pkgname)
|
pankso@344
|
1615 # Search for a package name
|
jozee@318
|
1616 if [ -z "$2" ]; then
|
pankso@600
|
1617 newline
|
al@694
|
1618 _ 'Please specify a pattern or file name to search for.'
|
al@694
|
1619 echo "$(_ 'Example:') 'tazpkg search-pkgname libnss'"
|
pankso@600
|
1620 newline
|
jozee@318
|
1621 exit 0
|
jozee@318
|
1622 fi
|
al@702
|
1623 title 'Search result for package "%s"' $2
|
pankso@598
|
1624
|
pankso@503
|
1625 # Search for a file on mirror and output only the package name
|
al@704
|
1626 TMPLIST=$(mktemp)
|
al@704
|
1627 for i in $PKGS_DB/files.list.lzma $PKGS_DB/undigest/*/files.list.lzma; do
|
al@704
|
1628 [ -f $i ] || continue
|
al@704
|
1629 lzcat $i | awk -F: -vT=$TMPLIST '
|
al@704
|
1630 BEGIN { P = "" }
|
al@704
|
1631 $2 ~ /'$2'/ {
|
al@704
|
1632 if ($1 != P) {
|
al@704
|
1633 print $1;
|
al@704
|
1634 printf "%s" 1 >> T;
|
al@704
|
1635 P = $1
|
al@704
|
1636 }
|
al@704
|
1637 }'
|
jozee@318
|
1638 done
|
al@704
|
1639 match=$(wc -m < $TMPLIST)
|
al@704
|
1640 rm $TMPLIST
|
al@704
|
1641
|
al@707
|
1642 footer "$(emsg "$(_p \
|
al@707
|
1643 '%s package' '%s packages' $match \
|
al@707
|
1644 "<c 32>$match</c>")")"
|
jozee@318
|
1645 ;;
|
al@694
|
1646
|
al@694
|
1647
|
pankso@504
|
1648 install|-i)
|
pankso@6
|
1649 # Install .tazpkg packages.
|
al@603
|
1650 check_root $@
|
pankso@6
|
1651 check_for_package_on_cmdline
|
pankso@6
|
1652 check_for_package_file
|
al@701
|
1653 check_for_installed_info
|
pankso@598
|
1654
|
al@704
|
1655 if [ -n "$root" ]; then
|
al@704
|
1656 ROOT="$root";
|
al@704
|
1657 check_base_dir "$root"
|
al@704
|
1658 fi
|
gokhlayeh@429
|
1659 [ "$list" ] && INSTALL_LIST="$list"
|
slaxemulator@488
|
1660 if [ "$rootconfig" ]; then
|
slaxemulator@487
|
1661 if [ "$root" ]; then
|
slaxemulator@487
|
1662 CACHE_DIR=$root/$CACHE_DIR
|
slaxemulator@487
|
1663 SAVE_CACHE_DIR=$CACHE_DIR
|
al@700
|
1664 PKGS_DB=$root/$PKGS_DB
|
slaxemulator@487
|
1665 else
|
slaxemulator@487
|
1666 echo "rootconfig needs --root= option used." >&2
|
slaxemulator@487
|
1667 exit 1
|
slaxemulator@487
|
1668 fi
|
slaxemulator@487
|
1669 fi
|
gokhlayeh@436
|
1670
|
gokhlayeh@386
|
1671 # Get repositories priority list.
|
gokhlayeh@386
|
1672 look_for_priority
|
gokhlayeh@436
|
1673
|
pankso@6
|
1674 # Check if forced install.
|
al@704
|
1675 if [ -z "$forced" ]; then
|
pascal@121
|
1676 check_for_installed_package $ROOT
|
pankso@6
|
1677 fi
|
gokhlayeh@356
|
1678 install_package $ROOT
|
slaxemulator@369
|
1679 update_desktop_database $ROOT
|
pankso@598
|
1680 update_mime_database $ROOT
|
pankso@598
|
1681 update_icon_database $ROOT
|
al@704
|
1682 compile_glib_schemas $ROOT
|
al@704
|
1683 ;;
|
al@694
|
1684
|
al@694
|
1685
|
erjo@59
|
1686 install-list|get-install-list)
|
pankso@6
|
1687 # Install a set of packages from a list.
|
al@603
|
1688 check_root $@
|
pankso@6
|
1689 if [ -z "$2" ]; then
|
pankso@600
|
1690 newline
|
al@704
|
1691 longline "$(_ \
|
al@704
|
1692 "Please change directory (cd) to the packages repository and specify the \
|
al@704
|
1693 list of packages to install.")"
|
al@704
|
1694 echo "$(_ 'Example:') $(emsg '<b>tazpkg install-list</b> <c 33>packages.list</c>')"
|
al@694
|
1695 exit 0
|
pankso@6
|
1696 fi
|
al@704
|
1697
|
pankso@6
|
1698 # Check if the packages list exist.
|
al@704
|
1699 if [ ! -f "$2" ]; then
|
al@704
|
1700 _ 'Unable to find list "%s"' "$2"
|
pankso@6
|
1701 exit 0
|
pankso@6
|
1702 fi
|
pankso@279
|
1703
|
al@704
|
1704 LIST=$(cat $2)
|
al@704
|
1705
|
pascal@120
|
1706 # Remember processed list
|
pascal@121
|
1707 export INSTALL_LIST="$2"
|
pascal@120
|
1708
|
erjo@59
|
1709 # Set $COMMAND and install all packages.
|
al@704
|
1710 COMMAND=${1%-list}
|
al@704
|
1711
|
pascal@121
|
1712 touch $2-processed
|
pascal@314
|
1713
|
pascal@314
|
1714 # Upgrade tazpkg first. It may handle new features/formats...
|
pascal@340
|
1715 # then upgrade essential packages early
|
pascal@341
|
1716 for pkg in busybox-pam busybox gcc-lib-base glibc-base \
|
al@704
|
1717 slitaz-base-files tazpkg ; do
|
pascal@341
|
1718 pkg=$(egrep $pkg-[0-9] $INSTALL_LIST)
|
al@704
|
1719 [ -z "$pkg" ] && continue
|
al@704
|
1720 _ 'Adding implicit depends "%s"...' $pkg
|
pascal@341
|
1721 LIST="$pkg
|
pascal@341
|
1722 $LIST"
|
pascal@340
|
1723 done
|
pascal@314
|
1724
|
al@694
|
1725 for pkg in $LIST; do
|
pascal@121
|
1726 grep -qs ^$pkg$ $2-processed && continue
|
pankso@658
|
1727 [ -d "$root/var/lib/tazpkg/installed" ] && continue
|
pankso@660
|
1728 tazpkg $COMMAND $pkg --list="$2" "$3" "$4" "$5"
|
pankso@6
|
1729 done
|
pankso@309
|
1730 rm -f $2-processed ;;
|
al@694
|
1731
|
al@694
|
1732
|
pankso@76
|
1733 add-flavor)
|
pascal@74
|
1734 # Install a set of packages from a flavor.
|
pankso@309
|
1735 install_flavor $2 ;;
|
al@694
|
1736
|
al@694
|
1737
|
pankso@76
|
1738 install-flavor)
|
pascal@74
|
1739 # Install a set of packages from a flavor and purge other ones.
|
pankso@309
|
1740 install_flavor $2 --purge ;;
|
al@694
|
1741
|
al@694
|
1742
|
pankso@76
|
1743 set-release)
|
paul@662
|
1744 # Change current release and upgrade packages.
|
pascal@74
|
1745 RELEASE=$2
|
pankso@76
|
1746 if [ -z "$RELEASE" ]; then
|
pankso@600
|
1747 newline
|
al@694
|
1748 _ 'Please specify the release you want on the command line.'
|
al@694
|
1749 echo "$(_ 'Example:') tazpkg set-release cooking"
|
pankso@600
|
1750 newline
|
pankso@76
|
1751 exit 0
|
pankso@76
|
1752 fi
|
al@700
|
1753 rm $PKGS_DB/mirror
|
pascal@74
|
1754 echo "$RELEASE" > /etc/slitaz-release
|
pascal@74
|
1755 tazpkg recharge && tazpkg upgrade
|
pascal@222
|
1756
|
pascal@222
|
1757 # Install missing depends
|
pascal@222
|
1758 cd $INSTALLED
|
pascal@222
|
1759 for i in * ; do
|
pascal@222
|
1760 DEPENDS=""
|
pascal@222
|
1761 . $i/receipt
|
pascal@222
|
1762 for j in $DEPENDS ; do
|
pascal@222
|
1763 [ -d $j ] || tazpkg get-install $j
|
pascal@222
|
1764 done
|
pankso@309
|
1765 done ;;
|
al@694
|
1766
|
al@694
|
1767
|
pankso@504
|
1768 remove|-r)
|
pankso@6
|
1769 # Remove packages.
|
al@603
|
1770 check_root $@
|
pankso@6
|
1771 check_for_package_on_cmdline
|
al@701
|
1772 check_for_installed_info
|
pankso@598
|
1773
|
al@694
|
1774 [ -n "$root" ] && ROOT="$root"
|
slaxemulator@370
|
1775 if [ ! -f "$ROOT$INSTALLED/$PACKAGE/receipt" ]; then
|
pankso@600
|
1776 newline
|
al@704
|
1777 _ 'Package "%s" is not installed.' $PACKAGE
|
pankso@6
|
1778 exit 0
|
pankso@6
|
1779 else
|
pascal@30
|
1780 ALTERED=""
|
pascal@30
|
1781 THE_PACKAGE=$PACKAGE # altered by receipt
|
slaxemulator@370
|
1782 for i in $(cd $ROOT$INSTALLED ; ls); do
|
slaxemulator@370
|
1783 [ -f $ROOT$INSTALLED/$i/receipt ] || continue
|
pankso@37
|
1784 DEPENDS=""
|
slaxemulator@370
|
1785 . $ROOT$INSTALLED/$i/receipt
|
pascal@30
|
1786 case " $(echo $DEPENDS) " in
|
al@704
|
1787 *\ $THE_PACKAGE\ *) ALTERED="$ALTERED $i";;
|
pascal@30
|
1788 esac
|
pascal@30
|
1789 done
|
pascal@114
|
1790 EXTRAVERSION=""
|
slaxemulator@370
|
1791 . $ROOT$INSTALLED/$THE_PACKAGE/receipt
|
pankso@6
|
1792 fi
|
pankso@600
|
1793 newline
|
pascal@30
|
1794 if [ -n "$ALTERED" ]; then
|
al@704
|
1795 _ 'The following packages depend on package "%s":' $PACKAGE
|
pascal@30
|
1796 for i in $ALTERED; do
|
pascal@30
|
1797 echo " $i"
|
pascal@30
|
1798 done
|
pascal@30
|
1799 fi
|
slaxemulator@370
|
1800 REFRESH=$(cd $ROOT$INSTALLED ; grep -sl ^$PACKAGE$ */modifiers)
|
pascal@163
|
1801 if [ -n "$REFRESH" ]; then
|
al@704
|
1802 _ 'The following packages have been modified by package "%s":' $PACKAGE
|
pascal@163
|
1803 for i in $REFRESH; do
|
pascal@170
|
1804 echo " ${i%/modifiers}"
|
pascal@163
|
1805 done
|
pascal@163
|
1806 fi
|
gokhlayeh@423
|
1807 if [ "$auto" ]; then
|
al@603
|
1808 answer=0
|
gokhlayeh@423
|
1809 else
|
al@704
|
1810 confirm "$(_ 'Remove package "%s" (%s)? (y/N)' $PACKAGE $VERSION$EXTRAVERSION)"
|
al@603
|
1811 answer=$?
|
gokhlayeh@423
|
1812 fi
|
al@603
|
1813 if [ $answer = 0 ]; then
|
al@704
|
1814 title 'Removing package "%s"' $PACKAGE
|
pankso@38
|
1815 # Pre remove commands.
|
slaxemulator@371
|
1816 if grep -q ^pre_remove $ROOT$INSTALLED/$PACKAGE/receipt; then
|
slaxemulator@533
|
1817 pre_remove $ROOT
|
pankso@38
|
1818 fi
|
al@603
|
1819 action "Removing all files installed..."
|
slaxemulator@370
|
1820 if [ -f $ROOT$INSTALLED/$PACKAGE/modifiers ]; then
|
al@694
|
1821 for file in $(cat $ROOT$INSTALLED/$PACKAGE/files.list); do
|
al@694
|
1822 for mod in $(cat $ROOT$INSTALLED/$PACKAGE/modifiers); do
|
al@603
|
1823 [ -f $ROOT$INSTALLED/$mod/files.list ] && [ $(grep "^$(echo $file | grepesc)$" $ROOT$INSTALLED/$mod/files.list | wc -l) -gt 1 ] && continue 2
|
al@603
|
1824 done
|
al@603
|
1825 remove_with_path $ROOT$file
|
pascal@206
|
1826 done
|
pascal@255
|
1827 else
|
al@694
|
1828 for file in $(cat $ROOT$INSTALLED/$PACKAGE/files.list); do
|
slaxemulator@371
|
1829 remove_with_path $ROOT$file
|
pascal@255
|
1830 done
|
pascal@255
|
1831 fi
|
pankso@6
|
1832 status
|
slaxemulator@370
|
1833 if grep -q ^post_remove $ROOT$INSTALLED/$PACKAGE/receipt; then
|
slaxemulator@533
|
1834 post_remove $ROOT
|
pankso@51
|
1835 fi
|
al@694
|
1836
|
pankso@6
|
1837 # Remove package receipt.
|
al@603
|
1838 action "Removing package receipt..."
|
slaxemulator@370
|
1839 rm -rf $ROOT$INSTALLED/$PACKAGE
|
pankso@6
|
1840 status
|
al@694
|
1841
|
pascal@253
|
1842 sed -i "/ $PACKAGE-$VERSION$EXTRAVERSION$/d" \
|
al@700
|
1843 $PKGS_DB/installed.$SUM 2> /dev/null
|
al@694
|
1844
|
al@701
|
1845 # Update installed.info
|
al@701
|
1846 sed -i "/^$PACKAGE /d" $PKGS_DB/installed.info
|
al@701
|
1847
|
pascal@183
|
1848 # Log this activity
|
al@603
|
1849 log_pkg Removed
|
al@701
|
1850
|
gokhlayeh@423
|
1851 if [ "$ALTERED" ]; then
|
gokhlayeh@423
|
1852 if [ "$auto" ]; then
|
al@603
|
1853 answer=0
|
gokhlayeh@423
|
1854 else
|
al@704
|
1855 confirm "$(_ 'Remove packages depending on package "%s"? (y/N)' $PACKAGE)"
|
al@603
|
1856 answer=$?
|
gokhlayeh@423
|
1857 fi
|
al@603
|
1858 if [ $answer = 0 ]; then
|
pascal@30
|
1859 for i in $ALTERED; do
|
slaxemulator@370
|
1860 if [ -d "$ROOT$INSTALLED/$i" ]; then
|
slaxemulator@371
|
1861 tazpkg remove $i $ROOTOPTS
|
pankso@37
|
1862 fi
|
pascal@30
|
1863 done
|
pascal@30
|
1864 fi
|
pascal@30
|
1865 fi
|
gokhlayeh@423
|
1866 if [ "$REFRESH" ]; then
|
gokhlayeh@423
|
1867 if [ "$auto" ]; then
|
al@603
|
1868 answer=0
|
gokhlayeh@423
|
1869 else
|
al@704
|
1870 confirm "$(_ 'Reinstall packages modified by package "%s"? (y/N)' $PACKAGE)"
|
al@603
|
1871 answer=$?
|
gokhlayeh@423
|
1872 fi
|
al@603
|
1873 if [ $answer = 0 ]; then
|
pascal@163
|
1874 for i in $REFRESH; do
|
slaxemulator@370
|
1875 if [ $(wc -l < $ROOT$INSTALLED/$i) -gt 1 ]; then
|
al@704
|
1876 _ 'Check %s for reinstallation' "$INSTALLED/$i"
|
pascal@163
|
1877 continue
|
pascal@163
|
1878 fi
|
slaxemulator@370
|
1879 rm -r $ROOT$INSTALLED/$i
|
slaxemulator@371
|
1880 tazpkg get-install ${i%/modifiers} $ROOTOPTS --forced
|
pascal@163
|
1881 done
|
pascal@163
|
1882 fi
|
pascal@163
|
1883 fi
|
pankso@6
|
1884 else
|
pankso@600
|
1885 newline
|
al@704
|
1886 _ 'Uninstallation of package "%s" cancelled.' $PACKAGE
|
pankso@6
|
1887 fi
|
pankso@600
|
1888 newline ;;
|
al@694
|
1889
|
al@694
|
1890
|
pankso@600
|
1891 extract|-e)
|
pankso@6
|
1892 # Extract .tazpkg cpio archive into a directory.
|
pankso@6
|
1893 check_for_package_on_cmdline
|
pankso@6
|
1894 check_for_package_file
|
al@704
|
1895 title 'Extracting package "%s"' $PACKAGE
|
al@694
|
1896
|
MikeDSmith25@135
|
1897 # If no directory destination is found on the cmdline
|
MikeDSmith25@135
|
1898 # we create one in the current dir using the package name.
|
pankso@6
|
1899 if [ -n "$TARGET_DIR" ]; then
|
pankso@6
|
1900 DESTDIR=$TARGET_DIR/$PACKAGE
|
pankso@6
|
1901 else
|
pankso@6
|
1902 DESTDIR=$PACKAGE
|
pankso@6
|
1903 fi
|
pankso@6
|
1904 mkdir -p $DESTDIR
|
al@694
|
1905
|
al@603
|
1906 action "Copying original package..."
|
pankso@9
|
1907 cp $PACKAGE_FILE $DESTDIR
|
pankso@6
|
1908 status
|
al@694
|
1909
|
pankso@6
|
1910 cd $DESTDIR
|
pankso@6
|
1911 extract_package
|
al@704
|
1912 [ -e "receipt" ] && \
|
al@704
|
1913 footer "$(_ 'Package "%s" is extracted to "%s"') $PACKAGE $DESTDIR"
|
al@603
|
1914 ;;
|
al@694
|
1915
|
al@694
|
1916
|
pascal@297
|
1917 recompress)
|
pascal@297
|
1918 # Recompress .tazpkg cpio archive with lzma.
|
pascal@297
|
1919 check_for_package_on_cmdline
|
pascal@297
|
1920 check_for_package_file
|
al@707
|
1921 title 'Recompressing package "%s"' $PACKAGE
|
pascal@297
|
1922 mkdir -p $TMP_DIR
|
al@694
|
1923
|
al@603
|
1924 action "Copying original package..."
|
pascal@297
|
1925 cp $PACKAGE_FILE $TMP_DIR
|
pascal@297
|
1926 status
|
al@694
|
1927
|
pascal@297
|
1928 cd $TMP_DIR
|
pascal@297
|
1929 extract_package
|
al@694
|
1930
|
al@707
|
1931 action "Recompressing the FS..."
|
gokhlayeh@383
|
1932 find fs | cpio -o -H newc --quiet | lzma e fs.cpio.lzma -si
|
pascal@297
|
1933 rm -rf fs
|
pascal@297
|
1934 status
|
al@694
|
1935
|
al@603
|
1936 action "Creating new package..."
|
gokhlayeh@383
|
1937 find . -print | cpio -o -H newc --quiet > \
|
pascal@297
|
1938 $TOP_DIR/$(basename $PACKAGE_FILE).$$ && mv -f \
|
pascal@297
|
1939 $TOP_DIR/$(basename $PACKAGE_FILE).$$ \
|
pascal@297
|
1940 $TOP_DIR/$(basename $PACKAGE_FILE)
|
pascal@297
|
1941 status
|
al@694
|
1942
|
pascal@297
|
1943 cd $TOP_DIR
|
al@603
|
1944 rm -rf $TMP_DIR
|
al@603
|
1945 separator; newline ;;
|
al@694
|
1946
|
al@694
|
1947
|
pascal@139
|
1948 list-config)
|
pascal@139
|
1949 # List configuration files installed.
|
pascal@141
|
1950 if [ "$2" = "--box" ]; then
|
al@707
|
1951 mkdir -p $TMP_DIR; cd $TMP_DIR
|
pascal@210
|
1952 FILES="$INSTALLED/*/volatile.cpio.gz"
|
pascal@210
|
1953 [ -n "$3" ] && FILES="$INSTALLED/$3/volatile.cpio.gz"
|
pankso@279
|
1954 for i in $FILES; do
|
gokhlayeh@383
|
1955 zcat $i | cpio -idm --quiet > /dev/null
|
pascal@190
|
1956 find * -type f 2>/dev/null | while read file; do
|
pascal@190
|
1957 if [ ! -e /$file ]; then
|
al@694
|
1958 echo -n "----------|----|----|$(_n 'File lost')"
|
pascal@190
|
1959 else
|
al@694
|
1960 echo -n "$(stat -c "%A|%U|%G|%s|" /$file)"
|
al@694
|
1961 cmp $file /$file > /dev/null 2>&1 || \
|
pascal@141
|
1962 echo -n "$(stat -c "%.16y" /$file)"
|
pascal@190
|
1963 fi
|
pascal@143
|
1964 echo "|/$file"
|
pascal@141
|
1965 done
|
pascal@141
|
1966 rm -rf *
|
pascal@146
|
1967 done
|
pascal@141
|
1968 cd $TOP_DIR
|
pascal@141
|
1969 rm -rf $TMP_DIR
|
pascal@141
|
1970 else
|
al@603
|
1971 title 'Configuration files'
|
pankso@279
|
1972 for i in $INSTALLED/*/volatile.cpio.gz; do
|
pascal@146
|
1973 [ -n "$2" -a "$i" != "$INSTALLED/$2/volatile.cpio.gz" ] && continue
|
pascal@146
|
1974 [ -f "$i" ] || continue
|
gokhlayeh@383
|
1975 zcat $i | cpio -t --quiet
|
pascal@146
|
1976 done | sed 's|^|/|' | sort
|
slaxemulator@475
|
1977 separator
|
pankso@600
|
1978 newline
|
pankso@309
|
1979 fi ;;
|
al@694
|
1980
|
al@694
|
1981
|
pascal@139
|
1982 repack-config)
|
pascal@137
|
1983 # Create SliTaz package archive from configuration files.
|
al@707
|
1984 mkdir -p $TMP_DIR; cd $TMP_DIR
|
pascal@137
|
1985 CONFIG_VERSION=1.0
|
pascal@137
|
1986 mkdir config-$CONFIG_VERSION
|
pascal@137
|
1987 cd config-$CONFIG_VERSION
|
pankso@279
|
1988 for i in $INSTALLED/*/volatile.cpio.gz; do
|
gokhlayeh@383
|
1989 zcat $i | cpio -t --quiet
|
pascal@137
|
1990 done > files.list
|
pascal@137
|
1991 mkdir fs
|
pascal@137
|
1992 cd fs
|
gokhlayeh@416
|
1993 ( cd / ; cpio -o -H newc --quiet ) < ../files.list | cpio -idm --quiet > /dev/null
|
pascal@137
|
1994 mkdir -p etc/tazlito
|
pankso@279
|
1995 for i in $INSTALLED/*/receipt; do
|
pascal@137
|
1996 EXTRAVERSION=""
|
pascal@137
|
1997 . $i
|
pascal@137
|
1998 echo "$PACKAGE-$VERSION$EXTRAVERSION"
|
pascal@137
|
1999 done > etc/tazlito/config-packages.list
|
pascal@137
|
2000 cd ..
|
pascal@137
|
2001 echo "etc/tazlito/config-packages.list" >> files.list
|
al@603
|
2002 pkg_date=$(date +"%x %X")
|
pascal@137
|
2003 cat > receipt <<EOT
|
pascal@137
|
2004 # SliTaz package receipt.
|
pascal@137
|
2005
|
pascal@137
|
2006 PACKAGE="config"
|
pascal@137
|
2007 VERSION="$CONFIG_VERSION"
|
pascal@137
|
2008 CATEGORY="base-system"
|
al@707
|
2009 SHORT_DESC="$(_n 'User configuration backup on date %s' $pkg_date)"
|
pascal@137
|
2010 DEPENDS="$(ls $INSTALLED)"
|
pascal@137
|
2011 EOT
|
pascal@137
|
2012 cd ..
|
pascal@137
|
2013 tazpkg pack config-$CONFIG_VERSION
|
pascal@137
|
2014 cp config-$CONFIG_VERSION.tazpkg $TOP_DIR
|
pascal@137
|
2015 cd $TOP_DIR
|
pascal@137
|
2016 rm -rf $TMP_DIR
|
pascal@137
|
2017 ;;
|
al@694
|
2018
|
al@694
|
2019
|
pascal@18
|
2020 repack)
|
MikeDSmith25@135
|
2021 # Create SliTaz package archive from an installed package.
|
pascal@18
|
2022 check_for_package_on_cmdline
|
pascal@18
|
2023 check_for_receipt
|
pascal@114
|
2024 EXTRAVERSION=""
|
pascal@114
|
2025 . $INSTALLED/$PACKAGE/receipt
|
al@707
|
2026 title 'Repacking "%s"' "$PACKAGE-$VERSION$EXTRAVERSION.tazpkg"
|
al@707
|
2027
|
pascal@24
|
2028 if grep -qs ^NO_REPACK= $INSTALLED/$PACKAGE/receipt; then
|
al@707
|
2029 _ "Can't repack package \"%s\"" $PACKAGE
|
pascal@24
|
2030 exit 1
|
pascal@24
|
2031 fi
|
al@707
|
2032
|
pascal@21
|
2033 if [ -s $INSTALLED/$PACKAGE/modifiers ]; then
|
al@707
|
2034 _ "Can't repack, \"%s\" files have been modified by:" $PACKAGE
|
pascal@21
|
2035 for i in $(cat $INSTALLED/$PACKAGE/modifiers); do
|
pascal@21
|
2036 echo " $i"
|
pascal@21
|
2037 done
|
pascal@21
|
2038 exit 1
|
pascal@21
|
2039 fi
|
al@707
|
2040
|
pascal@18
|
2041 MISSING=""
|
pascal@63
|
2042 while read i; do
|
pascal@18
|
2043 [ -e "$i" ] && continue
|
pascal@63
|
2044 [ -L "$i" ] || MISSING="$MISSING\n $i"
|
pascal@63
|
2045 done < $INSTALLED/$PACKAGE/files.list
|
pascal@18
|
2046 if [ -n "$MISSING" ]; then
|
al@694
|
2047 _n "Can't repack, the following files are lost:"
|
pascal@63
|
2048 echo -e "$MISSING"
|
pascal@18
|
2049 exit 1
|
pascal@18
|
2050 fi
|
al@707
|
2051
|
al@707
|
2052 mkdir -p $TMP_DIR; cd $TMP_DIR
|
pascal@298
|
2053 FILES="fs.cpio.lzma\n"
|
al@707
|
2054 for i in $(ls $INSTALLED/$PACKAGE); do
|
al@707
|
2055 case $i in
|
al@707
|
2056 volatile.cpio.gz|modifiers) ;;
|
al@707
|
2057 *) cp $INSTALLED/$PACKAGE/$i .; FILES="$FILES$i\n" ;;
|
al@707
|
2058 esac
|
pascal@24
|
2059 done
|
al@707
|
2060
|
pascal@72
|
2061 ln -s / rootfs
|
pascal@72
|
2062 mkdir tmp
|
al@707
|
2063 sed 's/^/rootfs/' < files.list | cpio -o -H newc --quiet | \
|
al@707
|
2064 { cd tmp ; cpio -idm --quiet >/dev/null; cd ..; }
|
pascal@72
|
2065 mv tmp/rootfs fs
|
al@707
|
2066
|
pascal@145
|
2067 if [ -f $INSTALLED/$PACKAGE/volatile.cpio.gz ]; then
|
pascal@145
|
2068 zcat $INSTALLED/$PACKAGE/volatile.cpio.gz | \
|
gokhlayeh@416
|
2069 { cd fs; cpio -idm --quiet; cd ..; }
|
pascal@145
|
2070 fi
|
al@707
|
2071
|
gokhlayeh@409
|
2072 if fgrep -q repack_cleanup $INSTALLED/$PACKAGE/receipt; then
|
pascal@107
|
2073 . $INSTALLED/$PACKAGE/receipt
|
pascal@107
|
2074 repack_cleanup fs
|
pascal@107
|
2075 fi
|
al@707
|
2076
|
slaxemulator@588
|
2077 if [ -f $INSTALLED/$PACKAGE/$CHECKSUM ]; then
|
slaxemulator@588
|
2078 sed 's, , fs,' < $INSTALLED/$PACKAGE/$CHECKSUM | \
|
slaxemulator@588
|
2079 $CHECKSUM -s -c || {
|
al@707
|
2080 _ "Can't repack, %s error." $CHECKSUM
|
pascal@107
|
2081 cd $TOP_DIR
|
pascal@214
|
2082 rm -rf $TMP_DIR
|
pascal@107
|
2083 exit 1
|
pascal@214
|
2084 }
|
pascal@107
|
2085 fi
|
al@707
|
2086
|
gokhlayeh@383
|
2087 find fs | cpio -o -H newc --quiet | lzma e fs.cpio.lzma -si
|
gokhlayeh@383
|
2088 echo -e "$FILES" | cpio -o -H newc --quiet > \
|
pascal@114
|
2089 $TOP_DIR/$PACKAGE-$VERSION$EXTRAVERSION.tazpkg
|
pascal@74
|
2090 cd $TOP_DIR
|
pascal@18
|
2091 \rm -R $TMP_DIR
|
al@707
|
2092 _ 'Package "%s" repacked successfully.' $PACKAGE
|
al@707
|
2093 _ 'Size: %s' "$(du -sh $PACKAGE-$VERSION$EXTRAVERSION.tazpkg)"
|
pankso@600
|
2094 newline ;;
|
al@694
|
2095
|
al@694
|
2096
|
pankso@6
|
2097 pack)
|
pankso@600
|
2098 # Create SliTaz package archive using cpio and lzma.
|
pankso@600
|
2099 # TODO: Cook also pack packages, we should share code in libpkg.sh
|
pankso@6
|
2100 check_for_package_on_cmdline
|
pankso@6
|
2101 cd $PACKAGE
|
pankso@6
|
2102 if [ ! -f "receipt" ]; then
|
al@694
|
2103 _ 'Receipt is missing. Please read the documentation.'
|
pankso@6
|
2104 exit 0
|
pankso@6
|
2105 else
|
al@707
|
2106 title 'Packing package "%s"' $PACKAGE
|
MikeDSmith25@135
|
2107 # Create files.list with redirecting find outpout.
|
al@603
|
2108 action "Creating the list of files..."
|
al@603
|
2109 cd fs
|
pankso@6
|
2110 find . -type f -print > ../files.list
|
pankso@6
|
2111 find . -type l -print >> ../files.list
|
pankso@6
|
2112 cd .. && sed -i s/'^.'/''/ files.list
|
pankso@6
|
2113 status
|
al@707
|
2114 action 'Creating %s of files...' $CHECKSUM
|
pascal@138
|
2115 while read file; do
|
pascal@138
|
2116 [ -L "fs$file" ] && continue
|
pascal@138
|
2117 [ -f "fs$file" ] || continue
|
pascal@158
|
2118 case "$file" in
|
al@694
|
2119 /lib/modules/*/modules.*|*.pyc) continue;;
|
pascal@158
|
2120 esac
|
slaxemulator@588
|
2121 $CHECKSUM "fs$file" | sed 's/ fs/ /'
|
slaxemulator@588
|
2122 done < files.list > $CHECKSUM
|
pascal@138
|
2123 status
|
slaxemulator@588
|
2124 UNPACKED_SIZE=$(du -chs fs receipt files.list $CHECKSUM \
|
pascal@147
|
2125 description.txt 2> /dev/null | awk \
|
pascal@147
|
2126 '{ sz=$1 } END { print sz }')
|
pankso@6
|
2127 # Build cpio archives.
|
al@707
|
2128 action "Compressing the FS..."
|
gokhlayeh@383
|
2129 find fs | cpio -o -H newc --quiet | lzma e fs.cpio.lzma -si
|
pascal@138
|
2130 rm -rf fs
|
pascal@147
|
2131 status
|
pascal@298
|
2132 PACKED_SIZE=$(du -chs fs.cpio.lzma receipt files.list \
|
slaxemulator@588
|
2133 $CHECKSUM description.txt 2> /dev/null | awk \
|
pascal@147
|
2134 '{ sz=$1 } END { print sz }')
|
al@603
|
2135 action "Updating receipt sizes..."
|
pankso@279
|
2136 sed -i s/^PACKED_SIZE.*$// receipt
|
pankso@279
|
2137 sed -i s/^UNPACKED_SIZE.*$// receipt
|
pascal@147
|
2138 sed -i "s/^PACKAGE=/PACKED_SIZE=\"$PACKED_SIZE\"\nUNPACKED_SIZE=\"$UNPACKED_SIZE\"\nPACKAGE=/" receipt
|
pascal@147
|
2139 status
|
al@603
|
2140 action "Creating full cpio archive..."
|
gokhlayeh@383
|
2141 find . -print | cpio -o -H newc --quiet > ../$PACKAGE.tazpkg
|
pascal@147
|
2142 status
|
al@603
|
2143 action "Restoring original package tree..."
|
gokhlayeh@383
|
2144 unlzma -c fs.cpio.lzma | cpio -idm --quiet
|
pascal@147
|
2145 status
|
pascal@298
|
2146 rm fs.cpio.lzma && cd ..
|
al@707
|
2147 footer "$(_ 'Package "%s" compressed successfully.' $PACKAGE)"
|
al@603
|
2148 pkg_size=$(du -sh $PACKAGE.tazpkg)
|
al@707
|
2149 _ 'Size: %s' $pkg_size
|
pankso@600
|
2150 newline
|
pankso@309
|
2151 fi ;;
|
al@694
|
2152
|
al@694
|
2153
|
pankso@6
|
2154 recharge)
|
pankso@6
|
2155 # Recharge packages.list from a mirror.
|
pankso@581
|
2156 #
|
al@694
|
2157 # WARNING: The 'mirrors' file has all SliTaz mirrors but 'mirror'
|
paul@607
|
2158 # must have only the chosen main mirror.
|
pankso@581
|
2159 #
|
al@603
|
2160 check_root $@
|
pankso@598
|
2161
|
gokhlayeh@448
|
2162 ARG=$2
|
gokhlayeh@448
|
2163 if [ "$root" ]; then
|
al@700
|
2164 PKGS_DB=$root$PKGS_DB
|
gokhlayeh@448
|
2165 [ "${2#--}" != "$2" ] && ARG=$3
|
gokhlayeh@448
|
2166 fi
|
gokhlayeh@448
|
2167 if [ "$ARG" = main ]; then
|
al@700
|
2168 repository_to_recharge=$PKGS_DB
|
gokhlayeh@448
|
2169 elif [ "$ARG" ]; then
|
al@700
|
2170 if [ -d "$PKGS_DB/undigest/$ARG" ]; then
|
al@700
|
2171 repository_to_recharge=$PKGS_DB/undigest/$ARG
|
gokhlayeh@430
|
2172 else
|
al@700
|
2173 repo="$PKGS_DB/undigest/$ARG"
|
al@707
|
2174 _ "Repository \"%s\" doesn't exist." $repo >&2
|
gokhlayeh@430
|
2175 exit 1
|
gokhlayeh@430
|
2176 fi
|
gokhlayeh@430
|
2177 else
|
al@700
|
2178 repository_to_recharge="$PKGS_DB $PKGS_DB/undigest/*"
|
pankso@598
|
2179 fi
|
gokhlayeh@430
|
2180 for path in $repository_to_recharge; do
|
pascal@187
|
2181 [ -f $path/mirror ] || continue
|
gokhlayeh@430
|
2182 cd $path
|
pankso@598
|
2183
|
gokhlayeh@430
|
2184 # Quietly check if recharging is needed.
|
gokhlayeh@430
|
2185 [ -f ID ] && mv ID ID.bak
|
mojo@575
|
2186 download_from "$(cat mirror)" ID >/dev/null 2>/dev/null
|
al@694
|
2187 if [ -f ID ] && fgrep -q $(cat ID.bak 2>/dev/null || echo "null") ID; then
|
al@700
|
2188 if [ "$path" = "$PKGS_DB" ]; then
|
gokhlayeh@430
|
2189 repository_name=Main
|
gokhlayeh@430
|
2190 else
|
al@603
|
2191 base_path="$(basename $path)"
|
al@707
|
2192 repository_name="$(_n 'Undigest %s' $base_path)"
|
gokhlayeh@430
|
2193 fi
|
al@707
|
2194 _ 'Repository "%s" is up to date.' $repository_name
|
gokhlayeh@430
|
2195 rm ID.bak
|
gokhlayeh@430
|
2196 continue
|
gokhlayeh@430
|
2197 fi
|
gokhlayeh@432
|
2198
|
gokhlayeh@432
|
2199 # Don't let ID be a symlink when using local repository.
|
gokhlayeh@432
|
2200 if [ -f ID ]; then
|
gokhlayeh@432
|
2201 mv -f ID ID.bak
|
gokhlayeh@432
|
2202 cat ID.bak > ID
|
slaxemulator@576
|
2203 rm ID.bak
|
gokhlayeh@432
|
2204 fi
|
pankso@598
|
2205
|
pankso@600
|
2206 newline
|
al@700
|
2207 if [ "$path" != "$PKGS_DB" ]; then
|
al@603
|
2208 base_path="$(basename $path)"
|
al@707
|
2209 _ 'Recharging undigest %s:' $base_path
|
pascal@187
|
2210 fi
|
gokhlayeh@430
|
2211
|
pascal@187
|
2212 if [ -f "packages.list" ]; then
|
al@603
|
2213 action "Creating backup of the last packages list..."
|
slaxemulator@588
|
2214 for i in packages.desc packages.$SUM packages.txt \
|
pankso@580
|
2215 packages.list packages.equiv files.list.lzma \
|
al@699
|
2216 extra.list mirrors packages.info
|
pankso@580
|
2217 do
|
gokhlayeh@438
|
2218 mv -f $i $i.bak 2>/dev/null
|
gokhlayeh@438
|
2219 done
|
pascal@187
|
2220 status
|
pascal@187
|
2221 fi
|
gokhlayeh@546
|
2222
|
al@699
|
2223 for i in desc $SUM txt list equiv; do
|
mojo@575
|
2224 download_from "$(cat mirror)" packages.$i
|
gokhlayeh@438
|
2225 done
|
pankso@598
|
2226 download_from "$(cat mirror)" files.list.lzma
|
pascal@692
|
2227 download_from "$(cat mirror)" extra.list
|
al@699
|
2228 download_from "$(sed 's|packages/.*||' mirror)" mirrors
|
al@699
|
2229
|
al@699
|
2230 # packages.info
|
al@699
|
2231 download_from "$(cat mirror)" packages.info.lzma
|
al@699
|
2232 lzma d packages.info.lzma packages.info
|
al@699
|
2233 rm packages.info.lzma
|
pankso@598
|
2234
|
pascal@187
|
2235 if [ -f "packages.list.bak" ]; then
|
pascal@187
|
2236 diff -u packages.list.bak packages.list | grep ^+[a-z] > packages.diff
|
pascal@692
|
2237 [ -f "extra.list.bak" ] &&
|
pascal@692
|
2238 diff -u extra.list.bak extra.list | grep ^+[a-z] >> packages.diff
|
pascal@187
|
2239 sed -i s/+// packages.diff
|
al@603
|
2240 title 'Mirrored packages diff'
|
pascal@187
|
2241 cat packages.diff
|
al@701
|
2242 new_pkgs=$(wc -l < packages.diff)
|
al@707
|
2243 footer "$(emsg "$(_p \
|
al@707
|
2244 '%s new package on the mirror.' \
|
al@707
|
2245 '%s new packages on the mirror.' $new_pkgs \
|
al@707
|
2246 "<c 32>$new_pkgs</c>")")"
|
pankso@6
|
2247 else
|
al@707
|
2248 footer "$(longline "$(_ "Last %s is ready to use. Note that \
|
al@707
|
2249 next time you recharge the list, a list of differences will be displayed to \
|
al@710
|
2250 show new and upgradeable packages." packages.list)")"
|
pascal@187
|
2251 fi
|
pankso@309
|
2252 done ;;
|
al@694
|
2253
|
al@694
|
2254
|
al@603
|
2255 help-up)
|
al@603
|
2256 # Options available for the command: up
|
al@603
|
2257 newline; usage_up; newline
|
pankso@645
|
2258 exit 1 ;;
|
al@694
|
2259
|
al@694
|
2260
|
al@603
|
2261 up|upgrade)
|
al@707
|
2262 check_root
|
pankso@466
|
2263 #
|
paul@476
|
2264 # This is the new way to upgrade packages making 'upgrade' and
|
pankso@466
|
2265 # upgradeable out-of-date. This new way is much, much more faster!
|
paul@476
|
2266 # Look into installed packages and get data from receipt, it is fast
|
paul@476
|
2267 # and easy to handle vars after using only md5sum to compare packages
|
pankso@598
|
2268 #
|
al@691
|
2269 for opt in $@; do
|
pankso@466
|
2270 case "$opt" in
|
al@691
|
2271 --recharge|-r) tazpkg recharge ;;
|
al@691
|
2272 --install|-i) install="y" ;;
|
al@691
|
2273 --check|-c) install="n" ;;
|
pankso@466
|
2274 esac
|
pankso@466
|
2275 done
|
pankso@598
|
2276 time=$(date +%s)
|
al@700
|
2277 installed_sum=$PKGS_DB/installed.$SUM
|
gokhlayeh@536
|
2278 look_for_priority
|
gokhlayeh@536
|
2279 for repo in $priority; do
|
gokhlayeh@536
|
2280 pkg_list=$repo/packages.list
|
al@691
|
2281 mtime=$(find $pkg_list -mtime +7)
|
gokhlayeh@536
|
2282 if [ "$mtime" ]; then
|
al@700
|
2283 if [ "$repo" = "$PKGS_DB" ]; then
|
gokhlayeh@536
|
2284 repo_name=main
|
gokhlayeh@536
|
2285 else
|
gokhlayeh@536
|
2286 repo_name="${repo##*/}"
|
slaxemulator@516
|
2287 fi
|
al@707
|
2288 _ 'List "%s" is older than one week... Recharging.' $pkg_list
|
gokhlayeh@536
|
2289 tazpkg recharge $repo_name
|
gokhlayeh@536
|
2290 fi
|
gokhlayeh@536
|
2291 done
|
al@707
|
2292 emsg "<n>$(_ 'Package')<i 28> $(_ 'Version')<i 48> $(_ 'Status')<->"
|
slaxemulator@535
|
2293 cd $INSTALLED
|
pankso@600
|
2294 newline > $UP_LIST
|
ben@483
|
2295 blocked_count=0
|
al@691
|
2296 for pkg in *; do
|
al@691
|
2297 [ ! -d $pkg ] && continue
|
pankso@485
|
2298 unset VERSION EXTRAVERSION
|
pankso@466
|
2299 . $pkg/receipt
|
pankso@485
|
2300 md5=$(fgrep " $PACKAGE-${VERSION}$EXTRAVERSION.tazpkg" \
|
slaxemulator@588
|
2301 $installed_sum | awk '{print $1}')
|
gokhlayeh@536
|
2302 for repo in $priority; do
|
gokhlayeh@536
|
2303 pkg_desc=$repo/packages.desc
|
gokhlayeh@536
|
2304 pkg_list=$repo/packages.list
|
slaxemulator@588
|
2305 pkg_sum=$repo/packages.$SUM
|
gokhlayeh@536
|
2306
|
slaxemulator@588
|
2307 if ! fgrep -q "$md5 $PACKAGE-" $pkg_sum; then
|
paul@662
|
2308 # Jump to next repository in priority if pkg doesn't exist
|
gokhlayeh@536
|
2309 # in this one.
|
gokhlayeh@536
|
2310 grep -q ^$PACKAGE- $pkg_list || continue
|
gokhlayeh@536
|
2311
|
al@603
|
2312 emsg -n "$PACKAGE<i 28> $VERSION"
|
pankso@598
|
2313
|
al@700
|
2314 # Skip pkgs listed in $PKGS_DB/blocked-packages.list
|
gokhlayeh@536
|
2315 if $(grep -qs "^$PACKAGE" $BLOCKED); then
|
pankso@598
|
2316 blocked_count=$(($blocked_count + 1))
|
al@694
|
2317 emsg "<i 48><c 31> $(_ 'Blocked')</c>"
|
gokhlayeh@536
|
2318 break
|
gokhlayeh@536
|
2319 fi
|
pankso@598
|
2320
|
gokhlayeh@536
|
2321 new=$(grep "^$PACKAGE |" $pkg_desc | awk '{print $3}')
|
pankso@598
|
2322
|
ben@483
|
2323 if [ "$VERSION" == "$new" ]; then
|
al@694
|
2324 emsg "<i 48><c 34> $(_ 'New build')</c>"
|
ben@483
|
2325 else
|
al@707
|
2326 emsg "<i 48><c 32> $(_ 'New version %s' $new)</c>"
|
ben@483
|
2327 fi
|
ben@483
|
2328 echo "$PACKAGE" >> $UP_LIST
|
gokhlayeh@536
|
2329 break
|
pankso@466
|
2330 fi
|
gokhlayeh@536
|
2331 done
|
pankso@466
|
2332 done
|
pankso@466
|
2333 sed -i /^$/d $UP_LIST
|
pascal@648
|
2334 upnb=$(wc -l < $UP_LIST)
|
pankso@496
|
2335 pkgs=$(ls | wc -l)
|
pankso@598
|
2336 time=$(($(date +%s) - $time))
|
pankso@480
|
2337 if [ "$upnb" = 0 ]; then
|
pankso@480
|
2338 install="n"
|
al@694
|
2339 _ 'System is up-to-date...'
|
pankso@598
|
2340 fi
|
al@707
|
2341
|
al@707
|
2342 footer "$(emsg "$(_p \
|
al@707
|
2343 '%s installed package scanned in %ds' \
|
al@707
|
2344 '%s installed packages scanned in %ds' $pkgs \
|
al@707
|
2345 "<c 32>$pkgs</c>" $time)")"
|
al@707
|
2346
|
pankso@598
|
2347 if [ "$upnb" != 0 ]; then
|
al@707
|
2348 blocked="$(_p \
|
al@707
|
2349 '%s blocked' '%s blocked' $blocked_count \
|
al@707
|
2350 $blocked_count)"
|
al@707
|
2351
|
al@707
|
2352 boldify "$(_p \
|
al@707
|
2353 'You have %s available upgrade (%s)' \
|
al@707
|
2354 'You have %s available upgrades (%s)' $upnb \
|
al@707
|
2355 $upnb "$blocked")"
|
al@603
|
2356 newline
|
pankso@480
|
2357 fi
|
pankso@466
|
2358 # Pkgs to upgrade ? Skip, let install them all or ask user
|
pankso@466
|
2359 [ "$install" == "n" ] && exit 0
|
pankso@480
|
2360 if [ "$upnb" -gt 0 ]; then
|
pankso@466
|
2361 if [ "$install" == "y" ]; then
|
pankso@466
|
2362 continue
|
pankso@466
|
2363 else
|
al@707
|
2364 confirm "$(_ 'Do you wish to install them now? (y/N)')"
|
al@707
|
2365 answer=$?
|
pankso@466
|
2366 fi
|
al@707
|
2367 case "$answer" in
|
al@707
|
2368 0)
|
al@691
|
2369 for pkg in $(cat $UP_LIST); do
|
pankso@466
|
2370 echo 'y' | tazpkg get-install $pkg --forced
|
pankso@502
|
2371 done
|
paul@554
|
2372 # List is generated each time and must be cleaned so
|
paul@662
|
2373 # tazpkg-notify doesn't find upgrades anymore.
|
al@707
|
2374 rm $UP_LIST; touch $UP_LIST ;;
|
pankso@466
|
2375 *)
|
al@694
|
2376 _ 'Leaving without any upgrades installed.'
|
al@603
|
2377 newline
|
pankso@466
|
2378 exit 0 ;;
|
pankso@466
|
2379 esac
|
pankso@466
|
2380 fi
|
pankso@600
|
2381 newline ;;
|
al@694
|
2382
|
al@694
|
2383
|
pascal@152
|
2384 bugs)
|
pascal@152
|
2385 # Show known bugs in package(s)
|
pascal@152
|
2386 cd $INSTALLED
|
pascal@159
|
2387 shift
|
pascal@159
|
2388 LIST=$@
|
al@694
|
2389 [ -n "$LIST" ] || LIST=$(ls)
|
al@694
|
2390 MSG=$(_n 'No known bugs.')
|
pascal@152
|
2391 for PACKAGE in $LIST; do
|
pascal@152
|
2392 BUGS=""
|
pascal@154
|
2393 EXTRAVERSION=""
|
pascal@152
|
2394 . $PACKAGE/receipt
|
pascal@152
|
2395 if [ -n "$BUGS" ]; then
|
al@694
|
2396 MSG=$(_n 'Bug list completed')
|
pankso@600
|
2397 newline
|
al@707
|
2398 _ 'Bugs in package "%s" version %s:' $PACKAGE $VERSION$EXTRAVERSION
|
pascal@152
|
2399 cat <<EOT
|
pascal@152
|
2400 $BUGS
|
pascal@152
|
2401 EOT
|
pascal@152
|
2402 fi
|
pascal@152
|
2403 done
|
pankso@309
|
2404 echo "$MSG" ;;
|
al@694
|
2405
|
al@694
|
2406
|
pascal@25
|
2407 check)
|
MikeDSmith25@135
|
2408 # Check installed packages set.
|
al@603
|
2409 check_root $@
|
pankso@598
|
2410
|
gokhlayeh@386
|
2411 # Get repositories priority list.
|
gokhlayeh@386
|
2412 look_for_priority
|
pankso@598
|
2413
|
pascal@25
|
2414 cd $INSTALLED
|
al@694
|
2415 for PACKAGE in $(ls); do
|
al@707
|
2416
|
pascal@122
|
2417 if [ ! -f $PACKAGE/receipt ]; then
|
al@707
|
2418 _ 'The package "%s" installation has not completed' $PACKAGE
|
pascal@122
|
2419 continue
|
pascal@122
|
2420 fi
|
al@707
|
2421
|
pascal@29
|
2422 DEPENDS=""
|
pascal@114
|
2423 EXTRAVERSION=""
|
pascal@29
|
2424 . $PACKAGE/receipt
|
pascal@29
|
2425 if [ -s $PACKAGE/modifiers ]; then
|
al@707
|
2426 _ 'The package "%s" has been modified by:' $PACKAGE-$VERSION$EXTRAVERSION
|
pascal@29
|
2427 for i in $(cat $PACKAGE/modifiers); do
|
pascal@29
|
2428 echo " $i"
|
pascal@29
|
2429 done
|
pascal@29
|
2430 fi
|
al@707
|
2431
|
al@707
|
2432 MSG="$(_n 'Files lost from package "%s":' $PACKAGE-$VERSION$EXTRAVERSION)\n"
|
pascal@25
|
2433 while read file; do
|
pascal@25
|
2434 [ -e "$file" ] && continue
|
pascal@25
|
2435 if [ -L "$file" ]; then
|
al@694
|
2436 MSG="$MSG $(_n 'target of symlink')"
|
pascal@25
|
2437 fi
|
pascal@25
|
2438 echo -e "$MSG $file"
|
pascal@25
|
2439 MSG=""
|
pascal@25
|
2440 done < $PACKAGE/files.list
|
al@707
|
2441
|
al@707
|
2442 MSG="$(_n 'Missing dependencies for package "%s":' $PACKAGE-$VERSION$EXTRAVERSION)\n"
|
pascal@25
|
2443 for i in $DEPENDS; do
|
pascal@25
|
2444 [ -d $i ] && continue
|
pascal@290
|
2445 [ -d $(equivalent_pkg $i) ] && continue
|
pascal@25
|
2446 echo -e "$MSG $i"
|
pascal@25
|
2447 MSG=""
|
pascal@25
|
2448 done
|
al@707
|
2449
|
al@707
|
2450 MSG="$(_n 'Dependencies loop between "%s" and:' $PACKAGE)\n"
|
pascal@122
|
2451 ALL_DEPS=""
|
pascal@122
|
2452 check_for_deps_loop $PACKAGE $DEPENDS
|
pascal@25
|
2453 done
|
al@694
|
2454
|
al@694
|
2455 _ 'Looking for known bugs...'
|
pascal@152
|
2456 tazpkg bugs
|
al@694
|
2457
|
al@707
|
2458 if [ "$2" == "--full" ]; then
|
al@707
|
2459 separator
|
al@707
|
2460
|
slaxemulator@588
|
2461 for file in */$CHECKSUM; do
|
pascal@177
|
2462 CONFIG_FILES=""
|
pascal@177
|
2463 . $(dirname "$file")/receipt
|
pascal@106
|
2464 [ -s "$file" ] || continue
|
pascal@177
|
2465 while read md5 f; do
|
pascal@177
|
2466 [ -f $f ] || continue
|
pascal@177
|
2467 for i in $CONFIG_FILES; do
|
pascal@177
|
2468 case "$f" in
|
al@694
|
2469 $i|$i/*) continue 2;;
|
pascal@177
|
2470 esac
|
pascal@177
|
2471 done
|
pascal@177
|
2472 echo "$md5 $f"
|
slaxemulator@588
|
2473 done < "$file" | $CHECKSUM -c - 2> /dev/null | \
|
al@707
|
2474 grep -v OK$ | sed "s/FAILED$/$CHECKSUM MISMATCH/"
|
pascal@106
|
2475 done
|
al@707
|
2476
|
pascal@60
|
2477 FILES=" "
|
pascal@60
|
2478 for file in $(cat */files.list); do
|
pascal@60
|
2479 [ -d "$file" ] && continue
|
pascal@60
|
2480 case "$FILES" in *\ $file\ *) continue;; esac
|
pascal@377
|
2481 [ $(grep "^$(echo $file | grepesc)$" */files.list 2> /dev/null | \
|
pascal@60
|
2482 wc -l) -gt 1 ] || continue
|
pascal@60
|
2483 FILES="$FILES$file "
|
al@707
|
2484 _ 'The following packages provide file "%s":' $file
|
al@694
|
2485 grep -l "^$(echo $file | grepesc)$" */files.list | \
|
al@694
|
2486 while read f; do
|
pascal@60
|
2487 pkg=${f%/files.list}
|
pascal@60
|
2488 if [ -f $pkg/modifiers ]; then
|
al@707
|
2489 overriders=$(_n '(overridden by %s)' "$(tr '\n' ' ' | sed 's| $||' < $pkg/modifiers)")
|
al@603
|
2490 else
|
al@633
|
2491 overriders=''
|
pascal@60
|
2492 fi
|
al@633
|
2493 echo -n " $pkg $overriders"
|
pankso@600
|
2494 newline
|
pascal@60
|
2495 done
|
pascal@60
|
2496 done
|
al@707
|
2497
|
al@694
|
2498 MSG="$(_n 'No package has installed the following files:')\n"
|
al@694
|
2499 find /etc /bin /sbin /lib /usr /var/www -not -type d 2>/dev/null | \
|
al@694
|
2500 while read file; do
|
pascal@73
|
2501 case "$file" in *\[*) continue;; esac
|
pascal@377
|
2502 grep -q "^$(echo $file | grepesc)$" */files.list && continue
|
pascal@73
|
2503 echo -e "$MSG $file"
|
pascal@73
|
2504 MSG=""
|
pascal@73
|
2505 done
|
pascal@60
|
2506 fi
|
al@694
|
2507 _ 'Check completed.'; echo ;;
|
al@694
|
2508
|
al@694
|
2509
|
pankso@10
|
2510 block)
|
pankso@10
|
2511 # Add a pkg name to the list of blocked packages.
|
al@603
|
2512 check_root $@
|
pankso@10
|
2513 check_for_package_on_cmdline
|
pankso@600
|
2514 newline
|
pascal@223
|
2515 if grep -qs "^$PACKAGE" $BLOCKED; then
|
al@707
|
2516 _ 'Package "%s" is already in the blocked packages list.' $PACKAGE
|
pankso@10
|
2517 else
|
al@707
|
2518 action 'Add package "%s" to: %s...' $PACKAGE $BLOCKED
|
pankso@10
|
2519 echo $PACKAGE >> $BLOCKED
|
pankso@10
|
2520 status
|
pascal@183
|
2521 # Log this activity
|
pascal@183
|
2522 . $INSTALLED/$PACKAGE/receipt
|
al@603
|
2523 log_pkg Blocked
|
pankso@10
|
2524 fi
|
pankso@600
|
2525 newline ;;
|
al@694
|
2526
|
al@694
|
2527
|
pankso@10
|
2528 unblock)
|
MikeDSmith25@135
|
2529 # Remove a pkg name from the list of blocked packages.
|
al@603
|
2530 check_root $@
|
pankso@10
|
2531 check_for_package_on_cmdline
|
pankso@600
|
2532 newline
|
pascal@223
|
2533 if grep -qs "^$PACKAGE" $BLOCKED; then
|
al@707
|
2534 action 'Removing package "%s" from: %s...' $PACKAGE $BLOCKED
|
pankso@10
|
2535 sed -i s/$PACKAGE/''/ $BLOCKED
|
pankso@10
|
2536 sed -i '/^$/d' $BLOCKED
|
pankso@10
|
2537 status
|
pascal@183
|
2538 # Log this activity
|
pascal@183
|
2539 . $INSTALLED/$PACKAGE/receipt
|
al@603
|
2540 log_pkg Unblocked
|
pankso@10
|
2541 else
|
al@707
|
2542 _ 'Package "%s" is not in the blocked packages list.' $PACKAGE
|
pankso@10
|
2543 fi
|
pankso@600
|
2544 newline ;;
|
al@694
|
2545
|
al@694
|
2546
|
pankso@6
|
2547 get)
|
al@603
|
2548 # Download a package with wget.
|
al@603
|
2549 check_root $@
|
pankso@6
|
2550 check_for_package_on_cmdline
|
pankso@6
|
2551 check_for_packages_list
|
pankso@598
|
2552
|
slaxemulator@478
|
2553 [ "$root" ] && ROOT="$root" && check_base_dir "$root"
|
slaxemulator@478
|
2554 if [ "$rootconfig" ]; then
|
slaxemulator@478
|
2555 if [ "$root" ]; then
|
slaxemulator@478
|
2556 CACHE_DIR=$root/$CACHE_DIR
|
slaxemulator@478
|
2557 SAVE_CACHE_DIR=$CACHE_DIR
|
al@700
|
2558 PKGS_DB=$root/$PKGS_DB
|
slaxemulator@478
|
2559 else
|
al@694
|
2560 _ 'rootconfig needs --root= option used.' >&2
|
slaxemulator@478
|
2561 exit 1
|
slaxemulator@478
|
2562 fi
|
slaxemulator@478
|
2563 fi
|
pankso@598
|
2564
|
gokhlayeh@386
|
2565 # Get repositories priority list.
|
gokhlayeh@386
|
2566 look_for_priority
|
pankso@598
|
2567
|
slaxemulator@478
|
2568 CURRENT_DIR=$PWD
|
pankso@6
|
2569 check_for_package_in_list
|
slaxemulator@478
|
2570 cd $CACHE_DIR
|
slaxemulator@478
|
2571 if [ -f "$PACKAGE.tazpkg" ]; then
|
al@707
|
2572 _ 'Package "%s" already in the cache' $PACKAGE
|
slaxemulator@478
|
2573 # Check package download was finished
|
slaxemulator@478
|
2574 tail -c 2k $PACKAGE.tazpkg | fgrep -q 00000000TRAILER || {
|
al@707
|
2575 _ 'Continuing package "%s" download' $PACKAGE
|
slaxemulator@478
|
2576 download $PACKAGE.tazpkg
|
slaxemulator@478
|
2577 }
|
slaxemulator@588
|
2578 if [ "$($CHECKSUM $PACKAGE.tazpkg)" != "$(fgrep " $PACKAGE.tazpkg" $rep/packages.$SUM)" ]; then
|
slaxemulator@378
|
2579 rm -f $PACKAGE.tazpkg
|
slaxemulator@378
|
2580 download $PACKAGE.tazpkg
|
slaxemulator@378
|
2581 fi
|
slaxemulator@378
|
2582 else
|
slaxemulator@378
|
2583 download $PACKAGE.tazpkg
|
slaxemulator@378
|
2584 fi
|
slaxemulator@478
|
2585 PACKAGE_FILE=$CACHE_DIR/$PACKAGE.tazpkg
|
pankso@658
|
2586 cp -a $PACKAGE_FILE $CURRENT_DIR ;;
|
al@694
|
2587
|
al@694
|
2588
|
pankso@504
|
2589 get-install|-gi)
|
pankso@6
|
2590 # Download and install a package.
|
al@603
|
2591 check_root $@
|
pankso@6
|
2592 check_for_package_on_cmdline
|
pankso@6
|
2593 check_for_packages_list
|
pankso@598
|
2594
|
pascal@121
|
2595 DO_CHECK=""
|
gokhlayeh@406
|
2596 [ "$forced" ] && DO_CHECK=no
|
gokhlayeh@429
|
2597 [ "$root" ] && ROOT="$root" && check_base_dir "$root"
|
gokhlayeh@406
|
2598 [ "$list" ] && INSTALL_LIST="$list"
|
gokhlayeh@431
|
2599 if [ "$rootconfig" ]; then
|
gokhlayeh@429
|
2600 if [ "$root" ]; then
|
gokhlayeh@429
|
2601 CACHE_DIR=$root/$CACHE_DIR
|
gokhlayeh@436
|
2602 SAVE_CACHE_DIR=$CACHE_DIR
|
al@700
|
2603 PKGS_DB=$root/$PKGS_DB
|
gokhlayeh@429
|
2604 else
|
al@694
|
2605 _ 'rootconfig needs --root= option used.' >&2
|
gokhlayeh@429
|
2606 exit 1
|
gokhlayeh@429
|
2607 fi
|
gokhlayeh@429
|
2608 fi
|
gokhlayeh@436
|
2609
|
gokhlayeh@436
|
2610 # Get repositories priority list.
|
gokhlayeh@436
|
2611 look_for_priority
|
gokhlayeh@436
|
2612
|
pascal@202
|
2613 AUTOEXEC="no"
|
gokhlayeh@416
|
2614 if ! check_for_package_in_list check; then
|
pascal@648
|
2615 CACHE_DIR="${CACHE_DIR%/*}/get"
|
pascal@648
|
2616 [ -d "$CACHE_DIR" ] || mkdir -p $CACHE_DIR
|
pascal@648
|
2617 if download_get_script $PACKAGE /tmp/$PACKAGE.$$ ; then
|
pascal@648
|
2618 install_package_from_get_script /tmp/$PACKAGE.$$ $ROOT
|
pascal@202
|
2619 exit 0
|
pascal@648
|
2620 else
|
pascal@648
|
2621 PACKAGE=get-$PACKAGE
|
pascal@648
|
2622 AUTOEXEC=$PACKAGE
|
pascal@648
|
2623 check_for_package_in_list
|
pascal@648
|
2624 if [ -n "$(get_installed_package_pathname $PACKAGE $ROOT)" ]; then
|
pascal@648
|
2625 $AUTOEXEC $ROOT
|
pascal@648
|
2626 exit 0
|
pascal@648
|
2627 fi
|
pascal@202
|
2628 fi
|
gokhlayeh@416
|
2629 fi
|
pankso@6
|
2630 # Check if forced install.
|
gokhlayeh@423
|
2631 if ! [ "$forced" ]; then
|
pascal@121
|
2632 check_for_installed_package $ROOT
|
pankso@6
|
2633 fi
|
pankso@6
|
2634 cd $CACHE_DIR
|
pankso@6
|
2635 if [ -f "$PACKAGE.tazpkg" ]; then
|
al@707
|
2636 _ 'Package "%s" already in the cache' $PACKAGE
|
MikeDSmith25@135
|
2637 # Check package download was finished
|
gokhlayeh@409
|
2638 tail -c 2k $PACKAGE.tazpkg | fgrep -q 00000000TRAILER || {
|
al@707
|
2639 _ 'Continuing package "%s" download' $PACKAGE
|
pascal@108
|
2640 download $PACKAGE.tazpkg
|
pascal@108
|
2641 }
|
slaxemulator@588
|
2642 if [ "$($CHECKSUM $PACKAGE.tazpkg)" != "$(fgrep " $PACKAGE.tazpkg" $rep/packages.$SUM)" ]; then
|
slaxemulator@375
|
2643 rm -f $PACKAGE.tazpkg
|
pascal@374
|
2644 download $PACKAGE.tazpkg
|
pascal@374
|
2645 fi
|
pankso@6
|
2646 else
|
pankso@600
|
2647 newline
|
pascal@17
|
2648 download $PACKAGE.tazpkg
|
pankso@6
|
2649 fi
|
pankso@14
|
2650 PACKAGE_FILE=$CACHE_DIR/$PACKAGE.tazpkg
|
al@700
|
2651 [ "$rootconfig" ] && PKGS_DB=${PKGS_DB#$root}
|
pascal@121
|
2652 install_package $ROOT
|
pankso@598
|
2653 [ "$AUTOEXEC" != "no" ] && $PACKAGE $ROOT
|
pankso@598
|
2654 update_desktop_database $ROOT
|
slaxemulator@369
|
2655 update_mime_database $ROOT ;;
|
al@694
|
2656
|
al@694
|
2657
|
pankso@504
|
2658 clean-cache|-cc)
|
pankso@6
|
2659 # Remove all downloaded packages.
|
al@603
|
2660 check_root $@
|
pankso@499
|
2661 files=$(find $CACHE_DIR -name *.tazpkg | wc -l)
|
al@707
|
2662 size=$(du -hs $CACHE_DIR | cut -f1 | sed 's|\.0||'); [ $files == "0" ] && size="0K"
|
al@707
|
2663 title 'Path: %s' $CACHE_DIR
|
al@603
|
2664 action "Cleaning cache directory..."
|
pankso@6
|
2665 rm -rf $CACHE_DIR/*
|
al@603
|
2666 status
|
al@707
|
2667
|
al@707
|
2668 footer "$(_p \
|
al@707
|
2669 '%s file removed from cache (%s).' \
|
al@707
|
2670 '%s files removed from cache (%s).' $files \
|
al@707
|
2671 "$(colorize 32 "$files")" $size)"
|
al@694
|
2672 ;;
|
al@694
|
2673
|
al@694
|
2674
|
pascal@187
|
2675 list-undigest)
|
pascal@187
|
2676 # list undigest URLs.
|
pascal@187
|
2677 if [ "$2" = "--box" ]; then
|
al@700
|
2678 for i in $PKGS_DB/undigest/*/mirror; do
|
pascal@187
|
2679 [ -f $i ] || continue
|
pascal@187
|
2680 echo "$(basename $(dirname $i))|$(cat $i)"
|
pascal@187
|
2681 done
|
pascal@187
|
2682 else
|
al@603
|
2683 title 'Current undigest(s)'
|
al@700
|
2684 for i in $PKGS_DB/undigest/*/mirror; do
|
pascal@187
|
2685 if [ ! -f $i ]; then
|
al@694
|
2686 _ 'No undigest mirror found.'
|
pascal@187
|
2687 exit 1
|
pascal@187
|
2688 fi
|
pascal@187
|
2689 echo "$(basename $(dirname $i)) $(cat $i)"
|
pascal@187
|
2690 done
|
pankso@600
|
2691 newline
|
pankso@309
|
2692 fi ;;
|
al@694
|
2693
|
al@694
|
2694
|
pascal@187
|
2695 remove-undigest)
|
pascal@187
|
2696 # remove undigest URL.
|
al@603
|
2697 check_root $@
|
gokhlayeh@388
|
2698 undigest="$2"
|
al@700
|
2699 if [ -d $PKGS_DB/undigest/$2 ]; then
|
al@707
|
2700 confirm "$(_ 'Remove "%s" undigest? (y/N)' $undigest)"
|
al@603
|
2701 if [ $? = 0 ]; then
|
al@707
|
2702 action 'Removing "%s" undigest...' $undigest
|
al@700
|
2703 rm -rf $PKGS_DB/undigest/$2
|
pascal@187
|
2704 status
|
al@700
|
2705 rmdir $PKGS_DB/undigest 2> /dev/null
|
pascal@187
|
2706 fi
|
pascal@187
|
2707 else
|
al@707
|
2708 _ 'Undigest "%s" not found' $undigest
|
pankso@309
|
2709 fi ;;
|
al@694
|
2710
|
al@694
|
2711
|
pascal@187
|
2712 add-undigest|setup-undigest)
|
pascal@187
|
2713 # Add undigest URL.
|
al@603
|
2714 check_root $@
|
pascal@187
|
2715 undigest=$2
|
al@700
|
2716 [ -d $PKGS_DB/undigest ] || mkdir $PKGS_DB/undigest
|
pascal@187
|
2717 if [ -z "$undigest" ]; then
|
pascal@187
|
2718 i=1
|
al@700
|
2719 while [ -d $PKGS_DB/undigest/$i ]; do
|
pascal@187
|
2720 i=$(($i+1))
|
pascal@187
|
2721 done
|
pascal@187
|
2722 undigest=$i
|
pascal@187
|
2723 fi
|
al@700
|
2724 if [ ! -d $PKGS_DB/undigest/$undigest ]; then
|
al@707
|
2725 _ 'Creating new undigest "%s".' $undigest
|
al@700
|
2726 mkdir $PKGS_DB/undigest/$undigest
|
pascal@187
|
2727 fi
|
al@700
|
2728 setup_mirror $PKGS_DB/undigest/$undigest $3 ;;
|
al@694
|
2729
|
al@694
|
2730
|
pankso@600
|
2731 setup-mirror|-sm)
|
pankso@6
|
2732 # Change mirror URL.
|
al@603
|
2733 check_root $@
|
al@700
|
2734 setup_mirror $PKGS_DB $2 ;;
|
al@694
|
2735
|
al@694
|
2736
|
erjo@56
|
2737 reconfigure)
|
erjo@56
|
2738 # Replay post_install from receipt
|
erjo@56
|
2739 check_for_package_on_cmdline
|
al@603
|
2740 check_root $@
|
pascal@250
|
2741 ROOT=""
|
pascal@250
|
2742 while [ -n "$3" ]; do
|
pascal@250
|
2743 case "$3" in
|
al@694
|
2744 --root=*)
|
al@694
|
2745 ROOT="${3#--root=}/" ;;
|
al@694
|
2746 *)
|
al@694
|
2747 shift 2
|
al@694
|
2748 u_opt="$*"
|
al@694
|
2749 newline >&2
|
al@707
|
2750 _ 'Unknown option "%s".' $u_opt >&2
|
al@694
|
2751 exit 1 ;;
|
pascal@250
|
2752 esac
|
pascal@250
|
2753 shift
|
pascal@250
|
2754 done
|
pascal@250
|
2755 if [ -d "$ROOT$INSTALLED/$PACKAGE" ]; then
|
pascal@250
|
2756 check_for_receipt $ROOT
|
erjo@56
|
2757 # Check for post_install
|
pascal@250
|
2758 if grep -q ^post_install $ROOT$INSTALLED/$PACKAGE/receipt; then
|
pascal@250
|
2759 . $ROOT$INSTALLED/$PACKAGE/receipt
|
pascal@250
|
2760 post_install $ROOT
|
pascal@183
|
2761 # Log this activity
|
al@603
|
2762 [ -n "$ROOT" ] || log_pkg Reconfigured
|
pankso@279
|
2763 else
|
pankso@600
|
2764 newline
|
al@707
|
2765 _ 'Nothing to do for package "%s".' $PACKAGE
|
erjo@56
|
2766 fi
|
erjo@56
|
2767 else
|
pankso@600
|
2768 newline
|
al@707
|
2769 _ 'Package "%s" is not installed.' $PACKAGE
|
al@707
|
2770 _ 'Install package with "%s" or "%s"' 'tazpkg install' 'tazpkg get-install'
|
pankso@600
|
2771 newline
|
pankso@309
|
2772 fi ;;
|
al@694
|
2773
|
al@694
|
2774
|
pankso@55
|
2775 shell)
|
pankso@653
|
2776 # TazPKG SHell
|
pankso@55
|
2777 if test $(id -u) = 0 ; then
|
pankso@55
|
2778 PROMPT="\\033[1;33mtazpkg\\033[0;39m# "
|
pankso@55
|
2779 else
|
pankso@55
|
2780 PROMPT="\\033[1;33mtazpkg\\033[0;39m> "
|
pankso@55
|
2781 fi
|
pankso@55
|
2782 if [ ! "$2" = "--noheader" ]; then
|
pankso@55
|
2783 clear
|
pankso@653
|
2784 title 'TazPKG SHell.'
|
al@694
|
2785 _ "Type 'usage' to list all available commands or 'quit' or 'q' to exit."
|
pankso@600
|
2786 newline
|
pankso@55
|
2787 fi
|
al@694
|
2788 while true; do
|
pankso@55
|
2789 echo -en "$PROMPT"; read cmd
|
pankso@55
|
2790 case $cmd in
|
pankso@55
|
2791 q|quit)
|
pankso@55
|
2792 break ;;
|
pankso@55
|
2793 shell)
|
al@694
|
2794 _ 'You are already running a TazPKG SHell.' ;;
|
pankso@55
|
2795 su)
|
pankso@55
|
2796 su -c 'exec tazpkg shell --noheader' && break ;;
|
pankso@55
|
2797 "")
|
pankso@55
|
2798 continue ;;
|
pankso@55
|
2799 *)
|
pankso@55
|
2800 tazpkg $cmd ;;
|
pankso@55
|
2801 esac
|
pankso@309
|
2802 done ;;
|
al@694
|
2803
|
al@694
|
2804
|
pascal@205
|
2805 depends)
|
paul@247
|
2806 # Display dependencies tree
|
pascal@205
|
2807 cd $INSTALLED
|
pascal@205
|
2808 ALL_DEPS=""
|
pascal@205
|
2809 if [ -f $2/receipt ]; then
|
pascal@205
|
2810 dep_scan $2 ""
|
pankso@309
|
2811 fi ;;
|
al@694
|
2812
|
al@694
|
2813
|
pascal@205
|
2814 rdepends)
|
paul@247
|
2815 # Display reverse dependencies tree
|
pascal@205
|
2816 cd $INSTALLED
|
pascal@205
|
2817 ALL_DEPS=""
|
pascal@205
|
2818 if [ -f $2/receipt ]; then
|
pascal@260
|
2819 rdep_scan $2
|
pankso@309
|
2820 fi ;;
|
al@694
|
2821
|
al@694
|
2822
|
pankso@504
|
2823 convert|-c)
|
pascal@262
|
2824 # convert misc package format to .tazpkg
|
pascal@263
|
2825 check_for_package_file
|
al@695
|
2826 tazpkg-convert $@
|
al@695
|
2827 ;;
|
al@694
|
2828
|
al@694
|
2829
|
pascal@263
|
2830 link)
|
pascal@263
|
2831 # link a package from another slitaz installation
|
pascal@263
|
2832 PACKAGE=$2
|
pascal@263
|
2833 if [ ! -d "$TARGET_DIR" -o \
|
pascal@263
|
2834 ! -d "$TARGET_DIR$INSTALLED/$PACKAGE" ]; then
|
al@707
|
2835 _ 'Usage: tazpkg link package_name slitaz_root'
|
al@707
|
2836 longline "$(
|
al@707
|
2837 _n 'Example:'
|
al@707
|
2838 echo -n ' '
|
al@707
|
2839 _ '"%s" will use less than 100k in your running system RAM.' \
|
al@707
|
2840 'tazpkg link openoffice /mnt')"
|
pascal@263
|
2841 exit 1
|
pascal@263
|
2842 fi
|
pascal@263
|
2843 if [ -e "$INSTALLED/$PACKAGE" ]; then
|
al@707
|
2844 _ 'Package "%s" is already installed.' $PACKAGE
|
pascal@263
|
2845 exit 1
|
pascal@263
|
2846 fi
|
pascal@263
|
2847 ln -s $TARGET_DIR$INSTALLED/$PACKAGE $INSTALLED
|
pascal@266
|
2848 DEPENDS="$(. $INSTALLED/$PACKAGE/receipt ; echo $DEPENDS)"
|
pascal@266
|
2849 MISSING=""
|
pascal@266
|
2850 for i in $DEPENDS; do
|
pascal@266
|
2851 [ -e $INSTALLED/$i ] && continue
|
pascal@266
|
2852 MISSING="$MISSING$i "
|
al@707
|
2853 _ 'Missing: %s' $i
|
pascal@266
|
2854 done
|
pascal@266
|
2855 if [ -n "$MISSING" ]; then
|
pankso@600
|
2856 newline
|
al@696
|
2857 confirm "$(_ 'Link all missing dependencies? (y/N)')"
|
al@603
|
2858 answer=$?
|
pankso@600
|
2859 newline
|
al@603
|
2860 if [ $answer = 0 ]; then
|
pascal@266
|
2861 for i in $MISSING; do
|
pascal@266
|
2862 tazpkg link $i $TARGET_DIR
|
pascal@266
|
2863 done
|
pascal@266
|
2864 else
|
pankso@600
|
2865 newline
|
al@707
|
2866 _ 'Leaving dependencies unresolved for package "%s"' $PACKAGE
|
al@694
|
2867 _ 'The package is installed but probably will not work.'
|
pankso@600
|
2868 newline
|
pascal@266
|
2869 fi
|
pascal@266
|
2870 fi
|
pascal@266
|
2871 . $INSTALLED/$PACKAGE/receipt
|
pascal@266
|
2872 if grep -q ^pre_install $INSTALLED/$PACKAGE/receipt; then
|
pascal@266
|
2873 pre_install
|
pascal@266
|
2874 fi
|
pascal@263
|
2875 while read path; do
|
pascal@263
|
2876 [ -e $path ] && continue
|
pascal@263
|
2877 while true; do
|
pascal@263
|
2878 dir=$(dirname $path)
|
pascal@263
|
2879 [ -e $dir ] && break
|
pascal@263
|
2880 path=$dir
|
pascal@263
|
2881 done
|
pascal@263
|
2882 ln -s $TARGET_DIR$path $dir
|
pascal@263
|
2883 done < $INSTALLED/$PACKAGE/files.list
|
pascal@266
|
2884 if grep -q ^post_install $INSTALLED/$PACKAGE/receipt; then
|
pascal@266
|
2885 post_install
|
pankso@309
|
2886 fi ;;
|
al@694
|
2887
|
al@694
|
2888
|
pankso@6
|
2889 usage|*)
|
pascal@119
|
2890 # Print a short help or give usage for an unknown or empty command.
|
pankso@279
|
2891 usage ;;
|
pankso@6
|
2892 esac
|
pankso@6
|
2893
|
pankso@6
|
2894 exit 0
|