diff options
author | Lin Jen-Shin <godfat@godfat.org> | 2017-08-24 17:26:18 +0800 |
---|---|---|
committer | Lin Jen-Shin <godfat@godfat.org> | 2017-08-24 17:27:47 +0800 |
commit | bea29327af6d14bea58f82304115735fd0b13d3f (patch) | |
tree | fa8905a397814372e0531403750ede5d4b91ecdf /app | |
parent | 140ac8d2ad81f03f67dddcb565458e9baee79755 (diff) | |
download | gitlab-ce-bea29327af6d14bea58f82304115735fd0b13d3f.tar.gz |
Just use methods over constants, so that we could
take the advantage that if they're not used, we
could garbage collect those data, reducing memory
footprint.
Diffstat (limited to 'app')
-rw-r--r-- | app/services/projects/import_export/cleanup_service.rb | 20 |
1 files changed, 14 insertions, 6 deletions
diff --git a/app/services/projects/import_export/cleanup_service.rb b/app/services/projects/import_export/cleanup_service.rb index 75eaee0cb7b..2e6bfb99189 100644 --- a/app/services/projects/import_export/cleanup_service.rb +++ b/app/services/projects/import_export/cleanup_service.rb @@ -1,11 +1,15 @@ module Projects module ImportExport class CleanupService - RESERVED_REFS_NAMES = + def self.reserved_refs_names %w[heads tags merge-requests keep-around environments] - RESERVED_REFS_REGEXP = - %r{\Arefs/(?:#{ - RESERVED_REFS_NAMES.map(&Regexp.method(:escape)).join('|')})/}x + end + + def self.reserved_refs_regexp + names = reserved_refs_names.map(&Regexp.method(:escape)).join('|') + + %r{\Arefs/(?:#{names})/} + end attr_reader :project @@ -23,8 +27,12 @@ module Projects private def garbage_refs - @garbage_refs ||= rugged.references.reject do |ref| - ref.name =~ RESERVED_REFS_REGEXP + @garbage_refs ||= begin + reserved_refs_regexp = self.class.reserved_refs_regexp + + rugged.references.reject do |ref| + ref.name =~ reserved_refs_regexp + end end end |