summaryrefslogtreecommitdiffstats
path: root/app
diff options
context:
space:
mode:
authorEtienne Massip <etienne.massip@gmail.com>2012-02-04 14:02:31 +0000
committerEtienne Massip <etienne.massip@gmail.com>2012-02-04 14:02:31 +0000
commitb9c26d6ddcd3b2afa91637d0f81738e7d2e6c17a (patch)
tree57f5e7cf2635d624410bf30a5ca44f179c6d61ba /app
parentbe050be5e5efb06910c8027703ee5dd4ddccf56f (diff)
downloadredmine-b9c26d6ddcd3b2afa91637d0f81738e7d2e6c17a.tar.gz
redmine-b9c26d6ddcd3b2afa91637d0f81738e7d2e6c17a.zip
Revision graph code cleanup.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@8773 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app')
-rw-r--r--app/helpers/repositories_helper.rb85
-rw-r--r--app/views/repositories/_revision_graph.html.erb17
-rw-r--r--app/views/repositories/_revisions.html.erb18
3 files changed, 62 insertions, 58 deletions
diff --git a/app/helpers/repositories_helper.rb b/app/helpers/repositories_helper.rb
index 24807139e..3c12262a5 100644
--- a/app/helpers/repositories_helper.rb
+++ b/app/helpers/repositories_helper.rb
@@ -256,59 +256,64 @@ module RepositoriesHelper
'<br />'.html_safe + l(:text_scm_path_encoding_note))
end
- def index_commits(commits, heads, href_proc = nil)
+ def index_commits(commits, heads)
return nil if commits.nil? or commits.first.parents.nil?
- map = {}
- commit_hashes = []
+
refs_map = {}
- href_proc ||= Proc.new {|x|x}
- heads.each{|r| refs_map[r.scmid] ||= []; refs_map[r.scmid] << r}
- commits.reverse.each_with_index do |c, i|
- h = {}
- h[:parents] = c.parents.collect do |p|
- [p.scmid, 0, 0]
- end
- h[:rdmid] = i
- h[:space] = 0
- h[:refs] = refs_map[c.scmid].join(" ") if refs_map.include? c.scmid
- h[:scmid] = c.scmid
- h[:href] = href_proc.call(c.scmid)
- commit_hashes << h
- map[c.scmid] = h
+ heads.each do |head|
+ refs_map[head.scmid] ||= []
+ refs_map[head.scmid] << head
end
- heads.sort! do |a,b|
- a.to_s <=> b.to_s
+
+ commits_by_scmid = {}
+ commits.reverse.each_with_index do |commit, commit_index|
+
+ commits_by_scmid[commit.scmid] = {
+ :parent_scmids => commit.parents.collect { |parent| parent.scmid },
+ :rdmid => commit_index,
+ :space => 0,
+ :refs => refs_map.include?(commit.scmid) ? refs_map[commit.scmid].join(" ") : nil,
+ :scmid => commit.scmid,
+ :href => block_given? ? yield(commit.scmid) : commit.scmid
+ }
end
- j = 0
- heads.each do |h|
- if map.include? h.scmid then
- j = mark_chain(j += 1, map[h.scmid], map)
+
+ heads.sort! { |head1, head2| head1.to_s <=> head2.to_s }
+
+ mark_index = 0
+ heads.each do |head|
+ if commits_by_scmid.include? head.scmid
+ mark_index = mark_chain(mark_index += 1, commits_by_scmid[head.scmid], commits_by_scmid)
end
end
# when no head matched anything use first commit
- if j == 0 then
- mark_chain(j += 1, map.values.first, map)
+ if mark_index == 0
+ mark_chain(mark_index += 1, commits_by_scmid.values.first, commits_by_scmid)
end
- map
+ commits_by_scmid
end
- def mark_chain(mark, commit, map)
- stack = [[mark, commit]]
- markmax = mark
+ def mark_chain(mark_index, commit, commits_by_scmid)
+
+ stack = [[mark_index, commit]]
+ mark_max_index = mark_index
+
until stack.empty?
- current = stack.pop
- m, commit = current
- commit[:space] = m if commit[:space] == 0
- m1 = m - 1
- commit[:parents].each_with_index do |p, i|
- psha = p[0]
- if map.include? psha and map[psha][:space] == 0 then
- stack << [m1 += 1, map[psha]] if i == 0
- stack = [[m1 += 1, map[psha]]] + stack if i > 0
+ mark_index, commit = stack.pop
+ commit[:space] = mark_index if commit[:space] == 0
+
+ mark_index -=1
+ commit[:parent_scmids].each_with_index do |parent_scmid, parent_index|
+
+ parent_commit = commits_by_scmid[parent_scmid]
+
+ if parent_commit and parent_commit[:space] == 0
+
+ stack.unshift [mark_index += 1, parent_commit]
end
end
- markmax = m1 if markmax < m1
+ mark_max_index = mark_index if mark_max_index < mark_index
end
- markmax
+ mark_max_index
end
end
diff --git a/app/views/repositories/_revision_graph.html.erb b/app/views/repositories/_revision_graph.html.erb
index 6dcaa3f2d..5b0ea73de 100644
--- a/app/views/repositories/_revision_graph.html.erb
+++ b/app/views/repositories/_revision_graph.html.erb
@@ -1,13 +1,12 @@
-<%= javascript_include_tag "raphael.js" %>
-<script type="text/javascript" charset="utf-8">
- var chunk = {commits:<%= commits.values.to_json.html_safe %>}
-</script>
-<%= javascript_include_tag "revision_graph.js" %>
+<%= javascript_include_tag 'raphael.js' %>
+<%= javascript_include_tag 'revision_graph.js' %>
-<script type="text/javascript">
- Event.observe(window,"load", function(){
- branchGraph(document.getElementById("holder"));
- })
+<script type="text/javascript" charset="utf-8">
+ Event.observe(window, 'load', function(){
+ branchGraph(
+ document.getElementById("holder"),
+ <%= commits.to_json.html_safe %>);
+ });
</script>
<div id="holder" class="graph"></div>
diff --git a/app/views/repositories/_revisions.html.erb b/app/views/repositories/_revisions.html.erb
index d9dfaf2b9..77744dae1 100644
--- a/app/views/repositories/_revisions.html.erb
+++ b/app/views/repositories/_revisions.html.erb
@@ -24,18 +24,18 @@
<% if show_revision_graph %>
<% if line_num == 1 %>
<td class="revision_graph" rowspan="<%= revisions.size %>">
- <% href_base = Proc.new {|x| url_for(:controller => 'repositories',
- :action => 'revision',
- :id => project,
- :repository_id => @repository.identifier_param,
- :rev => x) } %>
<%= render :partial => 'revision_graph',
:locals => {
:commits => index_commits(
- revisions,
- @repository.branches,
- href_base
- )
+ revisions,
+ @repository.branches) do |scmid|
+ url_for(
+ :controller => 'repositories',
+ :action => 'revision',
+ :id => project,
+ :repository_id => @repository.identifier_param,
+ :rev => scmid)
+ end
} %>
</td>
<% end %>