From fd2257eb2e45d2f4e3845d05056f58c399a3a467 Mon Sep 17 00:00:00 2001 From: slakmagik Date: Sat, 17 Oct 2009 08:12:28 +0000 Subject: [PATCH] this is a band-aid which modifies get_source() to force links and explicitly fall through a case; more directly, it sets a NO_DL_LOOP flag if sbopkg has done a download so that it doesn't download in an infinite loop. It moves the download command into a conditional which can break the loop. It also modifies check_source() to unset the flag if sbopkg has done a successful download, so it can do the next one. Finally, it modifies get_source_names() to only go into the guessing code if we have done a download, don't have a source file, and only need to guess on one source name - thanks to godling for noticing a failure in downloading dictd and the infinite loop; thanks to Chess and Mauro for review and suggestions. --- src/usr/sbin/sbopkg | 43 ++++++++++++++++++++++++++++++++----------- 1 file changed, 32 insertions(+), 11 deletions(-) diff --git a/src/usr/sbin/sbopkg b/src/usr/sbin/sbopkg index 60fca28..137debc 100755 --- a/src/usr/sbin/sbopkg +++ b/src/usr/sbin/sbopkg @@ -2621,9 +2621,11 @@ get_source_names() { SRCNAME=$(printf ${SRCNAME//\%/\\x}) fi # The above doesn't work when the download link doesn't reference the - # file name explicitly. If this is the case, all we can do is - # guessing... - if [[ ! $SRCNAME ]]; then + # file name either explicitly or correctly. If this is the case, our + # SRCNAME doesn't correspond to a file, and all we can do is guess + # from the file that was downloaded and/or the name of the package. + if [[ -n $NO_DL_LOOP && ! -f $(readlink $SRCNAME) && + ${#DOWNLOAD[@]} == 1 ]]; then # If the source has a name resembling $PRGNAM-$VERSION.tar.gz, # catch it. CWD=$(pwd) @@ -2670,7 +2672,11 @@ check_source() { # If there's no known source name, or if it doesn't exist, it has to be # downloaded... - [[ -z $SRCNAME || ! -f $SRCDIR/$SRCNAME ]] && return 1 + if [[ -f $SRCDIR/$SRCNAME ]]; then + unset NO_DL_LOOP + else + return 1 + fi # Check MD5 echo "Checking MD5SUM:" @@ -2766,11 +2772,14 @@ get_source() { check_source $PKG ${MD5SUM[$i]} "${SRCNAME[$i]}" case $? in 0 ) # Source OK - rm -f "$REPO_DIR/$PKGPATH/${SRCNAME[$i]}" - ln -s "$SRCDIR/${SRCNAME[$i]}" \ + # FIXME: I think this one can be deleted - just continue 2 + # on 0 + ln -sf "$SRCDIR/${SRCNAME[$i]}" \ "$REPO_DIR/$PKGPATH/${SRCNAME[$i]}" continue 2 ;; + 1 ) # Fall through and (re)try below + ;; 2 ) # Abort FAILURE=download break 2 @@ -2779,16 +2788,26 @@ get_source() { mkdir -p $DLDIR cd $DLDIR - wget $WGETFLAGS ${DOWNLOAD[$i]} >> $SBOPKGOUTPUT & echo "$!" >> \ - $PIDLIST 2>> $SBOPKGOUTPUT - wait + if [[ -z $NO_DL_LOOP ]]; then + wget $WGETFLAGS ${DOWNLOAD[$i]} >> \ + $SBOPKGOUTPUT & echo "$!" >> $PIDLIST 2>> $SBOPKGOUTPUT + wait + else + FAILURE=loop + echo " Download failed. Please report this as a bug." >> \ + $TMPSUMMARYLOG + echo >> $TMPSUMMARYLOG + fi # Source filename corrections for Virtualbox, where '?e=foo' gets # appended to the filename and for calcurse, where a 'foo?' gets # prepended to the filename DL=$(ls -A . 2> /dev/null) DL_SRCNAME=$(sed 's/?e=.*$//;s/^.*?//' <<< "$DL") if [[ $DL_SRCNAME ]]; then - rm -f $REPO_DIR/$PKGPATH/"$DL_SRCNAME" + # if we have *anything* in here, then we did a download. We + # may not know what to do with it, but we don't need to get it + # again. We only need to succeed or fail once. + NO_DL_LOOP=1 mv "$DL" "$SRCDIR/$DL_SRCNAME" else FAILURE=download @@ -2798,7 +2817,9 @@ get_source() { cd $SRCDIR rm -rf $DLDIR [[ $FAILURE ]] && break 2 - ln -s "$SRCDIR/$DL_SRCNAME" "$REPO_DIR/$PKGPATH/$DL_SRCNAME" + # this is required so we make a link as soon as we have the source + # and don't enter the guessing code in get_source_names() + ln -sf "$SRCDIR/$DL_SRCNAME" "$REPO_DIR/$PKGPATH/$DL_SRCNAME" done done