我已经在我的机器上设置了一个本地git。初始化git时,我添加了预编译的库和二进制文件。然而,现在在我的开发过程中,我不想间歇性地签入这些文件。我不想从回购中删除这些文件。是否有任何方法不跟踪这些文件,直到我完成我的开发。(我想我不能使用.gitignore,因为它只适用于那些不在git中的文件。我想暂时禁用文件跟踪。)


当前回答

假设不变的替代方法是skip-worktree。后者有不同的含义,类似于“Git不应该跟踪这个文件。开发者可以(也被鼓励)在本地做出改变。”

在您不希望跟踪构建文件的更改(通常是较大的)的情况下,假设—unchanged是一个不错的选择。

在这种情况下,文件应该有默认内容,开发人员可以自由地在本地修改文件,但不应该检查他们的本地更改回到远程回购,跳过工作树是一个更好的选择。

另一个优雅的选择是在repo中有一个默认文件。假设文件名是BuildConfig.Default.cfg。开发人员需要在本地将其重命名为BuildConfig.cfg,并且他们可以进行所需的任何本地更改。现在将BuildConfig.cfg添加到.gitignore中,这样文件就不会被跟踪了。

看这个问题,在公认的答案中有一些很好的背景信息。

其他回答

Git update-index应该做你想做的事情

这将告诉git您想开始忽略对文件的更改 Git update-index——assume-unchanged path/to/file

当你想重新开始记录的时候 Git update-index——no-assume-unchanged path/to/file

Github文档:update-index

假设不变的替代方法是skip-worktree。后者有不同的含义,类似于“Git不应该跟踪这个文件。开发者可以(也被鼓励)在本地做出改变。”

在您不希望跟踪构建文件的更改(通常是较大的)的情况下,假设—unchanged是一个不错的选择。

在这种情况下,文件应该有默认内容,开发人员可以自由地在本地修改文件,但不应该检查他们的本地更改回到远程回购,跳过工作树是一个更好的选择。

另一个优雅的选择是在repo中有一个默认文件。假设文件名是BuildConfig.Default.cfg。开发人员需要在本地将其重命名为BuildConfig.cfg,并且他们可以进行所需的任何本地更改。现在将BuildConfig.cfg添加到.gitignore中,这样文件就不会被跟踪了。

看这个问题,在公认的答案中有一些很好的背景信息。

我假设您正在询问如何删除构建文件夹或bin文件夹中的所有文件,而不是分别选择每个文件。

您可以使用该命令: Git rm -r -f /build\* 确保您在构建目录的父目录中。 这个命令将递归地“删除”bin/或build/文件夹中的所有文件。我的意思是git会假装那些文件被“删除”了,并且这些文件不会被跟踪。git实际上将这些文件标记为删除模式。

请确保为即将提交的.gitignore准备好了。 文档:git rm

不是对最初问题的回答。但这可能会帮助到某些人。

要查看您所做的更改(知道哪些文件被标记为——assume-unchanged)

git ls-files -v

结果文件列表将有一个字符前缀(例如:H或H) 如果它是小写的(即h),那么文件被标记为——assume-unchanged

git rm --cached

但是,您不应该首先提交已编译的二进制文件和外部依赖项。使用像Bundler这样的工具来把它们拉进来。