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

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

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

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

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


当前回答

有3个选项;你可能想要#3

这将为您保留本地文件,但将在其他人拉动时删除该文件。git rm--缓存<文件名>或git rm-r--缓存<文件夹名>这是为了优化,就像一个包含大量文件的文件夹,例如可能永远不会更改的SDK。它告诉Git停止每次在本地检查巨大的文件夹是否有更改,因为它没有任何更改。如果文件/文件夹有上游更改(当您拉动时),则假设未更改的索引将被重置,文件将被覆盖。git更新索引——假设<路径名>不变这是为了告诉Git你想要自己的独立版本的文件或文件夹。例如,您不想覆盖(或删除)生产/登台配置文件。git更新索引--跳过工作树<路径名>重要的是要知道git更新索引不会随git传播,因此每个用户都必须独立运行它。

其他回答

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

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

or

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

电子交易中心。

防止git监视文件或路径

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

并将其恢复使用

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

参考类似用例的回购https://github.com/awslabs/git-secrets

要告诉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命令的方法:

要忽略每个本地存储库的某些文件,请执行以下操作:

创建文件~/.gitignore_global,例如在终端中使用touch~/.gotignore_gglobal。运行git-config--global-core.excludsfile~/.gitignore_global一次。将要忽略的文件/dir路径写入~/.gitignore_global.example-modules/*.H,该路径将被假定为在您的工作目录中,即$WORK_dir/modules/*.H。

要忽略单个本地存储库的某些文件,请执行以下操作:

对repo中的文件.git/info/exclude执行上述第三步,即将要忽略的文件/dir路径写入.git/info/dexclude中,例如modules/*.C,它将被假定在您的工作目录中,即$WORK_dir/modules/*.C。