在一个新的git repo上,添加一个子模块并更改到子模块目录后,大多数git命令在子模块中运行时失败,并显示错误:
fatal: index file open failed: Not a directory
重现问题的完整命令集:
> git init .
Initialized empty Git repository in /Users/drh/code/personal/Experiments/git-test/.git/
> git status
On branch master
Initial commit
nothing to commit (create/copy files and use "git add" to track)
> git submodule add git@github.com:mitsuhiko/flask.git thirdparty/flask
Cloning into 'thirdparty/flask'...
remote: Reusing existing pack: 9959, done.
remote: Total 9959 (delta 0), reused 0 (delta 0)
Receiving objects: 100% (9959/9959), 5.17 MiB | 1.11 MiB/s, done.
Resolving deltas: 100% (5617/5617), done.
Checking connectivity... done.
> cd thirdparty/flask
> git status
fatal: index file open failed: Not a directory
> cat .git
gitdir: ../../.git/modules/thirdparty/flask
在小牛队上运行的git版本1.8.5.2
答案 0 :(得分:2)
我个人在一些子模块自动化的预提交钩子中看到了这个问题。环境变量GIT_DIR
,GIT_WORK_TREE
,GIT_INDEX_FILE
等导致了此问题。我可以使用env -i git <git-command>
来解决此问题,这是一种通过单个命令使用干净bash环境的简单方法。
答案 1 :(得分:0)
那是因为父回购中没有提交(意味着没有HEAD和no master
branch)。
正如您检测到的那样,父回购的GIT_DIR
可能设置得太迟,无法使用子模块。
如果good bug to report涵盖该情景,那将是none of the git submodule tests。
我认为其他一些应用程序(我怀疑
virtualenv
虽然无法重现)正在设置GIT_DIR
。