mirror of
https://github.com/moparisthebest/pacman
synced 2025-01-08 12:28:00 -05:00
paccache: add support for multiple cachedirs
Signed-off-by: Maxim Andersson <thesilentboatman@gmail.com>
This commit is contained in:
parent
b00269d9c8
commit
8122fae51a
@ -23,9 +23,9 @@ shopt -s extglob
|
|||||||
declare -r myname='paccache'
|
declare -r myname='paccache'
|
||||||
declare -r myver='@PACKAGE_VERSION@'
|
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 -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'
|
USE_COLOR='y'
|
||||||
|
|
||||||
@ -133,13 +133,13 @@ summarize() {
|
|||||||
[[ $pkg =~ $pkg_re ]] && name=${BASH_REMATCH[1]} arch=${BASH_REMATCH[2]}
|
[[ $pkg =~ $pkg_re ]] && name=${BASH_REMATCH[1]} arch=${BASH_REMATCH[2]}
|
||||||
if [[ -z $seen || $seenarch != "$arch" || $seen != "$name" ]]; then
|
if [[ -z $seen || $seenarch != "$arch" || $seen != "$name" ]]; then
|
||||||
seen=$name seenarch=$arch
|
seen=$name seenarch=$arch
|
||||||
printf '%s (%s):\n' "$name" "$arch"
|
printf '%s (%s):\n' "${name##*/}" "$arch"
|
||||||
fi
|
fi
|
||||||
printf ' %s\n' "$pkg"
|
printf ' %s\n' "${pkg##*/}"
|
||||||
elif (( verbose >= 2 )); then
|
elif (( verbose >= 2 )); then
|
||||||
printf "$PWD/%s$delim" "$pkg"
|
|
||||||
else
|
|
||||||
printf "%s$delim" "$pkg"
|
printf "%s$delim" "$pkg"
|
||||||
|
else
|
||||||
|
printf "%s$delim" "${pkg##*/}"
|
||||||
fi
|
fi
|
||||||
done < <(printf '%s\n' "$@" | pacsort --files)
|
done < <(printf '%s\n' "$@" | pacsort --files)
|
||||||
fi
|
fi
|
||||||
@ -165,7 +165,7 @@ Usage: ${myname} <operation> [options] [targets...]
|
|||||||
|
|
||||||
Options:
|
Options:
|
||||||
-a, --arch <arch> scan for "arch" (default: all architectures).
|
-a, --arch <arch> scan for "arch" (default: all architectures).
|
||||||
-c, --cachedir <dir> scan "dir" for packages.
|
-c, --cachedir <dir> scan "dir" for packages. can be used more than once.
|
||||||
(default: @localstatedir@/cache/pacman/pkg).
|
(default: @localstatedir@/cache/pacman/pkg).
|
||||||
-f, --force apply force to mv(1) and rm(1) operations.
|
-f, --force apply force to mv(1) and rm(1) operations.
|
||||||
-h, --help display this help message and exit.
|
-h, --help display this help message and exit.
|
||||||
@ -203,7 +203,7 @@ while :; do
|
|||||||
scanarch=$2
|
scanarch=$2
|
||||||
shift ;;
|
shift ;;
|
||||||
-c|--cachedir)
|
-c|--cachedir)
|
||||||
cachedir=$2
|
cachedirs+=("$2")
|
||||||
shift ;;
|
shift ;;
|
||||||
-d|--dryrun)
|
-d|--dryrun)
|
||||||
dryrun=1 ;;
|
dryrun=1 ;;
|
||||||
@ -256,6 +256,9 @@ done
|
|||||||
|
|
||||||
m4_include(../scripts/library/term_colors.sh)
|
m4_include(../scripts/library/term_colors.sh)
|
||||||
|
|
||||||
|
# setting default cachedir
|
||||||
|
cachedirs=("${cachedirs[@]:-@localstatedir@/cache/pacman/pkg}")
|
||||||
|
|
||||||
# remaining args are a whitelist
|
# remaining args are a whitelist
|
||||||
whitelist=("$@")
|
whitelist=("$@")
|
||||||
|
|
||||||
@ -265,29 +268,40 @@ case $(( dryrun+delete+move )) in
|
|||||||
[^1]) die "only one operation may be used at a time" ;;
|
[^1]) die "only one operation may be used at a time" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
[[ -d $cachedir ]] ||
|
|
||||||
die "cachedir '%s' does not exist or is not a directory" "$cachedir"
|
|
||||||
|
|
||||||
[[ $movedir && ! -d $movedir ]] &&
|
[[ $movedir && ! -d $movedir ]] &&
|
||||||
die "destination directory '%s' does not exist or is not a directory" "$movedir"
|
die "destination directory '%s' does not exist or is not a directory" "$movedir"
|
||||||
|
|
||||||
if (( move || delete )); then
|
if (( move || delete )); then
|
||||||
# make it an absolute path since we're about to chdir
|
# make it an absolute path since we're about to chdir
|
||||||
[[ ${movedir:0:1} != '/' ]] && movedir=$PWD/$movedir
|
[[ $movedir && ${movedir:0:1} != '/' ]] && movedir=$PWD/$movedir
|
||||||
[[ ! -w $cachedir || ( $movedir && ! -w $movedir ) ]] && needsroot=1
|
[[ $movedir && ! -w $movedir ]] && needsroot=1
|
||||||
|
fi
|
||||||
|
|
||||||
|
for cachedir in "${cachedirs[@]}"; do
|
||||||
|
[[ -d $cachedir ]] ||
|
||||||
|
die "cachedir '%s' does not exist or is not a directory" "$cachedir"
|
||||||
|
|
||||||
|
if (( move || delete )); then
|
||||||
|
[[ ! -w $cachedir ]] && needsroot=1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# unlikely that this will fail, but better make sure
|
# unlikely that this will fail, but better make sure
|
||||||
cd "$cachedir" >/dev/null || die "failed to chdir to '%s'" "$cachedir"
|
pushd "$cachedir" &>/dev/null || die "failed to chdir to '%s'" "$cachedir"
|
||||||
|
|
||||||
# note that these results are returned in an arbitrary order from awk, but
|
# 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.
|
# they'll be resorted (in summarize) iff we have a verbosity level set.
|
||||||
IFS=$'\n' read -r -d '' -a candidates < \
|
IFS=$'\n' read -r -d '' -a cand < \
|
||||||
<(printf '%s\n' *.pkg.tar?(.+([^.])) | pacsort --files |
|
<(printf '%s\n' "$PWD"/*.pkg.tar?(.+([^.])) | pacsort --files |
|
||||||
pkgfilter "$keep" "$scanarch" \
|
pkgfilter "$keep" "$scanarch" \
|
||||||
"${#whitelist[*]}" "${whitelist[@]}" \
|
"${#whitelist[*]}" "${whitelist[@]}" \
|
||||||
"${#blacklist[*]}" "${blacklist[@]}")
|
"${#blacklist[*]}" "${blacklist[@]}")
|
||||||
|
|
||||||
|
candidates+=("${cand[@]}")
|
||||||
|
unset cand
|
||||||
|
|
||||||
|
popd &>/dev/null
|
||||||
|
done
|
||||||
|
|
||||||
if (( ! ${#candidates[*]} )); then
|
if (( ! ${#candidates[*]} )); then
|
||||||
msg 'no candidate packages found for pruning'
|
msg 'no candidate packages found for pruning'
|
||||||
exit 1
|
exit 1
|
||||||
|
Loading…
Reference in New Issue
Block a user