我对一个文件进行了更改,再加上一个新文件,我想在切换到另一个任务时使用git stash将它们保存起来。但是git stash本身只存储对现有文件的更改;新文件仍保留在我的工作树中,打乱了我未来的工作。我如何保存这个未跟踪的文件?


当前回答

在git版本2.8.1上:以下对我有用。

将已修改和未跟踪的文件保存在不带名称的存储中

git stash save -u

使用名称将已修改和未跟踪的文件保存在存储库中

git stash save -u <name_of_stash>

您可以稍后使用pop或apply,如下所示。

git stash pop

git stash apply stash@{0}

其他回答

你如何隐藏未追踪的文件?

git stash --include-untracked

在git版本2.8.1上:以下对我有用。

将已修改和未跟踪的文件保存在不带名称的存储中

git stash save -u

使用名称将已修改和未跟踪的文件保存在存储库中

git stash save -u <name_of_stash>

您可以稍后使用pop或apply,如下所示。

git stash pop

git stash apply stash@{0}

我可以通过以下方式来隐藏未跟踪的文件:

git stash save "tracked files I'm working on"
git stash save -u "untracked files I'm trying to stash"
git stash pop stash@{1}

最后一个弹出隐藏的跟踪文件,从而只留下未跟踪的文件。

假设新的未跟踪文件名为:“views.json”。如果您想通过隐藏应用程序的状态来更改分支,我通常会键入:

git add views.json

然后:

git stash

它会被藏起来。然后我就可以用

git checkout other-nice-branch

我认为这可以通过告诉git文件存在来解决,而不是将文件的所有内容提交到暂存区,然后调用git stash。Araqnid描述了如何实现前者。

git add --intent-to-add path/to/untracked-file

or

git update-index --add --cacheinfo 100644 e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 path/to/untracked-file

然而,后者不起作用:

$ git stash
b.rb: not added yet
fatal: git-write-tree: error building trees
Cannot save the current index state