如何使用p4java克隆p4 repo?

时间:2017-07-31 08:23:39

标签: java perforce p4java

我正在尝试在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
    }
}

感谢任何帮助。

2 个答案:

答案 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给我正确的方向。