In a shell snippet meant to be sourced by other shell scripts, an
opening #! line does more harm than good.
The harm:
 - When the shell library is sourced, the interpreter and options from
   the #! line are not used.  Specifying a particular shell can
   confuse the reader into thinking it is safe for the shell library
   to rely on idiosyncrasies of that shell.
 - Using #! instead of a plain comment drops a helpful visual clue
   that this is a shell library and not a self-contained script.
 - Tools such as lintian can use a #! line to tell when an
   installation script has failed by forgetting to set a script
   executable.  This check does not work if shell libraries also start
   with a #! line.
The good:
 - Text editors notice the #! line and use it for syntax highlighting
   if you try to edit the installed scripts (without ".sh" suffix) in
   place.
The use of the #! for file type detection is not needed because Git's
shell libraries are meant to be edited in source form (with ".sh"
suffix).  Replace the opening #! lines with comments.
This involves tweaking the test harness's valgrind support to find
shell libraries by looking for "# " in the first line instead of "#!"
(see v1.7.6-rc3~7, 2011-06-17).
Suggested by Russ Allbery through lintian.  Thanks to Jeff King and
Clemens Buchacher for further analysis.
Tested by searching for non-executable scripts with #! line:
	find . -name .git -prune -o -type f -not -executable |
	while read file
	do
		read line <"$file"
		case $line in
		'#!'*)
			echo "$file"
			;;
		esac
	done
The only remaining scripts found are templates for shell scripts
(unimplemented.sh, wrap-for-bin.sh) and sample input used in tests
(t/t4034/perl/{pre,post}).
Signed-off-by: Jonathan Nieder <jrnieder@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
	
		
			
				
	
	
		
			90 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
# This is a shell library to calculate the remote repository and
 | 
						|
# upstream branch that should be pulled by "git pull" from the current
 | 
						|
# branch.
 | 
						|
 | 
						|
# git-ls-remote could be called from outside a git managed repository;
 | 
						|
# this would fail in that case and would issue an error message.
 | 
						|
GIT_DIR=$(git rev-parse -q --git-dir) || :;
 | 
						|
 | 
						|
get_default_remote () {
 | 
						|
	curr_branch=$(git symbolic-ref -q HEAD)
 | 
						|
	curr_branch="${curr_branch#refs/heads/}"
 | 
						|
	origin=$(git config --get "branch.$curr_branch.remote")
 | 
						|
	echo ${origin:-origin}
 | 
						|
}
 | 
						|
 | 
						|
get_remote_merge_branch () {
 | 
						|
	case "$#" in
 | 
						|
	0|1)
 | 
						|
	    origin="$1"
 | 
						|
	    default=$(get_default_remote)
 | 
						|
	    test -z "$origin" && origin=$default
 | 
						|
	    curr_branch=$(git symbolic-ref -q HEAD) &&
 | 
						|
	    [ "$origin" = "$default" ] &&
 | 
						|
	    echo $(git for-each-ref --format='%(upstream)' $curr_branch)
 | 
						|
	    ;;
 | 
						|
	*)
 | 
						|
	    repo=$1
 | 
						|
	    shift
 | 
						|
	    ref=$1
 | 
						|
	    # FIXME: It should return the tracking branch
 | 
						|
	    #        Currently only works with the default mapping
 | 
						|
	    case "$ref" in
 | 
						|
	    +*)
 | 
						|
		ref=$(expr "z$ref" : 'z+\(.*\)')
 | 
						|
		;;
 | 
						|
	    esac
 | 
						|
	    expr "z$ref" : 'z.*:' >/dev/null || ref="${ref}:"
 | 
						|
	    remote=$(expr "z$ref" : 'z\([^:]*\):')
 | 
						|
	    case "$remote" in
 | 
						|
	    '' | HEAD ) remote=HEAD ;;
 | 
						|
	    heads/*) remote=${remote#heads/} ;;
 | 
						|
	    refs/heads/*) remote=${remote#refs/heads/} ;;
 | 
						|
	    refs/* | tags/* | remotes/* ) remote=
 | 
						|
	    esac
 | 
						|
	    [ -n "$remote" ] && case "$repo" in
 | 
						|
		.)
 | 
						|
		    echo "refs/heads/$remote"
 | 
						|
		    ;;
 | 
						|
		*)
 | 
						|
		    echo "refs/remotes/$repo/$remote"
 | 
						|
		    ;;
 | 
						|
	    esac
 | 
						|
	esac
 | 
						|
}
 | 
						|
 | 
						|
error_on_missing_default_upstream () {
 | 
						|
	cmd="$1"
 | 
						|
	op_type="$2"
 | 
						|
	op_prep="$3"
 | 
						|
	example="$4"
 | 
						|
	branch_name=$(git symbolic-ref -q HEAD)
 | 
						|
	# If there's only one remote, use that in the suggestion
 | 
						|
	remote="<remote>"
 | 
						|
	if test $(git remote | wc -l) = 1
 | 
						|
	then
 | 
						|
		remote=$(git remote)
 | 
						|
	fi
 | 
						|
 | 
						|
	if test -z "$branch_name"
 | 
						|
	then
 | 
						|
		echo "You are not currently on a branch. Please specify which
 | 
						|
branch you want to $op_type $op_prep. See git-${cmd}(1) for details.
 | 
						|
 | 
						|
    $example
 | 
						|
"
 | 
						|
	else
 | 
						|
		echo "There is no tracking information for the current branch.
 | 
						|
Please specify which branch you want to $op_type $op_prep.
 | 
						|
See git-${cmd}(1) for details
 | 
						|
 | 
						|
    $example
 | 
						|
 | 
						|
If you wish to set tracking information for this branch you can do so with:
 | 
						|
 | 
						|
    git branch --set-upstream-to=$remote/<branch> ${branch_name#refs/heads/}
 | 
						|
"
 | 
						|
	fi
 | 
						|
	exit 1
 | 
						|
}
 |