[pacman-dev] [PATCH] paccache: adding the possibility for multiple cachedirs. (fixed)
Maxim Andersson
thesilentboatman at gmail.com
Mon Aug 25 00:58:50 EDT 2014
Either by specifing several -c parameters or only
one -c parameter with a comma separated value.
One could for example be for the official arch packages
and one for the aur.
Signed-off-by: Maxim Andersson <thesilentboatman at gmail.com>
---
contrib/paccache.sh.in | 89 +++++++++++++++++++++++++++++---------------------
1 file changed, 51 insertions(+), 38 deletions(-)
diff --git a/contrib/paccache.sh.in b/contrib/paccache.sh.in
index 039ac8a..2170d76 100644
--- a/contrib/paccache.sh.in
+++ b/contrib/paccache.sh.in
@@ -23,9 +23,9 @@ shopt -s extglob
declare -r myname='paccache'
declare -r myver='@PACKAGE_VERSION@'
-declare -a candidates=() cmdopts=() whitelist=() blacklist=()
+declare -a cachedirs=() candidates=() cmdopts=() whitelist=() blacklist=()
declare -i delete=0 dryrun=0 filecount=0 move=0 needsroot=0 totalsaved=0 verbose=0
-declare cachedir=@localstatedir@/cache/pacman/pkg delim=$'\n' keep=3 movedir= scanarch=
+declare delim=$'\n' keep=3 movedir= scanarch=
USE_COLOR='y'
@@ -159,25 +159,25 @@ A flexible pacman cache cleaning utility.
Usage: ${myname} <operation> [options] [targets...]
Operations:
- -d, --dryrun perform a dry run, only finding candidate packages.
- -m, --move <dir> move candidate packages to "dir".
- -r, --remove remove candidate packages.
+ -d, --dryrun perform a dry run, only finding candidate packages.
+ -m, --move <dir> move candidate packages to "dir".
+ -r, --remove remove candidate packages.
Options:
- -a, --arch <arch> scan for "arch" (default: all architectures).
- -c, --cachedir <dir> scan "dir" for packages.
- (default: @localstatedir@/cache/pacman/pkg).
- -f, --force apply force to mv(1) and rm(1) operations.
- -h, --help display this help message and exit.
- -i, --ignore <pkgs> ignore "pkgs", comma-separated. Alternatively, specify
- "-" to read package names from stdin, newline-
- delimited.
- -k, --keep <num> keep "num" of each package in the cache (default: 3).
- --nocolor remove color from output.
- -u, --uninstalled target uninstalled packages.
- -v, --verbose increase verbosity. specify up to 3 times.
- -z, --null use null delimiters for candidate names (only with -v
- and -vv).
+ -a, --arch <arch> scan for "arch" (default: all architectures).
+ -c, --cachedir <dirs> scan "dirs" for packages, comma-separated.
+ (default: @localstatedir@/cache/pacman/pkg).
+ -f, --force apply force to mv(1) and rm(1) operations.
+ -h, --help display this help message and exit.
+ -i, --ignore <pkgs> ignore "pkgs", comma-separated. Alternatively,
+ pecify "-" to read package names from stdin, newline-
+ delimited.
+ -k, --keep <num> keep "num" of each package in the cache (default: 3).
+ --nocolor remove color from output.
+ -u, --uninstalled target uninstalled packages.
+ -v, --verbose increase verbosity. specify up to 3 times.
+ -z, --null use null delimiters for candidate names (only with -v
+ and -vv).
EOF
}
@@ -203,7 +203,9 @@ while :; do
scanarch=$2
shift ;;
-c|--cachedir)
- cachedir=$2
+ IFS=',' read -r -a cdrs <<< "$2"
+ cachedirs+=("${cdrs[@]}")
+ unset cdrs
shift ;;
-d|--dryrun)
dryrun=1 ;;
@@ -256,6 +258,9 @@ done
m4_include(../scripts/library/term_colors.sh)
+# setting default cachedir
+cachedirs=${cachedirs:- at localstatedir@/cache/pacman/pkg}
+
# remaining args are a whitelist
whitelist=("$@")
@@ -265,28 +270,36 @@ case $(( dryrun+delete+move )) in
[^1]) die "only one operation may be used at a time" ;;
esac
-[[ -d $cachedir ]] ||
- die "cachedir '%s' does not exist or is not a directory" "$cachedir"
+for cachedir in "${cachedirs[@]}"
+do
+ [[ -d $cachedir ]] ||
+ die "cachedir '%s' does not exist or is not a directory" "$cachedir"
-[[ $movedir && ! -d $movedir ]] &&
- die "destination directory '%s' does not exist or is not a directory" "$movedir"
+ [[ $movedir && ! -d $movedir ]] &&
+ die "destination directory '%s' does not exist or is not a directory" "$movedir"
+
+ if (( move || delete )); then
+ # make it an absolute path since we're about to chdir
+ [[ ${movedir:0:1} != '/' ]] && movedir=$PWD/$movedir
+ [[ ! -w $cachedir || ( $movedir && ! -w $movedir ) ]] && needsroot=1
+ fi
+
+ # unlikely that this will fail, but better make sure
+ cd "$cachedir" >/dev/null || die "failed to chdir to '%s'" "$cachedir"
+
+ # note that these results are returned in an arbitrary order from awk, but
+ # they'll be resorted (in summarize) iff we have a verbosity level set.
+ IFS=$'\n' read -r -d '' -a tmpcandidates < \
+ <(printf '%s\n' *.pkg.tar?(.+([^.])) | pacsort --files |
+ pkgfilter "$keep" "$scanarch" \
+ "${#whitelist[*]}" "${whitelist[@]}" \
+ "${#blacklist[*]}" "${blacklist[@]}")
+
+ candidates+=(${tmpcandidates[@]})
+done
-if (( move || delete )); then
- # make it an absolute path since we're about to chdir
- [[ ${movedir:0:1} != '/' ]] && movedir=$PWD/$movedir
- [[ ! -w $cachedir || ( $movedir && ! -w $movedir ) ]] && needsroot=1
-fi
-# unlikely that this will fail, but better make sure
-cd "$cachedir" >/dev/null || die "failed to chdir to '%s'" "$cachedir"
-# note that these results are returned in an arbitrary order from awk, but
-# they'll be resorted (in summarize) iff we have a verbosity level set.
-IFS=$'\n' read -r -d '' -a candidates < \
- <(printf '%s\n' *.pkg.tar?(.+([^.])) | pacsort --files |
- pkgfilter "$keep" "$scanarch" \
- "${#whitelist[*]}" "${whitelist[@]}" \
- "${#blacklist[*]}" "${blacklist[@]}")
if (( ! ${#candidates[*]} )); then
msg 'no candidate packages found for pruning'
--
2.0.3
More information about the pacman-dev
mailing list