mirror of
https://github.com/zuno/slackpkgplus
synced 2025-01-15 03:40:49 +01:00
Version 0.9rc2 - 30/Apr/2013
- added config file checks - fixed a bug that try to check gpg even if CHECKGPG is set to off - fixed a bug that show compat32 packages as duplicated - implemented 'slackpkg search'
This commit is contained in:
parent
8a8b27118b
commit
afddae5749
6 changed files with 177 additions and 33 deletions
|
@ -1,3 +1,9 @@
|
||||||
|
Version 0.9rc2 - 30/Apr/2013
|
||||||
|
- added config file checks
|
||||||
|
- fixed a bug that try to check gpg even if CHECKGPG is set to off
|
||||||
|
- fixed a bug that show compat32 packages as duplicated
|
||||||
|
- implemented 'slackpkg search'
|
||||||
|
|
||||||
Version 0.9rc1 - 29/Apr/2013
|
Version 0.9rc1 - 29/Apr/2013
|
||||||
- added some repository
|
- added some repository
|
||||||
|
|
||||||
|
|
|
@ -30,7 +30,7 @@ copy_config_file() {
|
||||||
SRCMIRROR=slackpkgplus.x86.sample
|
SRCMIRROR=slackpkgplus.x86.sample
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
cp usr/doc/slackpkg+-0.9rc1/$SRCMIRROR etc/slackpkg/slackpkgplus.conf.new
|
cp usr/doc/slackpkg+-0.9rc2/$SRCMIRROR etc/slackpkg/slackpkgplus.conf.new
|
||||||
}
|
}
|
||||||
|
|
||||||
copy_config_file
|
copy_config_file
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
VERSION=0.9rc1
|
VERSION=0.9rc2
|
||||||
BUILD=3mt
|
BUILD=1mt
|
||||||
|
|
||||||
CWD=`pwd`
|
CWD=`pwd`
|
||||||
PKG=$CWD/../slackpkg+-$VERSION
|
PKG=$CWD/../slackpkg+-$VERSION
|
||||||
|
|
|
@ -8,7 +8,7 @@ fi
|
||||||
|
|
||||||
if [ "$SLACKPKGPLUS" = "on" ];then
|
if [ "$SLACKPKGPLUS" = "on" ];then
|
||||||
|
|
||||||
REPOPLUS=${REPOPLUS[*]}
|
REPOPLUS=$(echo "${REPOPLUS[*]} ${PKGS_PRIORITY[*]} ${!MIRRORPLUS[*]}"|sed 's/ /\n/g'|sed 's/:.*//'|awk '{if(!a[$1]++)print $1}')
|
||||||
PRIORITY=( ${PRIORITY[*]} slackpkgplus_$(echo $REPOPLUS|sed 's/ / slackpkgplus_/g') )
|
PRIORITY=( ${PRIORITY[*]} slackpkgplus_$(echo $REPOPLUS|sed 's/ / slackpkgplus_/g') )
|
||||||
|
|
||||||
|
|
||||||
|
@ -82,6 +82,7 @@ if [ "$SLACKPKGPLUS" = "on" ];then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ $(basename $1) = "CHECKSUMS.md5.asc" ];then
|
if [ $(basename $1) = "CHECKSUMS.md5.asc" ];then
|
||||||
|
if [ "CHECKGPG" = "on" ];then
|
||||||
for PREPO in $REPOPLUS;do
|
for PREPO in $REPOPLUS;do
|
||||||
URLFILE=${MIRRORPLUS[${PREPO/slackpkgplus_}]}CHECKSUMS.md5.asc
|
URLFILE=${MIRRORPLUS[${PREPO/slackpkgplus_}]}CHECKSUMS.md5.asc
|
||||||
if echo $URLFILE | grep -q "^file://" ; then
|
if echo $URLFILE | grep -q "^file://" ; then
|
||||||
|
@ -111,6 +112,9 @@ if [ "$SLACKPKGPLUS" = "on" ];then
|
||||||
sleep 5
|
sleep 5
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
else
|
||||||
|
checkgpg ${TMPDIR}/CHECKSUMS.md5 >/dev/null
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
if [ $(basename $1) = "ChangeLog.txt" ];then
|
if [ $(basename $1) = "ChangeLog.txt" ];then
|
||||||
for PREPO in $REPOPLUS;do
|
for PREPO in $REPOPLUS;do
|
||||||
|
@ -246,7 +250,7 @@ if [ "$SLACKPKGPLUS" = "on" ];then
|
||||||
if [ "$CMD" == "install-new" ] ; then
|
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
|
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 > $TMPDIR/available-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)
|
NEWCOMPAT32PKGS=$(comm -3 $TMPDIR/installed-compat32-packages.lst $TMPDIR/available-compat32-packages.lst)
|
||||||
|
|
||||||
|
@ -259,4 +263,135 @@ if [ "$SLACKPKGPLUS" = "on" ];then
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
function searchPackages() {
|
||||||
|
local i
|
||||||
|
|
||||||
|
INPUTLIST=$@
|
||||||
|
|
||||||
|
grep -vE "(^#|^[[:blank:]]*$)" ${CONF}/blacklist > ${TMPDIR}/blacklist
|
||||||
|
if echo $CMD | grep -q install ; then
|
||||||
|
ls -1 /var/log/packages/* | awk -f /usr/libexec/slackpkg/pkglist.awk > ${TMPDIR}/tmplist
|
||||||
|
else
|
||||||
|
ls -1 /var/log/packages/* | awk -f /usr/libexec/slackpkg/pkglist.awk | applyblacklist > ${TMPDIR}/tmplist
|
||||||
|
fi
|
||||||
|
cat ${WORKDIR}/pkglist | applyblacklist > ${TMPDIR}/pkglist
|
||||||
|
|
||||||
|
touch ${TMPDIR}/waiting
|
||||||
|
|
||||||
|
if [ "$CMD" == "search" ] ; then
|
||||||
|
# -- PKGLIST:
|
||||||
|
# temporary file used to store data about packages. It use
|
||||||
|
# the following format:
|
||||||
|
# repository:<repository_name>:basename:<package_basename>:
|
||||||
|
#
|
||||||
|
PKGLIST=$(tempfile --directory=$TMPDIR)
|
||||||
|
PKGINFOS=$(tempfile --directory=$TMPDIR)
|
||||||
|
|
||||||
|
for i in ${PRIORITY[@]}; do
|
||||||
|
DIR="$i"
|
||||||
|
if echo "$DIR" | grep -q "[a-zA-Z0-9]\+[:]" ; then
|
||||||
|
DIR=$(echo "$i" | cut -f2- -d":")
|
||||||
|
fi
|
||||||
|
|
||||||
|
grep "^${DIR}.*${PATTERN}" "${TMPDIR}/pkglist" > $PKGINFOS
|
||||||
|
|
||||||
|
while read PKG ; do
|
||||||
|
PKGDIR=$(echo "$PKG" | cut -f1 -d" ")
|
||||||
|
PKGBASENAME=$(echo "$PKG" | cut -f2 -d" ")
|
||||||
|
PKGFULLNAME=$(echo "$PKG" | cut -f6 -d" ")
|
||||||
|
|
||||||
|
if echo "$PKGDIR" | grep -q "slackpkgplus_" ; then
|
||||||
|
grep -q "^repository:${PKGDIR}:basename:${PKGBASENAME}:" $PKGLIST && continue
|
||||||
|
else
|
||||||
|
grep -q ":basename:${PKGBASENAME}:" $PKGLIST && continue
|
||||||
|
fi
|
||||||
|
LIST="$LIST ${PKGDIR}:${PKGFULLNAME}"
|
||||||
|
echo "repository:${PKGDIR}:basename:${PKGBASENAME}:" >> $PKGLIST
|
||||||
|
done < $PKGINFOS
|
||||||
|
done
|
||||||
|
|
||||||
|
rm -f $PKGLIST $PKGINFOS
|
||||||
|
fi
|
||||||
|
|
||||||
|
LIST=$(echo -e $LIST | tr \ "\n" | uniq )
|
||||||
|
|
||||||
|
rm ${TMPDIR}/waiting
|
||||||
|
|
||||||
|
echo -e "DONE\n"
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function searchlistEX() {
|
||||||
|
local i
|
||||||
|
local BASENAME
|
||||||
|
local RAWNAME
|
||||||
|
local STATUS
|
||||||
|
local INSTPKG
|
||||||
|
local REPO
|
||||||
|
local PNAME
|
||||||
|
|
||||||
|
printf "[ %-16s ] [ %-24s ] [ %-40s ]\n" "Status" "Repository" "Package"
|
||||||
|
for i in $1; do
|
||||||
|
REPO=$(echo "$i" | cut -f1 -d":")
|
||||||
|
PNAME=$(echo "$i" | cut -f2- -d":")
|
||||||
|
|
||||||
|
if echo "$REPO" | grep -q "slackpkgplus_" ; then
|
||||||
|
REPO=$(echo "$REPO" | cut -f2- -d"_")
|
||||||
|
else
|
||||||
|
REPO=""
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "$REPO" ] && [ "$BASENAME" = "$(cutpkg ${PNAME})" ]; then
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
# BASENAME is base package name
|
||||||
|
BASENAME="$(cutpkg ${PNAME})"
|
||||||
|
|
||||||
|
# RAWNAME is Latest available version
|
||||||
|
RAWNAME="${PNAME/%.t[blxg]z/}"
|
||||||
|
|
||||||
|
# Default is uninstalled
|
||||||
|
STATUS="uninstalled"
|
||||||
|
|
||||||
|
# First is the package already installed?
|
||||||
|
# Amazing what a little sleep will do
|
||||||
|
# exclusion is so much nicer :)
|
||||||
|
INSTPKG=$(ls -1 /var/log/packages | \
|
||||||
|
grep -e "^${BASENAME}-[^-]\+-\(${ARCH}\|fw\|noarch\)-[^-]\+")
|
||||||
|
|
||||||
|
# INSTPKG is local version
|
||||||
|
if [ ! "${INSTPKG}" = "" ]; then
|
||||||
|
|
||||||
|
# If installed is it uptodate?
|
||||||
|
if [ "${INSTPKG}" = "${RAWNAME}" ]; then
|
||||||
|
STATUS=" installed "
|
||||||
|
printf " %-16s %-24s %-40s \n" "$STATUS" "$REPO" "$INSTPKG"
|
||||||
|
else
|
||||||
|
STATUS="upgrade"
|
||||||
|
printf " %-16s %-24s %-40s \n" "$STATUS" "$REPO" "$INSTPKG --> ${RAWNAME}"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
printf " %-16s %-24s %-40s \n" "$STATUS" "$REPO" "${RAWNAME}"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ "$CMD" == "search" ] ; then
|
||||||
|
PATTERN=$(echo $ARG | sed -e 's/\+/\\\+/g' -e 's/\./\\\./g' -e 's/ /\|/g')
|
||||||
|
searchPackages $PATTERN
|
||||||
|
|
||||||
|
if [ "$LIST" = "" ]; then
|
||||||
|
echo -e "No package name matches the pattern."
|
||||||
|
else
|
||||||
|
echo -e "The list below shows all packages with name matching \"$PATTERN\".\n"
|
||||||
|
searchlistEX "$LIST"
|
||||||
|
|
||||||
|
# PENDING: file-search must be implemented first.
|
||||||
|
#
|
||||||
|
#echo -e "\nYou can search specific files using \"slackpkg file-search file\".\n"
|
||||||
|
fi
|
||||||
|
cleanup
|
||||||
|
fi
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -11,11 +11,13 @@ SLACKPKGPLUS=on
|
||||||
#PKGS_PRIORITY=( restricted:vlc )
|
#PKGS_PRIORITY=( restricted:vlc )
|
||||||
#
|
#
|
||||||
|
|
||||||
# List repository you want to use (defined below)
|
# List repository you want to use (defined below).
|
||||||
|
# remember to launch 'slackpkg update' if you modify that row.
|
||||||
REPOPLUS=( alienbob restricted slacky ponce )
|
REPOPLUS=( alienbob restricted slacky ponce )
|
||||||
|
|
||||||
|
|
||||||
# Define mirrors (uncomment one or more mirror)
|
|
||||||
|
# Define mirrors (uncomment one or more mirror; remember to add it to REPOPLUS)
|
||||||
# Note: only multilib,alienbob,restricted,slacky,ponce repositories does supports GPG. If you add other
|
# Note: only multilib,alienbob,restricted,slacky,ponce repositories does supports GPG. If you add other
|
||||||
# you may need to disable gpg check in slackpkg.conf
|
# you may need to disable gpg check in slackpkg.conf
|
||||||
|
|
||||||
|
|
|
@ -15,10 +15,11 @@ SLACKPKGPLUS=on
|
||||||
#
|
#
|
||||||
|
|
||||||
# List repository you want to use (defined below)
|
# List repository you want to use (defined below)
|
||||||
|
# # remember to launch 'slackpkg update' if you modify that row.
|
||||||
REPOPLUS=( alienbob restricted slacky ponce )
|
REPOPLUS=( alienbob restricted slacky ponce )
|
||||||
|
|
||||||
|
|
||||||
# Define mirrors (uncomment one or more mirror)
|
# Define mirrors (uncomment one or more mirror; remember to add it to REPOPLUS)
|
||||||
# Note: only multilib,alienbob,restricted,slacky,ponce repositories does supports GPG. If you add other
|
# Note: only multilib,alienbob,restricted,slacky,ponce repositories does supports GPG. If you add other
|
||||||
# you may need to disable gpg check in slackpkg.conf
|
# you may need to disable gpg check in slackpkg.conf
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue