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