diff options
author | Jacob Vosmaer (GitLab) <jacob@gitlab.com> | 2017-09-01 15:01:50 +0300 |
---|---|---|
committer | Douwe Maan <douwe@gitlab.com> | 2017-09-01 15:01:50 +0300 |
commit | 0187018e482f842704aa2cdc2f81375c859ec824 (patch) | |
tree | b91b3e0ce3fe763d09ea3ead63392b212936ef42 /lib/gitlab/git/repository.rb | |
parent | 7d3e888d069c3035b25f0dc8ff5efc8e52063db9 (diff) |
Simplify Git interactions in AfterImportService
Diffstat (limited to 'lib/gitlab/git/repository.rb')
-rw-r--r-- | lib/gitlab/git/repository.rb | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/lib/gitlab/git/repository.rb b/lib/gitlab/git/repository.rb index 554e40dc8a6..8709f82bcc4 100644 --- a/lib/gitlab/git/repository.rb +++ b/lib/gitlab/git/repository.rb @@ -250,11 +250,17 @@ module Gitlab branch_names + tag_names end + def delete_all_refs_except(prefixes) + delete_refs(*all_ref_names_except(prefixes)) + end + # Returns an Array of all ref names, except when it's matching pattern # # regexp - The pattern for ref names we don't want - def all_ref_names_except(regexp) - rugged.references.reject { |ref| ref.name =~ regexp }.map(&:name) + def all_ref_names_except(prefixes) + rugged.references.reject do |ref| + prefixes.any? { |p| ref.name.start_with?(p) } + end.map(&:name) end # Discovers the default branch based on the repository's available branches |