mirror of
https://github.com/zuno/slackpkgplus
synced 2025-01-13 20:01:04 +01:00
Version 0.9.5 - 28/Aug/2013
- fixed a problem with some compat32 packages - fixed a issue about packages selection with the official slackware repository (thanks to phenixia2003)
This commit is contained in:
parent
dd5e73aca3
commit
5f88cbb071
3 changed files with 48 additions and 20 deletions
|
@ -1,3 +1,7 @@
|
|||
Version 0.9.5 - 28/Aug/2013
|
||||
- fixed a problem with some compat32 packages
|
||||
- fixed a issue about packages selection with the official slackware repository
|
||||
|
||||
Version 0.9.4 - 27/Aug/2013
|
||||
- fixed a issue when a pattern is used multiple times in argument
|
||||
- fixed a bug in install/upgrade regarding the enhanced priority
|
||||
|
|
|
@ -1,3 +1,8 @@
|
|||
Version 0.9.5 - 28/Aug/2013
|
||||
- fixed a problem with some compat32 packages
|
||||
- fixed a issue about packages selection with the official slackware repository
|
||||
(thanks to phenixia2003)
|
||||
|
||||
Version 0.9.4 - 27/Aug/2013
|
||||
- fixed a issue when a pattern is used multiple times in argument
|
||||
- fixed a bug in install/upgrade regarding the enhanced priority
|
||||
|
|
|
@ -399,6 +399,16 @@ function checkmd5() {
|
|||
[ ! -z "$PREFIX" ] && PRIORITY=( ${PREFIX[*]} ${PRIORITY[*]} )
|
||||
fi
|
||||
|
||||
# -- This flag is set when running slackpkg to manage the multilib :
|
||||
#
|
||||
# slackpkg install|upgrade|reinstall|remove <multilib_repository_name>
|
||||
#
|
||||
# This is used by applyblacklist() to prevent silent exclusion of
|
||||
# multilib package aaa_elflibs-compat32 when /etc/slackpkg/blacklist
|
||||
# contains the pattern aaa_elflibs.
|
||||
#
|
||||
MLREPO_SELELECTED=false
|
||||
|
||||
# -- Ensures the internal blacklist is empty
|
||||
#
|
||||
echo -n "" > ${TMPDIR}/blacklist.slackpkgplus
|
||||
|
@ -416,7 +426,15 @@ function checkmd5() {
|
|||
# be applied too.
|
||||
#
|
||||
function applyblacklist() {
|
||||
grep -vEw -f ${TMPDIR}/blacklist -f ${TMPDIR}/blacklist.slackpkgplus
|
||||
# -- This is to prevent silent exclusion of multilib package
|
||||
# aaa_elflibs-compat32 when /etc/slackpkg/blacklist contains the
|
||||
# pattern aaa_elflibs.
|
||||
if $MLREPO_SELELECTED && grep -q "^aaa_elflibs$" ${TMPDIR}/blacklist && ! grep -q "^aaa_elflibs-compat32$" ${TMPDIR}/blacklist ; then
|
||||
sed -i --expression "s/^aaa_elflibs/#aaa_elflibs/" ${TMPDIR}/blacklist
|
||||
grep -vEw -f ${TMPDIR}/blacklist -f ${TMPDIR}/blacklist.slackpkgplus | grep -v "[ ]aaa_elflibs[ ]"
|
||||
else
|
||||
grep -vEw -f ${TMPDIR}/blacklist -f ${TMPDIR}/blacklist.slackpkgplus
|
||||
fi
|
||||
}
|
||||
|
||||
|
||||
|
@ -452,14 +470,31 @@ function checkmd5() {
|
|||
fi
|
||||
elif grep -q "^SLACKPKGPLUS_${pref}[ ]" ${WORKDIR}/pkglist ; then
|
||||
|
||||
if [ "$CMD" == "remove" ] && echo "$pref" | grep -qi "multilib" ; then
|
||||
echo "$pref" | grep -qi "multilib" && MLREPO_SELELECTED=true
|
||||
|
||||
if $MLREPO_SELELECTED && [ "$CMD" == "remove" ] ; then
|
||||
internal_blacklist "glibc"
|
||||
internal_blacklist "gcc"
|
||||
fi
|
||||
|
||||
package="SLACKPKGPLUS_${pref}"
|
||||
PRIORITYLIST=( ${PRIORITYLIST[*]} SLACKPKGPLUS_${pref}:.* )
|
||||
else
|
||||
elif grep -q "^${pref}[ ]" ${WORKDIR}/pkglist ; then
|
||||
|
||||
# -- ${pref} relates to one of the standard directories (ie
|
||||
# slackware,slackware64,testing,extra,...). In this case,
|
||||
# packages is set to "^${pref}" to avoid packages outside
|
||||
# the given "directories" to be selected. For instance,
|
||||
# without this, if slackpkg+ is configured with the
|
||||
# repositories "multilib" and "microlinux", running
|
||||
# "slackpkg install slackware64" leads to install packages
|
||||
# from slackware64 directory, but also packages from
|
||||
# "multilib" and "microlinux" repositories, because packages
|
||||
# from these repositories are stored in directories whose
|
||||
# names include the word "slackware64".
|
||||
#
|
||||
package="^${pref}"
|
||||
else
|
||||
package=$pref
|
||||
fi
|
||||
|
||||
|
@ -492,22 +527,6 @@ function checkmd5() {
|
|||
fi
|
||||
fi
|
||||
|
||||
if [ "$CMD" == "install-new" ] ; then
|
||||
ls -1 /var/log/packages/*compat32 2>/dev/null | rev | cut -f1 -d/ | cut -f4- -d- | rev | sort > $TMPDIR/installed-compat32-packages.lst
|
||||
|
||||
grep "[[:digit:]]\+compat32[ ]" $WORKDIR/pkglist | cut -f2 -d" " | sort -u > $TMPDIR/available-compat32-packages.lst
|
||||
|
||||
NEWCOMPAT32PKGS=$(comm -3 $TMPDIR/installed-compat32-packages.lst $TMPDIR/available-compat32-packages.lst)
|
||||
|
||||
if [ ! -z "$NEWCOMPAT32PKGS" ] ; then
|
||||
LIST=""
|
||||
|
||||
for pkg in $NEWCOMPAT32PKGS ; do
|
||||
LIST="$LIST $(grep " ${pkg} " $WORKDIR/pkglist | cut -f6,8 -d" " --output-delimiter=".")"
|
||||
done
|
||||
fi
|
||||
fi
|
||||
|
||||
|
||||
if [ "$CMD" == "search" ] || [ "$CMD" == "file-search" ] ; then
|
||||
PATTERN=$(echo $ARG | sed -e 's/\+/\\\+/g' -e 's/\./\\\./g' -e 's/ /\|/g')
|
||||
|
|
Loading…
Reference in a new issue