diff options
Diffstat (limited to 'dev-lang/perl')
-rw-r--r-- | dev-lang/perl/ChangeLog | 6 | ||||
-rwxr-xr-x | dev-lang/perl/files/perl-cleaner | 71 |
2 files changed, 43 insertions, 34 deletions
diff --git a/dev-lang/perl/ChangeLog b/dev-lang/perl/ChangeLog index 7a19efcceec4..c248cdc5622b 100644 --- a/dev-lang/perl/ChangeLog +++ b/dev-lang/perl/ChangeLog @@ -1,6 +1,10 @@ # ChangeLog for dev-lang/perl # Copyright 2002-2005 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/dev-lang/perl/ChangeLog,v 1.105 2005/01/27 13:01:22 mcummings Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-lang/perl/ChangeLog,v 1.106 2005/01/31 10:18:07 mcummings Exp $ + + 31 Jan 2005; Michael Cummings <mcummings@gentoo.org> files/perl-cleaner: + swtaylor came up with a quicker way to generate the module list, plus a more + secure call for making the tmp files 27 Jan 2005; Michael Cummings <mcummings@gentoo.org> files/perl-cleaner: Code cleanup thanks to Mr.B. *MAJOR* typo in the filename for the prelist of diff --git a/dev-lang/perl/files/perl-cleaner b/dev-lang/perl/files/perl-cleaner index 24053aa7c73c..a2a9becff7e9 100755 --- a/dev-lang/perl/files/perl-cleaner +++ b/dev-lang/perl/files/perl-cleaner @@ -1,5 +1,12 @@ #!/bin/bash + +# sort of a changelog if you want to call it that... + +# version 1.2 - swtaylor gave some good pointers on making the tmp files, as well as reminding me of grep's -f functionality :) +# version 1.1 - Mr. Bones gave a lot of good input on cleaning up the script +# Version 1 - stuff + # First and foremost - make sure we have a perl to work with... PERL=$(which perl) if [ "${PERL}x" == "x" ]; then @@ -13,38 +20,34 @@ TMPDIR=${TMPDIR:-/tmp} PKGDIR=$(/usr/bin/portageq vdb_path) DATESTAMP=$(date +"%Y%m%d%H%M%S") -LOG="${TMPDIR}/perl-cleaner.log.$DATESTAMP" - +LOG=$(mktemp ${TMPDIR}/perl-cleaner.log.$DATESTAMP.XXXXXXXXXX) PAGER=${PAGER:-more} + +# Set up our temporary files +MODULES_LIST=$(mktemp ${TMPDIR}/modules.list.XXXXXXXXXX) +EBUILDS_PREINSTALL=$(mktemp ${TMPDIR}/ebuilds.preinstall.XXXXXXXXXX) +EBUILDS_ORDERED=$(mktemp ${TMPDIR}/ebuilds.ordered.XXXXXXXXXX) +EBUILDS_REINSTALL=$(mktemp ${TMPDIR}/ebuilds.reinstall.XXXXXXXXXX) + ASK="" if [ ! -z $2 ]; then ASK="--ask" fi -# Set up our temporary files - -function cleanrun() { - for FILE in modules.list ebuilds.preinstall ebuilds.ordered ebuilds.reinstall ; do - - if [ -f ${TMPDIR}/$FILE ]; then - cp /dev/null ${TMPDIR}/$FILE - fi - done -} function postclean { - for FILE in modules.list ebuilds.preinstall ebuilds.ordered ebuilds.reinstall; do + for FILE in ${MODULES_LIST} ${EBUILDS_PREINSTALL} ${EBUILDS_ORDERED} ${EBUILDS_REINSTALL}; do - if [ -f ${TMPDIR}/$FILE ]; then - rm -f ${TMPDIR}/$FILE + if [ -f $FILE ]; then + rm -f $FILE fi done echo - echo "For a complete log, please read ${TMPDIR}/perl-cleaner.log.DATESTAMP" + echo "For a complete log, please read $LOG" echo } @@ -81,14 +84,17 @@ function module_list() { # no sense in revisiting that dir echo "$(date) : Building list of modules for reinstall" | tee -a $LOG INC=$(perl -e 'for $line (@INC) { next if $line eq "."; next if $line =~ m/'${PERL_VERSION}'/; print "$line\n" }') + MODFIND=$(mktemp ${TMPDIR}/modules.found.XXXXXXXXXX) echo "Locating modules for reinstall" for DIR in $INC; do if [ -d $DIR ]; then for file in $(find $DIR -iname "*.pm" -type f|grep -v "${PERL_VERSION}"); do - grep -l $file $PKGDIR/*/*/CONTENTS >>${TMPDIR}/modules.list + echo "$file" >>$MODFIND done fi done + grep -f $MODFIND -l $PKGDIR/*/*/CONTENTS >${MODULES_LIST} + rm $MODFIND } # The meat of it - rebuilding the ebuilds @@ -99,20 +105,20 @@ function module_list() { function ebuild_rebuild() { echo "$(date) : Rebuilding modules: Building list of ebuilds" | tee -a $LOG - if [ -s ${TMPDIR}/modules.list ]; then - for line in $(sort -u ${TMPDIR}/modules.list); do - echo "$line"|sed -e 's|.*pkg/||' -e 's|/CONTENTS||'|grep -v "dev-lang/perl" >>${TMPDIR}/ebuilds.preinstall + if [ -s ${MODULES_LIST} ]; then + for line in $(sort -u ${MODULES_LIST}); do + echo "$line"|sed -e 's|.*pkg/||' -e 's|/CONTENTS||'|grep -v "dev-lang/perl" >>${EBUILDS_PREINSTALL} done fi # If they asked for interactive, let them see what will be reinstalled - if [ -s ${TMPDIR}/ebuilds.preinstall ]; then + if [ -s ${EBUILDS_PREINSTALL} ]; then if [ ! -z $ASK ]; then echo "Press Enter to see the list of ebuilds we'll be avaluating" read key - $PAGER ${TMPDIR}/ebuilds.preinstall + $PAGER ${EBUILDS_PREINSTALL} printf "Continue? (Y/N) " read ANSWER if [ $(echo "${ANSWER}" | egrep -e "^n|N" ) ]; then @@ -121,7 +127,7 @@ function ebuild_rebuild() { fi fi - for EBUILD in $(cat ${TMPDIR}/ebuilds.preinstall); do + for EBUILD in $(cat ${EBUILDS_PREINSTALL} ); do if emerge --oneshot -p "=$EBUILD"|egrep -q ".*ebuilds.*satisfy"; then if emerge --oneshot -p ">=$EBUILD"|egrep -q ".*ebuilds.*satisfy"; then echo "$(date) : There are no unmasked ebuilds to satisfy $EBUILD. Skipping" | tee -a $LOG @@ -131,23 +137,23 @@ function ebuild_rebuild() { printf "${EBUILD} isn't available, but a new version is. Install? (Y/N) " read ANSWER if [ $(echo "${ANSWER}" | egrep -e "^y|Y" ) ]; then - echo ">=$EBUILD" >> ${TMPDIR}/ebuilds.ordered + echo ">=$EBUILD" >> ${EBUILDS_ORDERED} echo "$(date) : User chose to install >=${EBUILD}">>$LOG fi else - echo ">=$EBUILD" >>${TMPDIR}/ebuilds.ordered + echo ">=$EBUILD" >>${EBUILDS_ORDERED} fi fi else - echo "=$EBUILD">>${TMPDIR}/ebuilds.ordered + echo "=$EBUILD">>${EBUILDS_ORDERED} fi done - if [ -s ${TMPDIR}/ebuilds.ordered ]; then + if [ -s ${EBUILDS_ORDERED} ]; then if [ ! -z $ASK ]; then echo "Press Enter to see the final list of ebuilds to install" read key - $PAGER ${TMPDIR}/ebuilds.ordered + $PAGER ${EBUILDS_ORDERED} printf "Continue? (Y/N) " read ANSWER if [ $(echo "${ANSWER}" | egrep -e "^n|N" ) ]; then @@ -157,17 +163,17 @@ function ebuild_rebuild() { fi # Cut down to one line so portage can handle ordering these appropriately - emerge -p --oneshot $(cat ${TMPDIR}/ebuilds.ordered) | grep ebuild | sed -e 's:\([^ ]\+\):=\1:g' -e 's:.*\] \([^ ]*\) .*:\1:'>>${TMPDIR}/ebuilds.reinstall + emerge -p --oneshot $(cat ${EBUILDS_ORDERED} ) | grep ebuild | sed -e 's:\([^ ]\+\):=\1:g' -e 's:.*\] \([^ ]*\) .*:\1:'>>${EBUILDS_REINSTALL} echo "Reinstalling ebuilds" echo "$(date) : Ebuilds to reinstall: ">>$LOG - cat ${TMPDIR}/ebuilds.reinstall>>$LOG + cat ${EBUILDS_REINSTALL}>>$LOG echo >>$LOG # Now that we have them in the right order, emerge them one at a time # This is to avoid problems if one doesn't emerge correctly - for EBUILD in $(cat ${TMPDIR}/ebuilds.reinstall); do + for EBUILD in $(cat ${EBUILDS_REINSTALL}); do emerge --oneshot ${ASK} "$EBUILD" done else @@ -193,7 +199,7 @@ function libperl_list() { $(find $(echo $PATH | sed 's/:/ /g') -type f -perm +0111 ! -newer /usr/lib/libperl.so ) ; do if [ -f ${i} ]; then - ldd ${i} 2>&1 | grep "libperl" - >/dev/null && grep -l $i $PKGDIR/*/*/CONTENTS>>${TMPDIR}/modules.list; + ldd ${i} 2>&1 | grep "libperl" - >/dev/null && grep -l $i $PKGDIR/*/*/CONTENTS>>${MODULES_LIST}; fi done @@ -218,7 +224,6 @@ function leftovers() { done } -cleanrun case "$1" in leftovers) |