繁体   English   中英

如何在现有存储库上使用JGit从源中拉出

[英]How to pull from origin using JGit on existing repository

我需要一段可以从源中pull并与本地存储库merge的代码。 我尝试使用本地存储库,它可以获取最后的提交和修订。 但是无法将更改从源中pull

File gitWorkDir = new File(gitDir);
Git git = Git.open(gitWorkDir);
Repository repo = git.getRepository();
UsernamePasswordCredentialsProvider user = new 
UsernamePasswordCredentialsProvider("username", "password");
PullCommand pullCmd = git.pull();
pullCmd.setCredentialsProvider(user);
pullCmd.call();
ObjectId lastCommitId = repo.resolve(Constants.HEAD);
log.info(lastCommitId);

gitDir是我的本地存储库目录。

您需要提供远程存储库名称和远程分支名称。 例如originmaster

PullResult result = git.pull()
    .setCredentialsProvider(user)
    .setRemote("origin")
    .setRemoteBranchName("master")
    .call();

if (result.isSuccessful()) {
  ...
} else {
  ...
}

还请注意,pull命令返回的结果是PullRequest -其方法isSuccessful()指示是否成功完成了拉取。 您可能也想在代码中添加此逻辑。

参考文献:

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM