From c6273ec50c019a115b11a8ef1032a64710f0a46a Mon Sep 17 00:00:00 2001 From: Oswaldo Ferreira Date: Wed, 7 Mar 2018 22:29:12 -0300 Subject: Avoid re-fetching merge-base SHA from Gitaly unnecessarily --- app/models/compare.rb | 36 ++++++++++++++++++++---------------- 1 file changed, 20 insertions(+), 16 deletions(-) (limited to 'app/models/compare.rb') diff --git a/app/models/compare.rb b/app/models/compare.rb index 3a8bbcb1acd..19ea2bc3065 100644 --- a/app/models/compare.rb +++ b/app/models/compare.rb @@ -1,4 +1,6 @@ class Compare + include Gitlab::Utils::StrongMemoize + delegate :same, :head, :base, to: :@compare attr_reader :project @@ -11,9 +13,10 @@ class Compare end end - def initialize(compare, project, straight: false) + def initialize(compare, project, base_sha: nil, straight: false) @compare = compare @project = project + @base_sha = base_sha @straight = straight end @@ -22,40 +25,41 @@ class Compare end def start_commit - return @start_commit if defined?(@start_commit) + strong_memoize(:start_commit) do + commit = @compare.base - commit = @compare.base - @start_commit = commit ? ::Commit.new(commit, project) : nil + ::Commit.new(commit, project) if commit + end end def head_commit - return @head_commit if defined?(@head_commit) + strong_memoize(:head_commit) do + commit = @compare.head - commit = @compare.head - @head_commit = commit ? ::Commit.new(commit, project) : nil + ::Commit.new(commit, project) if commit + end end alias_method :commit, :head_commit def base_commit - return @base_commit if defined?(@base_commit) + strong_memoize(:base_commit) do + return unless start_commit && head_commit + return OpenStruct.new(sha: @base_sha) if @base_sha - @base_commit = if start_commit && head_commit - project.merge_base_commit(start_commit.id, head_commit.id) - else - nil - end + project.merge_base_commit(start_commit.id, head_commit.id) + end end def start_commit_sha - start_commit.try(:sha) + start_commit&.sha end def base_commit_sha - base_commit.try(:sha) + base_commit&.sha end def head_commit_sha - commit.try(:sha) + commit&.sha end def raw_diffs(*args) -- cgit v1.2.1