diff options
| author | Junio C Hamano <gitster@pobox.com> | 2008-08-27 16:39:19 -0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2008-08-27 16:39:19 -0700 | 
| commit | bb0d283989ec8853ffd72dfb26ff557ffa7781e4 (patch) | |
| tree | cd96334c7d83c9463e1f0a16c8c6da45d8776781 | |
| parent | bb34ca5c5f7df33ea84a5b71621dbdeac1da39c1 (diff) | |
| parent | 2327f61ecc4e9fbb6dd9fffdec0b043aeaca908f (diff) | |
| download | git-bb0d283989ec8853ffd72dfb26ff557ffa7781e4.tar.gz | |
Merge branch 'da/submodule-sync'
* da/submodule-sync:
  git-submodule: add "sync" command
| -rw-r--r-- | Documentation/git-submodule.txt | 9 | ||||
| -rwxr-xr-x | git-submodule.sh | 48 | 
2 files changed, 55 insertions, 2 deletions
| diff --git a/Documentation/git-submodule.txt b/Documentation/git-submodule.txt index abbd5b72de..babaa9bc46 100644 --- a/Documentation/git-submodule.txt +++ b/Documentation/git-submodule.txt @@ -15,6 +15,7 @@ SYNOPSIS  'git submodule' [--quiet] update [--init] [--] [<path>...]  'git submodule' [--quiet] summary [--summary-limit <n>] [commit] [--] [<path>...]  'git submodule' [--quiet] foreach <command> +'git submodule' [--quiet] sync [--] [<path>...]  DESCRIPTION @@ -139,6 +140,14 @@ foreach::  As an example, "git submodule foreach 'echo $path `git rev-parse HEAD`' will  show the path and currently checked out commit for each submodule. +sync:: +	Synchronizes submodules' remote URL configuration setting +	to the value specified in .gitmodules.  This is useful when +	submodule URLs change upstream and you need to update your local +	repositories accordingly. ++ +"git submodule sync" synchronizes all submodules while +"git submodule sync -- A" synchronizes submodule "A" only.  OPTIONS  ------- diff --git a/git-submodule.sh b/git-submodule.sh index 59fe7b335c..4a95035d85 100755 --- a/git-submodule.sh +++ b/git-submodule.sh @@ -6,7 +6,7 @@  USAGE="[--quiet] [--cached] \  [add <repo> [-b branch] <path>]|[status|init|update [-i|--init]|summary [-n|--summary-limit <n>] [<commit>]] \ -[--] [<path>...]|[foreach <command>]" +[--] [<path>...]|[foreach <command>]|[sync [--] [<path>...]]"  OPTIONS_SPEC=  . git-sh-setup  . git-parse-remote @@ -601,6 +601,50 @@ cmd_status()  		fi  	done  } +# +# Sync remote urls for submodules +# This makes the value for remote.$remote.url match the value +# specified in .gitmodules. +# +cmd_sync() +{ +	while test $# -ne 0 +	do +		case "$1" in +		-q|--quiet) +			quiet=1 +			shift +			;; +		--) +			shift +			break +			;; +		-*) +			usage +			;; +		*) +			break +			;; +		esac +	done +	cd_to_toplevel +	module_list "$@" | +	while read mode sha1 stage path +	do +		name=$(module_name "$path") +		url=$(git config -f .gitmodules --get submodule."$name".url) +		if test -e "$path"/.git +		then +		( +			unset GIT_DIR +			cd "$path" +			remote=$(get_default_remote) +			say "Synchronizing submodule url for '$name'" +			git config remote."$remote".url "$url" +		) +		fi +	done +}  # This loop parses the command line arguments to find the  # subcommand name to dispatch.  Parsing of the subcommand specific @@ -611,7 +655,7 @@ cmd_status()  while test $# != 0 && test -z "$command"  do  	case "$1" in -	add | foreach | init | update | status | summary) +	add | foreach | init | update | status | summary | sync)  		command=$1  		;;  	-q|--quiet) | 
