summaryrefslogtreecommitdiff
path: root/app
diff options
context:
space:
mode:
authorLin Jen-Shin <godfat@godfat.org>2017-08-24 17:26:18 +0800
committerLin Jen-Shin <godfat@godfat.org>2017-08-24 17:27:47 +0800
commitbea29327af6d14bea58f82304115735fd0b13d3f (patch)
treefa8905a397814372e0531403750ede5d4b91ecdf /app
parent140ac8d2ad81f03f67dddcb565458e9baee79755 (diff)
downloadgitlab-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.rb20
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