选择性导入大型 Perforce 存储库的正确方法是什么?
git-p4 文档提到您可以-//depot/main/ignore
切换到过滤目录。这是否等同于git filter-branch
在克隆后运行 a 以删除相同的目录?
此外,Perforce 似乎提供了另一个称为“客户端”视图的功能。之前没用过Perforce,所以对使用模型有点陌生。我目前的理解是,人们会p4
在运行之前以某种方式设置正确的客户端视图git p4 clone
。有没有人有完整的细节?
Perforce 客户端规范确定 Perforce 存储库的哪些部分对 Perforce 客户端可见(并将同步)。clientspec 还提供了从 Perforce 存储库路径到本地路径的映射。
您可以通过选择性地包含部分 Perforce 存储库来修剪 Perforce 客户端。例如
//depot/main/path1/... //your-perforce-client/main/path1/...
//depot/main/path2/... //your-perforce-client/main/path2/...
将只包括//depot/main/path1/
and//depot/main/path2/
和 not //depot/main/path3/
。正如您所指出的,您还可以显式排除路径。例如
//depot/main/path1/... //your-perforce-client/main/path1/...
-//depot/main/path1/foo/... //your-perforce-client/main/path1/foo/...
将包括其子目录下//depot/main/path1/
除文件之外的所有内容。foo
根据您的 Perforce 存储库的结构以及您想要包含(或排除)的内容,您可能可以git-p4
直接告诉您要导入 Perforce 树的哪些部分:
git p4 clone --destination=/path/to/new/git/tree //depot/path1 //depot/path2
如果您想使用排除项,或者如果您想调整 Perforce 软件仓库路径映射到本地路径的方式,则需要添加该--use-client-spec
选项。.p4config
您可以通过在 Git 树的父目录中创建一个文件来配置应该使用哪个 Perforce 客户端,该文件包含:
P4CLIENT=YOUR_PERFORCE_CLIENT_NAME
然后设置环境变量:
P4CONFIG=.p4config
这样做将导致在当前目录p4
中查找.p4config
文件(然后逐步搜索父目录)以获取 Perforce 配置数据。
将被导入的文件将是Perforce 客户端规范包含的路径和命令行上明确提供的路径的交集。git p4 clone
(正如您所提到的,git-p4 clone
确实允许通过在路径前加上前缀来排除路径-
。但是,我不建议这样做,因为这意味着这些路径将仅在初始导入时被排除。如果将来在 Perforce 中触及该路径中的文件,执行git p4 rebase
/git p4 sync
将拾取那些更改的文件(除非您记得再次在命令行上明确排除它们)。--use-client-spec
但是,最初导入 using 将设置一个标志,允许在将来使用/.git/config
时自动兑现。)git p4 rebase
git p4 sync
一个警告是,如果有一天你想包含 Perforce 存储库的其他部分,执行选择性克隆会增加额外的复杂性。如果您需要这样做,请参阅我对“初始克隆后扩展客户端规范”的回答。git-p4