问题描述
我正在尝试提取某个存储库中某些文件的提交并将它们合并到另一个存储库中。我的情况看起来有些特殊,因为我想从多个子目录(而不是整个子目录)中提取一些文件。
我尝试将git filter-branch
与--index-filter
和--filter-tree
结合使用,但看起来我仍然收到一些属于我不想要的其他文件的提交。
这是存储库的目录树:
/src
/inc
/test
/other_directory
我想提交属于所有存储库中的某些文件(但不是目录中的所有文件)的提交。例如,我要提交src/file1.c,src/file2.c,inc/file1.h,inc/file2.h,test/file1_test.c,test/file2_test.c
。
我使用filter-branch
使用了here中描述的一些步骤,
git filter-branch --force --index-filter ' bash script_to_delete_other_files.sh' --prune-empty --tag name-filter cat -- --all
注意:运行26小时后,我观察到结果非常好。我找到了我想要的文件的提交,但是还有一些其他提交属于某些已删除的文件(这些文件在过滤之前不处于存储库状态,因此git让它们进入历史记录,我不知道为什么)。
script_to_delete_other_files.sh
包含的内容
git rm -rf --cached --ignore-unmatch src/file3.c
git rm -rf --cached --ignore-unmatch inc/file3.h
git rm -rf --cached --ignore-unmatch test/file3_test.c
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)