Inter-revision diff: patch 2

Comparing v3 (message) to v5 (message)

--- v3
+++ v5
@@ -4,7 +4,11 @@
 
 By using a relative path instead of an absolute path, we can move the
 superproject directory around on the filesystem without breaking the
-submodule's cache.
+submodule's cache. And by using the path from gitdir to gitdir, we can
+move the submodule within the superproject's tree structure without
+breaking the submodule's cache, too. Finally, by pointing at
+"get_git_common_dir()" instead of "get_git_dir()", we ensure the link
+will refer to the parent repo, not to a specific worktree.
 
 Since this hint value is only introduced during new submodule creation
 via `git submodule add`, though, there is more work to do to allow the
@@ -19,81 +23,76 @@
 Signed-off-by: Emily Shaffer <emilyshaffer@google.com>
 Helped-by: Junio C Hamano <gitster@pobox.com>
 ---
- Documentation/config/submodule.txt | 15 +++++++++++
- builtin/submodule--helper.c        |  4 +++
- t/t7400-submodule-basic.sh         | 40 ++++++++++++++++--------------
- 3 files changed, 41 insertions(+), 18 deletions(-)
+ Documentation/config/submodule.txt | 12 +++++++++++
+ builtin/submodule--helper.c        |  4 ++++
+ t/t7400-submodule-basic.sh         | 32 ++++++++++++++++++++----------
+ 3 files changed, 38 insertions(+), 10 deletions(-)
 
 diff --git a/Documentation/config/submodule.txt b/Documentation/config/submodule.txt
-index d7a63c8c12..23e0a01d90 100644
+index ee454f8126..8cc57fe1c1 100644
 --- a/Documentation/config/submodule.txt
 +++ b/Documentation/config/submodule.txt
-@@ -90,3 +90,18 @@ submodule.alternateErrorStrategy::
+@@ -91,3 +91,15 @@ submodule.alternateErrorStrategy::
  	`ignore`, `info`, `die`. Default is `die`. Note that if set to `ignore`
  	or `info`, and if there is an error with the computed alternate, the
  	clone proceeds as if no alternate was specified.
 +
 +submodule.superprojectGitDir::
-+	The relative path from the submodule's worktree to its superproject's
-+	gitdir. When Git is run in a repository, it usually makes no difference
-+	whether this repository is standalone or a submodule, but if this
-+	configuration variable is present, additional behavior may be possible,
-+	such as "git status" printing additional information about this
-+	submodule's status with respect to its superproject. This config should
-+	only be present in projects which are submodules, but is not guaranteed
-+	to be present in every submodule, so only optional value-added behavior
-+	should be linked to it. It is set automatically during
-+	submodule creation.
-++
-+	Because of this configuration variable, it is forbidden to use the
-+	same submodule worktree shared by multiple superprojects.
++	The relative path from the submodule's gitdir to its superproject's
++	common dir. When Git is run in a repository, it usually makes no
++	difference whether this repository is standalone or a submodule, but if
++	this configuration variable is present, additional behavior may be
++	possible, such as "git status" printing additional information about
++	this submodule's status with respect to its superproject. This config
++	should only be present in projects which are submodules, but is not
++	guaranteed to be present in every submodule, so only optional
++	value-added behavior should be linked to it. It is set automatically
++	during submodule creation.
 diff --git a/builtin/submodule--helper.c b/builtin/submodule--helper.c
-index d55f6262e9..d60fcd2c7d 100644
+index 6298cbdd4e..f803812225 100644
 --- a/builtin/submodule--helper.c
 +++ b/builtin/submodule--helper.c
-@@ -1910,6 +1910,10 @@ static int module_clone(int argc, const char **argv, const char *prefix)
+@@ -1838,6 +1838,10 @@ static int clone_submodule(struct module_clone_data *clone_data)
  		git_config_set_in_file(p, "submodule.alternateErrorStrategy",
- 					   error_strategy);
+ 				       error_strategy);
  
 +	git_config_set_in_file(p, "submodule.superprojectGitdir",
-+			       relative_path(absolute_path(get_git_dir()),
-+					     path, &sb));
++			       relative_path(absolute_path(get_git_common_dir()),
++					     sm_gitdir, &sb));
 +
  	free(sm_alternate);
  	free(error_strategy);
  
 diff --git a/t/t7400-submodule-basic.sh b/t/t7400-submodule-basic.sh
-index 4bc6b6c886..e407329d81 100755
+index d69a5c0032..3c20d42fbe 100755
 --- a/t/t7400-submodule-basic.sh
 +++ b/t/t7400-submodule-basic.sh
