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/ 和 //depot/main/path2/ 而不包括 //depot/main/path3/。正如您所指出的,您还可以显式排除路径。例如
//depot/main/path1/... //your-perforce-client/main/path1/...
-//depot/main/path1/foo/... //your-perforce-client/main/path1/foo/...
将包含//depot/main/path1/ 中的所有内容except 文件在其foo 子目录下。
根据您的 Perforce 存储库的结构以及您想要包含(或排除)的内容,您可能可以直接告诉 git-p4 您要导入 Perforce 树的哪些部分:
git p4 clone --destination=/path/to/new/git/tree //depot/path1 //depot/path2
如果您想使用排除或调整 Perforce 库路径映射到本地路径的方式,则需要添加 --use-client-spec 选项。您可以通过在 Git 树的父目录中创建一个 .p4config 文件来配置应该使用哪个 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 导入将设置.git/config 中的一个标志,允许在将来使用 git p4 rebase/git p4 sync 时自动兑现。)
需要注意的是,如果有一天您想要包含 Perforce 存储库的其他部分,执行选择性克隆会增加额外的复杂性。如果需要,请参阅 my answer to "Extending git-p4 clientspec after initial clone"。