我克隆了一个包含一些.csproj文件的项目。我不需要/喜欢我的本地csproj文件被Git跟踪(或在创建补丁时被提起),但很明显,项目中需要这些文件。

我已经将*.csproj添加到我的LOCAL.gitignore中,但文件已经在repo中。

当我键入gitstatus时,它显示了我对csproj的更改,我对跟踪或提交补丁程序不感兴趣。

如何从我的个人存储库中删除这些文件的“跟踪”(但将它们保存在源中,以便我可以使用它们),以便我在执行状态(或创建补丁)时不会看到更改?

是否有正确/规范的方法来处理这种情况?


当前回答

忘了你的gitignore?

如果您在本地拥有整个项目,但忘记添加git-ignore,现在正在跟踪一些不必要的文件,请使用此命令删除所有内容

git rm --cached -r .

确保您处于项目的根位置。

然后你可以像往常一样

Add

git add .

犯罪

git commit -m 'removed all and added with git ignore'

Push

git push origin master

结论

希望这能帮助那些不得不对自己的.git进行更改的人。

它会删除整个缓存看看你的.gitignore添加要跟踪的文件推送至您的回购

其他回答

正如其他答案所指出的,所选答案是错误的。

另一个问题的答案表明,可能需要跳过工作树。

git update-index --skip-worktree <file>

这个答案链接到一篇文章(http://fallengamer.livejournal.com/93321.html)并引用了这篇文章,很好地概括了--假设不变和--跳过工作树之间的区别,如下所示:

--假设未更改假设开发人员不应该更改文件。此标志用于提高不更改文件夹的性能如SDK。

--当您指示git不要触摸特定文件,因为开发人员应该更改它时,skip-worktree非常有用。例如,如果上游的主存储库承载一些生产就绪配置文件,您不想意外提交更改对于这些文件,跳过工作树正是您想要的。

所有这些都归功于borealid的研究和回答。此处包含此信息纯粹是为了方便他人。

单线回答git更新索引--假定不变[路径]

每当您有一个位于中央存储库和本地存储库中的文件时,请使用此选项。您需要对该文件进行更改,但不能将其转移/提交到中央存储库。此文件不应添加到.gitignore中。因为如果系统管理员引入了文件中的新更改,高级开发人员需要在所有本地repo中分发。

最佳示例:DB连接的配置文件。在中央存储库中,您将拥有生产数据库服务器的所有用户名、密码、主机和端口值。但在本地开发中,您应该只使用本地或任何其他开发DB服务器(您的团队已设置)。在这种情况下,您希望在配置文件中进行更改,但不应提交到中央存储库。

最好的

只需调用git-rm-缓存在要从修订控制中删除的每个文件上就可以了。只要本地忽略模式正确,您就不会在git状态的输出中看到这些文件。

请注意,此解决方案从存储库中删除文件,因此所有开发人员都需要维护自己的本地(非版本控制)文件副本

要防止git检测到这些文件中的更改,还应使用以下命令:

git update-index --assume-unchanged [path]

你可能想做什么:(从下面@Ryan Taylor回答)

这是为了告诉git您想要自己的独立版本的文件或文件夹。例如,您不想覆盖(或删除)生产/登台配置文件。git更新索引--跳过工作树<路径名>

完整答案在以下URL中:http://source.kohlerville.com/2009/02/untrack-files-in-git/

git rm--文件名

gitls文件,以确保文件已删除或未跟踪

gitcommit-m“取消跟踪更改”

数字推送

问题可能是由操作顺序引起的。如果您首先修改了.gitignore,然后修改了git-rm-cached-xxx,那么您可能不得不继续遇到这个问题。

正确的解决方案:

git rm--缓存的xxx修改了.gitignore

顺序不变!

修改后的.gitignore重载!