Commit ef30dcd6 authored by Nick Thomas's avatar Nick Thomas

Deduplicate commits before rendering them in RefsController#logs_tree

parent ebbb3a27
......@@ -37,14 +37,9 @@ class Projects::RefsController < Projects::ApplicationController
end
def logs_tree
@offset = if params[:offset].present?
params[:offset].to_i
else
0
end
@resolved_commits ||= {}
@limit = 25
@offset = params[:offset].to_i
@path = params[:path]
contents = []
......@@ -62,8 +57,7 @@ class Projects::RefsController < Projects::ApplicationController
{
file_name: content.name,
# TODO: deduplicate commits so we don't render the same one multiple times
commit: (Commit.new(last_commit, project) if last_commit),
commit: resolve_commit(last_commit),
type: content.type,
commit_path: commit_path,
lock_label: path_lock && text_label_for_lock(path_lock, file)
......@@ -71,9 +65,7 @@ class Projects::RefsController < Projects::ApplicationController
end
end
# The commit titles must be passed through Banzai before being shown.
# Doing this here in bulk allows significant database work to be skipped.
prerender_commits!(@logs.map { |log| log[:commit] })
prerender_commits!
offset = (@offset + @limit)
if contents.size > offset
......@@ -93,9 +85,21 @@ class Projects::RefsController < Projects::ApplicationController
private
def prerender_commits!(commits)
# Ensure that if multiple tree entries share the same last commit, they share
# a ::Commit instance. This prevents us from rendering the same commit title
# multiple times
def resolve_commit(raw_commit)
return nil unless raw_commit.present?
@resolved_commits[raw_commit.id] ||= Commit.new(raw_commit, project)
end
# The commit titles must be passed through Banzai before being shown.
# Doing this here in bulk allows significant database work to be skipped.
def prerender_commits!
commits = @resolved_commits.values
renderer = Banzai::ObjectRenderer.new(user: current_user, default_project: @project)
renderer.render(commits, :full_title) # modifies the commit objects inplace
renderer.render(commits, :full_title)
end
def validate_ref_id
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment