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