-@@ -108,14 +108,18 @@ test_expect_success 'setup - repository to add submodules to' '
- submodurl=$(pwd -P)
+@@ -109,12 +109,24 @@ submodurl=$(pwd -P)
  
  inspect() {
--	dir=$1 &&
--
--	git -C "$dir" for-each-ref --format='%(refname)' 'refs/heads/*' >heads &&
--	{ git -C "$dir" symbolic-ref HEAD || :; } >head &&
--	git -C "$dir" rev-parse HEAD >head-sha1 &&
--	git -C "$dir" update-index --refresh &&
--	git -C "$dir" diff-files --exit-code &&
--	git -C "$dir" clean -n -d -x >untracked
-+	sub_dir=$1 &&
+ 	sub_dir=$1 &&
 +	super_dir=$2 &&
+ 
+ 	git -C "$sub_dir" for-each-ref --format='%(refname)' 'refs/heads/*' >heads &&
+ 	{ git -C "$sub_dir" symbolic-ref HEAD || :; } >head &&
+ 	git -C "$sub_dir" rev-parse HEAD >head-sha1 &&
+ 	git -C "$sub_dir" update-index --refresh &&
+ 	git -C "$sub_dir" diff-files --exit-code &&
 +
-+	git -C "$sub_dir" for-each-ref --format='%(refname)' 'refs/heads/*' >heads &&
-+	{ git -C "$sub_dir" symbolic-ref HEAD || :; } >head &&
-+	git -C "$sub_dir" rev-parse HEAD >head-sha1 &&
-+	git -C "$sub_dir" update-index --refresh &&
-+	git -C "$sub_dir" diff-files --exit-code &&
-+	cached_super_dir="$(git -C "$sub_dir" config --get submodule.superprojectGitDir)" &&
-+	[ "$(git -C "$super_dir" rev-parse --absolute-git-dir)" \
-+		-ef "$sub_dir/$cached_super_dir" ] &&
-+	git -C "$sub_dir" clean -n -d -x >untracked
++	# Ensure that submodule.superprojectGitDir contains the path from the
++	# submodule's gitdir to the superproject's gitdir.
++
++	super_abs_gitdir=$(git -C "$super_dir" rev-parse --path-format=absolute --git-common-dir) &&
++	sub_abs_gitdir=$(git -C "$sub_dir" rev-parse --path-format=absolute --git-common-dir) &&
++
++	[ "$(git -C "$sub_dir" config --get submodule.superprojectGitDir)" = \
++	  "$(test-tool path-utils relative_path "$super_abs_gitdir" \
++						"$sub_abs_gitdir")" ] &&
++
+ 	git -C "$sub_dir" clean -n -d -x >untracked
  }
  
- test_expect_success 'submodule add' '
-@@ -138,7 +142,7 @@ test_expect_success 'submodule add' '
+@@ -138,7 +150,7 @@ test_expect_success 'submodule add' '
  	) &&
  
  	rm -f heads head untracked &&
@@ -102,7 +101,7 @@
  	test_cmp expect heads &&
  	test_cmp expect head &&
  	test_must_be_empty untracked
-@@ -229,7 +233,7 @@ test_expect_success 'submodule add --branch' '
+@@ -240,7 +252,7 @@ test_expect_success 'submodule add --branch' '
  	) &&
  
  	rm -f heads head untracked &&
@@ -111,7 +110,7 @@
  	test_cmp expect-heads heads &&
  	test_cmp expect-head head &&
  	test_must_be_empty untracked
-@@ -245,7 +249,7 @@ test_expect_success 'submodule add with ./ in path' '
+@@ -256,7 +268,7 @@ test_expect_success 'submodule add with ./ in path' '
  	) &&
  
  	rm -f heads head untracked &&
@@ -120,7 +119,7 @@
  	test_cmp expect heads &&
  	test_cmp expect head &&
  	test_must_be_empty untracked
-@@ -261,7 +265,7 @@ test_expect_success 'submodule add with /././ in path' '
+@@ -272,7 +284,7 @@ test_expect_success 'submodule add with /././ in path' '
  	) &&
  
  	rm -f heads head untracked &&
@@ -129,7 +128,7 @@
  	test_cmp expect heads &&
  	test_cmp expect head &&
  	test_must_be_empty untracked
-@@ -277,7 +281,7 @@ test_expect_success 'submodule add with // in path' '
+@@ -288,7 +300,7 @@ test_expect_success 'submodule add with // in path' '
  	) &&
  
  	rm -f heads head untracked &&
@@ -138,7 +137,7 @@
  	test_cmp expect heads &&
  	test_cmp expect head &&
  	test_must_be_empty untracked
-@@ -293,7 +297,7 @@ test_expect_success 'submodule add with /.. in path' '
+@@ -304,7 +316,7 @@ test_expect_success 'submodule add with /.. in path' '
  	) &&
  
  	rm -f heads head untracked &&
@@ -147,7 +146,7 @@
  	test_cmp expect heads &&
  	test_cmp expect head &&
  	test_must_be_empty untracked
-@@ -309,7 +313,7 @@ test_expect_success 'submodule add with ./, /.. and // in path' '
+@@ -320,7 +332,7 @@ test_expect_success 'submodule add with ./, /.. and // in path' '
  	) &&
  
  	rm -f heads head untracked &&
@@ -156,7 +155,7 @@
  	test_cmp expect heads &&
  	test_cmp expect head &&
  	test_must_be_empty untracked
-@@ -340,7 +344,7 @@ test_expect_success 'submodule add in subdirectory' '
+@@ -351,7 +363,7 @@ test_expect_success 'submodule add in subdirectory' '
  	) &&
  
  	rm -f heads head untracked &&
@@ -165,7 +164,7 @@
  	test_cmp expect heads &&
  	test_cmp expect head &&
  	test_must_be_empty untracked
-@@ -481,7 +485,7 @@ test_expect_success 'update should work when path is an empty dir' '
+@@ -492,7 +504,7 @@ test_expect_success 'update should work when path is an empty dir' '
  	git submodule update -q >update.out &&
  	test_must_be_empty update.out &&
  
@@ -174,7 +173,7 @@
  	test_cmp expect head-sha1
  '
  
-@@ -540,7 +544,7 @@ test_expect_success 'update should checkout rev1' '
+@@ -551,7 +563,7 @@ test_expect_success 'update should checkout rev1' '
  	echo "$rev1" >expect &&
  
  	git submodule update init &&
@@ -184,5 +183,5 @@
  	test_cmp expect head-sha1
  '
 -- 
-2.33.0.rc2.250.ged5fa647cd-goog
+2.34.0.rc0.344.g81b53c2807-goog
 
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help