diff options
Diffstat (limited to 'sonar-scanner-engine')
-rw-r--r-- | sonar-scanner-engine/src/main/java/org/sonar/scanner/scan/branch/ProjectBranches.java | 23 |
1 files changed, 20 insertions, 3 deletions
diff --git a/sonar-scanner-engine/src/main/java/org/sonar/scanner/scan/branch/ProjectBranches.java b/sonar-scanner-engine/src/main/java/org/sonar/scanner/scan/branch/ProjectBranches.java index ce5d73822e3..afc5182d1d6 100644 --- a/sonar-scanner-engine/src/main/java/org/sonar/scanner/scan/branch/ProjectBranches.java +++ b/sonar-scanner-engine/src/main/java/org/sonar/scanner/scan/branch/ProjectBranches.java @@ -19,11 +19,11 @@ */ package org.sonar.scanner.scan.branch; +import java.util.HashMap; import java.util.List; import java.util.Map; -import java.util.function.Function; -import java.util.stream.Collectors; import javax.annotation.CheckForNull; +import javax.annotation.Nullable; import javax.annotation.concurrent.Immutable; /** @@ -34,8 +34,20 @@ public class ProjectBranches { private final Map<String, BranchInfo> branches; + @Nullable + private final String defaultBranchName; + public ProjectBranches(List<BranchInfo> branchInfos) { - branches = branchInfos.stream().collect(Collectors.toMap(BranchInfo::name, Function.identity())); + this.branches = new HashMap<>(); + String mainBranchName = null; + for (BranchInfo branch : branchInfos) { + String branchName = branch.name(); + this.branches.put(branchName, branch); + if (branch.isMain()) { + mainBranchName = branchName; + } + } + this.defaultBranchName = mainBranchName; } @CheckForNull @@ -46,4 +58,9 @@ public class ProjectBranches { public boolean isEmpty() { return branches.isEmpty(); } + + @CheckForNull + public String defaultBranchName() { + return defaultBranchName; + } } |