我正在尝试在Java程序中克隆P4存储库,同时使用P4java。
如何一次克隆整个P4存储库?,而不是一次读取一个文件(如下所示)?
fileList = server.getDepotFiles(FileSpecBuilder.makeFileSpecList(new String[] {"//depot/dir/apps/..."}), false);
for (IFileSpec fileSpec : fileList){
if (fileSpec != null){
BufferedReader br = new BufferedReader(new InputStreamReader(fileSpec.getContents(true)));
// create new file locally and write content
}
}
感谢任何帮助。
答案 0 :(得分:1)
您的示例程序正在做什么(获取每个文件的头部转速并编写本地副本)正是sync
命令的作用。我建议您只使用sync
。
答案 1 :(得分:0)
我找到this解决方案,工作正常。 (感谢博客)。 基本上,它创建一个新的临时客户端,并使用filespec列表(depot文件名)和p4 sync命令克隆repo。 这里编辑的代码:
{
InputStream input = new FileInputStream(getPerforceDetails);
Properties prop = new Properties();
prop.load(input);
url = prop.getProperty("url"); //ex: perforce.xxx.xxxxxxx.com:port#
repo = prop.getProperty("repo"); //ex: //depot/xxx/xxxx/apps/...
username = prop.getProperty("username");
password = prop.getProperty("password"));
final String url = IServerAddress.Protocol.P4JAVA.toString() + "://" + serverUri;
server = ServerFactory.getServer(url, null);
server.connect();
server.setUserName(username);
server.login(password);
IServerInfo info = server.getServerInfo();
System.out.println( "Server Info \n" + info);
fileList = server.getDepotFiles(FileSpecBuilder.makeFileSpecList(new String[] {prop.getProperty("repo")}), false);
//comment above line if you have only few files to clones and refer blog mentioned.
// Creating new temporary client
IClient tempClient = new Client();
tempClient.setName("tempClient" + UUID.randomUUID().toString().replace("-", ""));
tempClient.setRoot("c:/tempP4");
tempClient.setServer(server);
// Setting the client as the current one for the server
server.setCurrentClient(tempClient);
// Creating Client View entry
ClientViewMapping tempMappingEntry = new ClientViewMapping();
// Setting up the mapping properties
tempMappingEntry.setLeft("//depot/gxxxx/hxxxxxx/ixxxx/...");
tempMappingEntry.setRight("//" + tempClient.getName() + "/...");
tempMappingEntry.setType(EntryType.INCLUDE);
// Creating Client view
ClientView tempClientView = new ClientView();
// Attaching client view entry to client view
tempClientView.addEntry(tempMappingEntry);
tempClient.setClientView(tempClientView);
// Registering the new client on the server
System.out.println(server.createClient(tempClient));
fileList = server.getDepotFiles(FileSpecBuilder.makeFileSpecList(new String[] {prop.getProperty("repo")}), false);
try{
// Forming the FileSpec collection to be synced-up
List<IFileSpec> fileSpecsSet = FileSpecBuilder.makeFileSpecList(pathsUnderDepot);
// Syncing up the client
//tempClient.sync(FileSpecBuilder.getValidFileSpecs(fileSpecsSet), true, false, false, false);
//uncomment above line, n comment below if you are cloning only few files
tempClient.sync(fileList, true, false, false, false);
}finally{
// Removing the temporary client from the server
System.out.println(server.deleteClient(tempClient.getName(), false));
}
}
感谢@Sam Stafford给我正确的方向。