diff options
author | Zac Medico <zmedico@gentoo.org> | 2007-01-29 00:48:48 +0000 |
---|---|---|
committer | Zac Medico <zmedico@gentoo.org> | 2007-01-29 00:48:48 +0000 |
commit | e30e81f929d8858fd4724fd9872def91f9c4a36a (patch) | |
tree | 11d3c7b4c4e821de90e83d3440ec06e2fd3b7013 | |
parent | 5286903f43654f10b21d1b01e6505e8539c68705 (diff) | |
download | portage-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-x | bin/ecompressdir | 46 |
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} |