所以,我一直在学习更多关于 git 子模块的知识,而且我读到的所有地方都告诉我,在添加子模块后,我最终会得到一个分离的 HEAD。这是有道理的,因为我希望我的超级项目具体知道应该使用哪个提交。但是,这不是我在实践中看到的(在 Mac OS X 上)。
考虑以下命令序列,这些命令创建一个包含单个文件的快速存储库(称为 sub),然后将其作为子模块添加到另一个名为 blah 的存储库中。
/tmp> git version
git version 1.7.12.4 (Apple Git-37)
/tmp> git init sub
Initialized empty Git repository in /private/tmp/sub/.git/
/tmp> cd sub
/tmp/sub> touch a.txt
/tmp/sub> git add a.txt
/tmp/sub> git commit -m "add a file"
[master (root-commit) c527790] .
0 files changed
create mode 100644 a.txt
/tmp/sub> cd ..
/tmp> git init blah
Initialized empty Git repository in /private/tmp/blah/.git/
/tmp> cd blah
/tmp/blah> git submodule add /tmp/sub sub
Cloning into 'sub'...
done.
/tmp/blah> cd sub
/tmp/blah/sub> git status
# On branch master
nothing to commit (working directory clean)
为什么子模块在主分支上?我原以为它会说它不在分支上。更多挖掘表明 git 引用了正确的提交哈希,但不知何故位于主分支上,而不是分离的 HEAD。
/tmp/blah/sub> cd ../../sub
/tmp/sub> git reflog
97b97b3 HEAD@{0}: commit (initial): add a file
/tmp/sub> cd ../blah
/tmp/blah> git submodule status
97b97b349cfae8da490c2cad3b3f4fc3af6a53c7 sub (heads/master)
我错过了什么?非常感谢。