使用 JGit 获取所有分支

2022-09-03 04:58:47

如何使用 JGit 获取存储库中的所有分支?让我们举一个示例存储库。正如我们所看到的,它有5个分支。
在这里,我发现了这个例子:

int c = 0;
List<Ref> call = new Git(repository).branchList().call();
for (Ref ref : call) {
    System.out.println("Branch: " + ref + " " + ref.getName() + " "
            + ref.getObjectId().getName());
    c++;
}
System.out.println("Number of branches: " + c);

但我得到的只是这个:

Branch: Ref[refs/heads/master=d766675da9e6bf72f09f320a92b48fa529ffefdc] refs/heads/master d766675da9e6bf72f09f320a92b48fa529ffefdc
Number of branches: 1
Branch: master

答案 1

如果缺少的是远程分支,则必须将 to 或 设置为 。默认情况下,该命令仅返回本地分支。ListModeListBranchCommandALLREMOTE

new Git(repository).branchList().setListMode(ListMode.ALL).call();

答案 2

我对git分支使用以下方法,而无需使用Jgit克隆存储库

这符合绒球.xml

    <dependency>
        <groupId>org.eclipse.jgit</groupId>
        <artifactId>org.eclipse.jgit</artifactId>
        <version>4.0.1.201506240215-r</version>
    </dependency>

方法

public static List<String> fetchGitBranches(String gitUrl)
            {
                Collection<Ref> refs;
                List<String> branches = new ArrayList<String>();
                try {
                    refs = Git.lsRemoteRepository()
                            .setHeads(true)
                            .setRemote(gitUrl)
                            .call();
                    for (Ref ref : refs) {
                        branches.add(ref.getName().substring(ref.getName().lastIndexOf("/")+1, ref.getName().length()));
                    }
                    Collections.sort(branches);
                } catch (InvalidRemoteException e) {
                    LOGGER.error(" InvalidRemoteException occured in fetchGitBranches",e);
                    e.printStackTrace();
                } catch (TransportException e) {
                    LOGGER.error(" TransportException occurred in fetchGitBranches",e);
                } catch (GitAPIException e) {
                    LOGGER.error(" GitAPIException occurred in fetchGitBranches",e);
                }
                return branches;
            }

推荐