我正在尝试将一个大型仓库划分为多个较小的仓库。目标是拆分文件夹并在此过程中保留标签。
我尝试过:
git filter-branch --prune-empty --subdirectory-filter my-folder develop
此正确将my-folder
放置在新项目的根目录中,并保留了标签。但是,签出标签会导致在新仓库中看到整个旧目录结构。
所以我尝试了:
git filter-branch --tag-name-filter cat --prune-empty --subdirectory-filter my-folder -- --branches=develop --tags
这会导致开发分支带有旧的目录结构,BUT,当我签出标签时,我看到子目录已正确过滤到根目录!所以标签是正确的,但不是develop分支。基本上,它与第一种方法有相反的问题。
我对为什么第二种方法不起作用感到困惑。我真的很感谢任何指点!
编辑:
立即尝试:
git filter-branch --tag-name-filter cat --prune-empty --subdirectory-filter my-folder -- --all
我很犹豫,这将花费更长的时间。这确实花费了更长的时间,但大多数情况下都起作用。什么没有奏效?好了,尚未创建文件夹的较旧标签保留在存储库中,并且在签出时包含完整的(非常)旧目录结构。我不得不grep并删除所有这些标签。仓库仍然不像我预期的那么小...
正如我在“ Git commands that could break/rewrite the history”中提到的那样,旧的git filter-branch命令正在逐渐被弃用。
使用新的git filter-repo
,应该是:
git filter-repo
然后将那个分支推送到新的空Git存储库。
应该正确移动相关标签。