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

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

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

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

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


当前回答

git rm--文件名

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

gitcommit-m“取消跟踪更改”

数字推送

其他回答

很多人建议你使用git更新索引——假设不变。事实上,这可能是一个很好的解决方案,但只是在短期内。

您可能想做的是:git更新索引--跳过工作树。

(第三个选项可能是:git-rm-cached。它将保留本地文件,但将标记为从远程存储库中删除。)

前两个选项之间的区别?

假设未更改是为了临时允许您隐藏文件中的修改。如果您想隐藏对文件所做的修改,修改文件,然后签出另一个分支,则必须使用no假设未更改,然后可能隐藏已完成的修改。跳过工作树将跟踪您签出的任何分支,并进行修改!

假设不变的用例

它假设不应修改此文件,并在执行git状态时提供更清晰的输出。但是,当签出到另一个分支时,您需要重置标志,并在此之前提交或隐藏更改。如果您在激活此选项的情况下进行拉取,则需要解决冲突,并且git不会自动合并。它实际上只隐藏修改(gitstatus不会显示标记的文件)。

当我只想暂时停止跟踪更改+提交一堆与相同修改相关的文件(gitcommit-a)时,我喜欢使用它。

跳过工作树的用例

你有一个包含参数(例如,包括密码)的设置类,你的朋友必须根据他们的设置进行更改。

1:创建该类的第一个版本,填写您可以填写的字段,并将其他字段留空/空。2:提交并将其推送到远程服务器。3:git更新索引--跳过工作树MySetupClass.java4:使用自己的参数更新配置类。5:回去做另一个功能。

无论分支如何,您所做的修改都将跟随您。警告:如果你的朋友也想修改这个类,他们必须具有相同的设置,否则他们的修改将被推送到远程存储库。拉动时,文件的远程版本应覆盖您的文件。

PS:做一个或另一个,但不能同时做两个,因为你会有不良副作用。如果要尝试其他标志,应首先禁用后者。

要告诉Git不要跟踪对本地文件/文件夹的更改(这意味着Git状态不会检测到对它的更改),请执行以下操作:

git update-index --skip-worktree path/to/file

要让Git再次跟踪本地版本的更改(以便您提交更改),请执行以下操作:

git update-index --no-skip-worktree path/to/file

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

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

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

最好的

这是一个两步过程:

删除对文件/文件夹的跟踪-但将其保留在磁盘上-使用git rm—缓存现在,它们没有显示为“已更改”,但仍显示为git状态为-u的未跟踪文件将它们添加到.gitignore

为了节省一些时间,您添加到.gitignore中的规则可以用于删除多个文件/文件夹,即。

git rm--缓存的app/**/*.xml

or

git rm--缓存的-r app/widgets/yourfolder/

电子交易中心。