summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2012-02-10 13:59:01 -0800
committerJunio C Hamano <gitster@pobox.com>2012-02-10 13:59:01 -0800
commit5febbda4e7afb4f26bed9d2dc5f9c4ceca86d2b8 (patch)
treea98a9004d033ea6bf882bf0d131138f8a38d8c91
parent38ca63f3c0ef70ba4e41d3b5e347e2c7e7d67fe5 (diff)
parent1017c1abcb6d733e1de83eb5a1cf7e1bf4ad6aca (diff)
downloadgit-5febbda4e7afb4f26bed9d2dc5f9c4ceca86d2b8.tar.gz
Merge branch 'jl/submodule-re-add' into maint
* jl/submodule-re-add: submodule add: fix breakage when re-adding a deep submodule
-rwxr-xr-xgit-submodule.sh1
-rwxr-xr-xt/t7406-submodule-update.sh8
2 files changed, 9 insertions, 0 deletions
diff --git a/git-submodule.sh b/git-submodule.sh
index 3adab93635..9bb2e13e92 100755
--- a/git-submodule.sh
+++ b/git-submodule.sh
@@ -131,6 +131,7 @@ module_clone()
gitdir=
gitdir_base=
name=$(module_name "$path" 2>/dev/null)
+ test -n "$name" || name="$path"
base_path=$(dirname "$path")
gitdir=$(git rev-parse --git-dir)
diff --git a/t/t7406-submodule-update.sh b/t/t7406-submodule-update.sh
index 33b292b8a8..5b97222c48 100755
--- a/t/t7406-submodule-update.sh
+++ b/t/t7406-submodule-update.sh
@@ -611,4 +611,12 @@ test_expect_success 'submodule update places git-dir in superprojects git-dir re
)
'
+test_expect_success 'submodule add properly re-creates deeper level submodules' '
+ (cd super &&
+ git reset --hard master &&
+ rm -rf deeper/ &&
+ git submodule add ../submodule deeper/submodule
+ )
+'
+
test_done