我有monorepo
很多不同packages
的地方。我想拿一个包并为它创建一个新的仓库。我想保留与项目文件夹中的文件有关的提交。
我尝试使用git filter-branch
with--subdirectory-filter
可以使用指定文件夹中的文件创建一个分支。
git filter-branch --subdirectory-filter ./src/project
git log --pretty=oneline
dc1fd15e212c2e916591d931f81d0f94b0312067 (HEAD -> master) j
a68625cffd59e0bc6efda226042b81979985f77c a1
612e28ee9a2a7e59e8da0dff2c0109f0c03fa216 a2
04335730f1e4ecfbd7882fcdc16d5f2402261b3f a3
3e76c4deecd9b019302bcdf667523dbc866479bd a4
01ca27e1801b1f80d7480110c2861d798b0e6893 a5
但是,通过log
命令和--all
标志,您可以看到比在主分支中看到的更多提交。
git log --pretty=oneline --all
f96e38e502b6bcab013f4505f40b0060fcafc461 a
06d7edc961690a9e2ec406d64dcee57443441926 b
06723ca315e8f2aad83d4d7e3bfcb095456329c6 c
f7f3ff04c873ba573602e8ed24b88394284d1e7a d
9d355e1802fdb6a44199d7f798d4dfc59ab73244 e
00d3e0d524d7f44bd41ea0e12583e234b7db941c f
97a245266a28d75baffa43cc8fc19a8adcf89fe3 g
faa1c96d7789db06b216be5d989f8d809d626a32 h
a5e892fcb2eb4f05c5cb4f7f0adbf3dfe5bd29b5 i
dc1fd15e212c2e916591d931f81d0f94b0312067 (HEAD -> master) j
68583660582d9184f2ea29e9c74da00793775245 k
a68625cffd59e0bc6efda226042b81979985f77c l
8a224dcebdfc18b13001c600113104f20ea0334e m
4c1606853902e1e3711892e5515e51fee45dcfa2 n
4ecd26965d13266a51f807af3ea88382d5cf8ba8 o
612e28ee9a2a7e59e8da0dff2c0109f0c03fa216 p
31cf0b36a977fa7d2d16fb66465fd59f8a9e274a q
dcc685af381a520795bfafe8df667aeb2cf087e6 r
a2d39ff1e21541e0a638b39877ab19fee2c162d0 s
9a5775e3bc3194bb021a0687140f976f6751cee1 t
2b9535729525537811745456f8917e200effb44f u
f4813470ee84b740e398ed09a68121982f6d171e v
4d46ecbe227d191fc7be0260ff6ddb7c2bd6d759 w
aeb866d98e78fed9aef3e9cc721b21b9d051438c x
e1ac5f9505f75290833a28c6b27cff659f734b24 y
9b3db9df98df1a20da1b8dda1200c2d09603ee2d z
def782319c775c68698666eb5f3fe828a70bf7a6 h
006d44e9f1abb7bba7cb9bdc1dcba09b41a3297d i
1e7eb9b30a6402914344c5ef038076a26bdd4a65 j
2e55da67d626db00043eeddbe1204afd3e7e5790 k
65e868a89ff22412f939ffc71fea8c6cef016683 l
aadc31aa541da8fe0f25af5aec9a967f6c5172f1 m
ed865f5499640eac12cd0b0048a54224898cf998 n
7c51acdc3e57f3c28fdcc9ea5c3c368b29991d9b o
06770a789e66dddc1e87257a4f64ca42e9fed6cf p
8148c5cdaa920900eac1750c2453ead6446b2d08 q
这些提交中的每一个都有不属于所需的文件和数据subdirectory
。
如何删除这些文件?这是bfg
进来的地方。
使用-p
( --protect-blobs-from
) 标志我可以传入master
.
bfg -D '*' -p "`git rev-list master | tr '\n' ','`"
这将从整个存储库历史记录中删除不在分支中的所有文件。master
然而!如果您git log --all
仍然看到所有额外的提交,提交中没有文件。
我正在寻找一种方法来为命令(例如./src/project
)提供目录并拥有一个仅包含与该目录中的文件有关的文件和提交的存储库。
如何在不更改文件的情况下删除这些提交?
有一个bfg
用于--prune-empty
命令的 PR。这可能会有所帮助,但在合并之前不是一个可行的解决方案,而且我似乎仍然需要同时使用filter-branch
和bfg
.
我也试过clone
这个分支。理想情况下,有一种方法可以获取 master 并从中创建一个全新的存储库,其中只有那些refs
.
更新:
我已经扩展了@BlythMeister 的帖子,文章中的filter-branch
命令存在一个问题,它将把内容移到头部。所以我必须在之后运行它。subdirectory-filter
subdirectory
DIR=./src/project
git filter-branch --index-filter 'git rm --cached -qr --ignore-unmatch -- . && git reset -q $GIT_COMMIT -- $DIR' --prune-empty -- --all
git filter-branch --subdirectory-filter $DIR