summaryrefslogtreecommitdiffstats
path: root/lib/redmine
diff options
context:
space:
mode:
authorGo MAEDA <maeda@farend.jp>2021-03-26 03:48:32 +0000
committerGo MAEDA <maeda@farend.jp>2021-03-26 03:48:32 +0000
commit919c9cfdd0a58491b248e28ff521911a1b383089 (patch)
tree413ccc3db7236d08cce8e49e28bfb25838898e56 /lib/redmine
parent9c56418f4e72a278efba6c5a4403ae4157d02421 (diff)
downloadredmine-919c9cfdd0a58491b248e28ff521911a1b383089.tar.gz
redmine-919c9cfdd0a58491b248e28ff521911a1b383089.zip
Support for Git repositories with default branch "main" (#34942).
Patch by Go MAEDA. git-svn-id: http://svn.redmine.org/redmine/trunk@20851 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'lib/redmine')
-rw-r--r--lib/redmine/scm/adapters/git_adapter.rb16
1 files changed, 9 insertions, 7 deletions
diff --git a/lib/redmine/scm/adapters/git_adapter.rb b/lib/redmine/scm/adapters/git_adapter.rb
index d3c9449e5..b85bd0296 100644
--- a/lib/redmine/scm/adapters/git_adapter.rb
+++ b/lib/redmine/scm/adapters/git_adapter.rb
@@ -25,6 +25,9 @@ module Redmine
class GitAdapter < AbstractAdapter
# Git executable name
GIT_BIN = Redmine::Configuration['scm_git_command'] || "git"
+ # Repositories created after 2020 may have a default branch of
+ # "main" instead of "master"
+ GIT_DEFAULT_BRANCH_NAMES = %w[main master].freeze
class GitBranch < Branch
attr_accessor :is_default
@@ -110,14 +113,13 @@ module Redmine
end
def default_branch
- bras = self.branches
- return unless bras
+ return if branches.blank?
- default_bras = bras.detect{|x| x.is_default == true}
- return default_bras.to_s if default_bras
-
- master_bras = bras.detect{|x| x.to_s == 'master'}
- master_bras ? 'master' : bras.first.to_s
+ (
+ branches.detect(&:is_default) ||
+ branches.detect {|b| GIT_DEFAULT_BRANCH_NAMES.include?(b.to_s)} ||
+ branches.first
+ ).to_s
end
def entry(path=nil, identifier=nil)