aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-scanner-engine/src/main/java
diff options
context:
space:
mode:
Diffstat (limited to 'sonar-scanner-engine/src/main/java')
-rw-r--r--sonar-scanner-engine/src/main/java/org/sonar/scanner/scan/branch/ProjectBranches.java23
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;
+ }
}