Git - 如何从单个分支中删除文件

标签 git version-control versioning

我有一个存储库,其中有一个主分支,最终将包含该应用程序的“核心”,以及包含核心的客户端分支,此外还有包含所有 Assets 、样式和前端的公共(public)分支-结束 View 。我知道这是可以完成的,因为我已经用本地存储库对其进行了测试。但问题是我从一个完全构建的客户端应用程序开始,我想从主分支中切出一些文件夹,当我向外 merge 到客户端分支时,不将这些删除传播到其他分支,更新为系统的核心。

那么,更简单地说,如何从一个分支中删除文件,而不在 merge 时将该删除传播到其他分支?

最佳答案

IMO 你应该使用 submodules分离客户细节( Assets 等)。手动处理这个问题会带来灾难

为每个客户端创建一个单独的存储库,并添加一个指向您的核心的子模块,以及它们之间共享的任何其他内容。不在客户端之间共享的代码不需要属于核心,也不需要属于其他共享子模块。这意味着与客户端对应的每个(当前)分支必须成为一个单独的存储库。毕竟,它们是相互独立的,这就是重点。

您最终将得到此存储库层次结构:

       core
        /\
       /  \
client1    client2

更新:

重要提示:备份所有内容,这样在出现问题时就不会遇到麻烦。

所有这些都高度依赖于您的场景。但以下是如何在非 Windows 系统中完成我所描述的内容的想法:

1) 将当前存储库拆分为不同的存储库(例如:core、client1、client2 等):

cp -R original_repo copy_repo
cd copy_repo
git checkout desired_branch
git filter-branch --prune-empty --subdirectory-filter desired_directory -- --all

对每个客户端目录也重复此操作。在此步骤结束时,您将为每个部分(核心、客户端 1、客户端 2 等)拥有一个单独的存储库。

2) 将新的拆分核心存储库作为子模块添加到每个 client1..clientN 存储库:

git submodule add <path_for_core_alone>
git submodule init # Add the submodule to .git/config
git submodule update # Clone the core repository

3)咖啡和利润。

关于Git - 如何从单个分支中删除文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4875429/

相关文章:

sql - 在 Oracle 中部署相同 View 的多个版本

Git从另一个分支复制文件而不暂存

来自远程的特定哈希的 git 存档

git - 我如何使用 Git 忽略 CVS 目录?

git - gitignore 全局配置到底有什么作用?

version-control - VCS 适合设计师使用吗?

Maven 版本控制最佳实践

git - 无法访问 'git/attributes'

svn - 在变更集 0(零)之前添加其他变更集?

maven - 版本插件不更新子模块,只更新父模块