summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorZac Medico <zmedico@gentoo.org>2007-01-29 00:48:48 +0000
committerZac Medico <zmedico@gentoo.org>2007-01-29 00:48:48 +0000
commite30e81f929d8858fd4724fd9872def91f9c4a36a (patch)
tree11d3c7b4c4e821de90e83d3440ec06e2fd3b7013
parentRemove a stray print statement. Thanks to Rick Warner in bug #125261. (trunk... (diff)
downloadportage-e30e81f929d8858fd4724fd9872def91f9c4a36a.tar.gz
portage-e30e81f929d8858fd4724fd9872def91f9c4a36a.tar.bz2
portage-e30e81f929d8858fd4724fd9872def91f9c4a36a.zip
add support for transparently decompressing gz/Z/bz2 files since some upstream packages will compress for us (trunk r5824:5825)
svn path=/main/branches/2.1.2/; revision=5826
-rwxr-xr-xbin/ecompressdir46
1 files changed, 36 insertions, 10 deletions
diff --git a/bin/ecompressdir b/bin/ecompressdir
index 47ea5db41..a95e1a205 100755
--- a/bin/ecompressdir
+++ b/bin/ecompressdir
@@ -17,6 +17,35 @@ fi
source "${PORTAGE_BIN_PATH:-/usr/lib/portage/bin}"/isolated-functions.sh
+# funk_up_dir(action, suffix, binary)
+# - action: compress or decompress
+# - suffix: the compression suffix to work with
+# - binary: the program to execute that'll compress/decompress
+# The directory we act on is implied in the ${dir} variable
+funk_up_dir() {
+ local act=$1 suffix=$2 binary=$3
+
+ local negate=""
+ [[ ${act} == "compress" ]] && negate="!"
+
+ # first we act on all the files
+ find "${dir}" -type f ${negate} -iname '*.'${suffix} -print0 | ${XARGS} -0 ${binary}
+ ((ret+=$?))
+
+ find -L "${dir}" -type l | \
+ while read brokenlink ; do
+ olddest=$(readlink "${brokenlink}")
+ [[ ${act} == "compress" ]] \
+ && newdest="${olddest}${suffix}" \
+ || newdest="${olddest%.${suffix}}"
+ rm -f "${brokenlink}"
+ [[ ${act} == "compress" ]] \
+ && ln -snf "${newdest}" "${brokenlink}${suffix}" \
+ || ln -snf "${newdest}" "${brokenlink%.${suffix}}"
+ ((ret+=$?))
+ done
+}
+
ret=0
for dir in "$@" ; do
@@ -28,16 +57,13 @@ for dir in "$@" ; do
vecho "${0##*/}: $(ecompress --bin) ${dir#${D}}"
fi
- find "${dir}" -type f '!' -name '*'${suffix} -print0 | ${XARGS} -0 ecompress
- ((ret+=$?))
- find -L "${dir}" -type l | \
- while read brokenlink ; do
- olddest=$(readlink "${brokenlink}")
- newdest="${olddest}${suffix}"
- rm -f "${brokenlink}"
- ln -snf "${newdest}" "${brokenlink}${suffix}"
- ((ret+=$?))
- done
+ # not uncommon for packages to compress doc files themselves
+ funk_up_dir "decompress" "Z" "gunzip"
+ funk_up_dir "decompress" "gz" "gunzip"
+ funk_up_dir "decompress" "bz2" "bunzip2"
+
+ # now lets do our work
+ funk_up_dir "compress" "${suffix}" "ecompress"
done
exit ${ret}