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

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

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

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

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


当前回答

在搜索了很长时间之后,找到一种方法。在android studio项目中,在.gitconfig.like中别名一个git命令,在签出分支之前还原配置文件,然后跳过它,签出分支之后使用sed将配置文件更改为我的本地配置。签出和修改属性=!git update-index--no-skip-worktree local.properties&&git checkout local.pproperties&&git-checkout$1&&git update-index--skip-worktree本地.properties&&sed-i''s/.*sdk.dir.*/sdk.dir=\\/Users\\/run\\/Library\\/Android\\/sdk/g'local.properties&&:

其他回答

只需调用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更新索引--假设file.csproj不变,git不会自动检查file.cspro是否有更改:这将在您更改它们时阻止它们以git状态出现。因此,您可以这样标记所有.csproj文件,尽管您必须手动标记上游回购发送给您的任何新文件。(如果您的.gitignore或.git/info/exclude中有它们,那么您创建的将被忽略)

我不完全确定.csproj文件是什么。。。如果它们与IDE配置类似(类似于Eclipse的.Eclipse和.classpath文件),那么我建议它们根本不应该是源代码控制的。另一方面,如果它们是构建系统的一部分(如Makefile),那么它们显然应该——并且一种获取可选本地更改的方法(例如从local.csproj a la config.mk)会很有用:将构建划分为全局部分和本地覆盖。

在这个答案中给出了一个几乎无需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。

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

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

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

最好的

这是一个两步过程:

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