From 8af697d69441500c42dfc5d8954d44314d65a00b Mon Sep 17 00:00:00 2001 From: Janos Gyerik Date: Wed, 22 Aug 2018 14:24:02 +0200 Subject: SONAR-11166 Fall back to default branch when target is not specified --- .../sonar/scanner/scan/branch/ProjectBranches.java | 23 +++++++++++++++++++--- 1 file changed, 20 insertions(+), 3 deletions(-) (limited to 'sonar-scanner-engine/src/main/java/org') 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 branches; + @Nullable + private final String defaultBranchName; + public ProjectBranches(List 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; + } } -- cgit v1.2.3