这个问题是在设计另一个 Git.dotfiles
管理系统时出现的。我想$HOME
用作我的工作树并将存储库存储在其他地方(而不是.git
因为这会混淆其他存储库)。
在具有先前复制和可能调整的点文件的旧机器上,我现在想克隆我的新点文件存储库并(挥手)进入一个状态,我可以看到我的点文件的(预先)存在状态$HOME/.*
作为对主文件的修改我新克隆的存储库。这主要是背景,在Git 中我只想小心地在脏目录中签出而不覆盖.
(在一般情况下,我可以从一个新目录开始,然后复制我的更改,但是当工作树是我的时,这似乎很难做到$HOME
。)
我发现一对命令似乎可以让我到达正确的位置,但我不确定这种方法是否存在缺陷或更简单的方法来做同样的事情:
git read-tree -v HEAD # load HEAD into the index
git checkout-index -a # cautiously check out all files without overwriting
这两个命令是否与复制我的家、进行普通结帐、然后复制我的文件的状态相同,这样git diff
只会有我在这台机器上所做的更改并且没有文件被删除?
还有其他应该应用的选项吗?
上下文是我的(alpha)引导脚本:
git clone --bare -n git://github.com/$(git config github.user)/.dotfiles.git ~/.dotfiles/repo.git
git config -f .dotfiles/repo.git/config core.bare false
git config -f .dotfiles/repo.git/config core.logallrefupdates true
git config -f .dotfiles/repo.git/config core.worktree $HOME
export GIT_DIR=~/.dotfiles/repo.git ; export GIT_WORK_TREE=~
git read-tree -v HEAD
git checkout-index -a # all files without overwriting
ln -sf $HOME/.dotfiles/gitignore-dots $HOME/.dotfiles/repo.git/info/exclude