diff options
| author | Junio C Hamano <junkio@cox.net> | 2006-10-18 22:08:29 -0700 | 
|---|---|---|
| committer | Junio C Hamano <junkio@cox.net> | 2006-10-18 22:08:29 -0700 | 
| commit | a4c6ae5a76f6f18876be69e5c1684f425e04bfc1 (patch) | |
| tree | 8376d41bcb2b012159db6c4feecad08e082e667f /git-fetch.sh | |
| parent | 170487fbc3d7ec0f36208eed18d4ca0ea1e1acb7 (diff) | |
| parent | ba0ac36ec5708820e670731001f7ab35351c6c48 (diff) | |
| download | git-a4c6ae5a76f6f18876be69e5c1684f425e04bfc1.tar.gz | |
Merge branch 'sb/fetch'
* sb/fetch:
  merge and resolve: Output short hashes and .. in "Updating ..."
  fetch: Misc output cleanup
Diffstat (limited to 'git-fetch.sh')
| -rwxr-xr-x | git-fetch.sh | 41 | 
1 files changed, 25 insertions, 16 deletions
| diff --git a/git-fetch.sh b/git-fetch.sh index 79222fbb1a..b15fc2b389 100755 --- a/git-fetch.sh +++ b/git-fetch.sh @@ -129,22 +129,25 @@ append_fetch_head () {      then  	headc_=$(git-rev-parse --verify "$head_^0") || exit  	echo "$headc_	$not_for_merge_	$note_" >>"$GIT_DIR/FETCH_HEAD" -	[ "$verbose" ] && echo >&2 "* committish: $head_" -	[ "$verbose" ] && echo >&2 "  $note_"      else  	echo "$head_	not-for-merge	$note_" >>"$GIT_DIR/FETCH_HEAD" -	[ "$verbose" ] && echo >&2 "* non-commit: $head_" -	[ "$verbose" ] && echo >&2 "  $note_" -    fi -    if test "$local_name_" != "" -    then -	# We are storing the head locally.  Make sure that it is -	# a fast forward (aka "reverse push"). -	fast_forward_local "$local_name_" "$head_" "$note_"      fi + +    update_local_ref "$local_name_" "$head_" "$note_"  } -fast_forward_local () { +update_local_ref () { +    # If we are storing the head locally make sure that it is +    # a fast forward (aka "reverse push"). + +    label_=$(git-cat-file -t $2) +    newshort_=$(git-rev-parse --short $2) +    if test -z "$1" ; then +	[ "$verbose" ] && echo >&2 "* fetched $3" +	[ "$verbose" ] && echo >&2 "  $label_: $newshort_" +	return 0 +    fi +    oldshort_=$(git-rev-parse --short "$1" 2>/dev/null)      mkdir -p "$(dirname "$GIT_DIR/$1")"      case "$1" in      refs/tags/*) @@ -154,13 +157,16 @@ fast_forward_local () {  	then  		if now_=$(cat "$GIT_DIR/$1") && test "$now_" = "$2"  		then -			[ "$verbose" ] && echo >&2 "* $1: same as $3" ||: +			[ "$verbose" ] && echo >&2 "* $1: same as $3" +			[ "$verbose" ] && echo >&2 "  $label_: $newshort_" ||:  		else  			echo >&2 "* $1: updating with $3" +			echo >&2 "  $label_: $newshort_"  			git-update-ref -m "$rloga: updating tag" "$1" "$2"  		fi  	else  		echo >&2 "* $1: storing $3" +		echo >&2 "  $label_: $newshort_"  		git-update-ref -m "$rloga: storing tag" "$1" "$2"  	fi  	;; @@ -178,31 +184,34 @@ fast_forward_local () {  	        if test -n "$verbose"  		then  			echo >&2 "* $1: same as $3" +			echo >&2 "  $label_: $newshort_"  		fi  		;;  	    *,$local)  		echo >&2 "* $1: fast forward to $3" -		echo >&2 "  from $local to $2" +		echo >&2 "  old..new: $oldshort_..$newshort_"  		git-update-ref -m "$rloga: fast-forward" "$1" "$2" "$local"  		;;  	    *)  		false  		;;  	    esac || { -		echo >&2 "* $1: does not fast forward to $3;"  		case ",$force,$single_force," in  		*,t,*) -			echo >&2 "  forcing update." +			echo >&2 "* $1: forcing update to non-fast forward $3" +			echo >&2 "  old...new: $oldshort_...$newshort_"  			git-update-ref -m "$rloga: forced-update" "$1" "$2" "$local"  			;;  		*) -			echo >&2 "  not updating." +			echo >&2 "* $1: not updating to non-fast forward $3" +			echo >&2 "  old...new: $oldshort_...$newshort_"  			exit 1  			;;  		esac  	    }  	else  	    echo >&2 "* $1: storing $3" +	    echo >&2 "  $label_: $newshort_"  	    git-update-ref -m "$rloga: storing head" "$1" "$2"  	fi  	;; | 
