Patch #42762 » v1_01_fix_revision_graph.patch
app/helpers/repositories_helper.rb | ||
---|---|---|
300 | 300 |
heads.sort_by!(&:to_s) |
301 | 301 |
space = nil |
302 | 302 |
heads.each do |head| |
303 |
if commits_by_scmid.include? head.scmid
|
|
303 |
if commits_by_scmid.include?(head.scmid) && commits_by_scmid[head.scmid][:space].nil?
|
|
304 | 304 |
space = index_head((space || -1) + 1, head, commits_by_scmid) |
305 | 305 |
end |
306 | 306 |
end |
307 |
- |
app/helpers/repositories_helper.rb | ||
---|---|---|
298 | 298 |
} |
299 | 299 |
end |
300 | 300 |
heads.sort_by!(&:to_s) |
301 |
space = nil |
|
301 |
# Process commits starting from the latest |
|
302 |
space = index_head(0, commits.first, commits_by_scmid) |
|
303 |
# Process commits from heads |
|
302 | 304 |
heads.each do |head| |
303 | 305 |
if commits_by_scmid.include?(head.scmid) && commits_by_scmid[head.scmid][:space].nil? |
304 |
space = index_head((space || -1) + 1, head, commits_by_scmid)
|
|
306 |
space = index_head(space + 1, head, commits_by_scmid)
|
|
305 | 307 |
end |
306 | 308 |
end |
307 |
# when no head matched anything use first commit |
|
308 |
space ||= index_head(0, commits.first, commits_by_scmid) |
|
309 |
# Process orphan commits |
|
310 |
while (commit = commits.find { |commit| commits_by_scmid[commit.scmid][:space].nil? }) |
|
311 |
space = index_head(space + 1, commit, commits_by_scmid) |
|
312 |
end |
|
309 | 313 |
return commits_by_scmid, space |
310 | 314 |
end |
311 | 315 |
|
312 |
- |
app/assets/javascripts/revision_graph.js | ||
---|---|---|
63 | 63 |
fill: colors[commit.space], |
64 | 64 |
stroke: 'none' |
65 | 65 |
}).toFront(); |
66 |
// paths to parents |
|
67 |
$.each(commit.parent_scmids, function(index, parent_scmid) { |
|
68 |
parent_commit = commits_by_scmid[parent_scmid]; |
|
66 |
|
|
67 |
// check for parents in the same column |
|
68 |
let noVerticalParents = true; |
|
69 |
$.each(commit.parent_scmids, function (index, parentScmid) { |
|
70 |
parent_commit = commits_by_scmid[parentScmid]; |
|
69 | 71 |
if (parent_commit) { |
70 | 72 |
if (!parent_commit.hasOwnProperty("space")) |
71 | 73 |
parent_commit.space = 0; |
72 | 74 |
|
75 |
// has parent in the same column on this page |
|
76 |
if (parent_commit.space === commit.space) |
|
77 |
noVerticalParents = false; |
|
78 |
} else { |
|
79 |
// has parent in the same column on the other page |
|
80 |
noVerticalParents = false; |
|
81 |
} |
|
82 |
}); |
|
83 |
|
|
84 |
// paths to parents |
|
85 |
$.each(commit.parent_scmids, function(index, parent_scmid) { |
|
86 |
parent_commit = commits_by_scmid[parent_scmid]; |
|
87 |
if (parent_commit) { |
|
73 | 88 |
parent_y = yForRow(max_rdmid - parent_commit.rdmid); |
74 | 89 |
parent_x = graph_x_offset + XSTEP / 2 + XSTEP * parent_commit.space; |
75 |
if (parent_commit.space == commit.space) { |
|
90 |
const controlPointDelta = (parent_y - y) / 8; |
|
91 |
|
|
92 |
if (parent_commit.space === commit.space) { |
|
76 | 93 |
// vertical path |
77 | 94 |
path = revisionGraph.path([ |
78 | 95 |
'M', x, y, |
79 | 96 |
'V', parent_y]); |
97 |
} else if (noVerticalParents) { |
|
98 |
// branch start (Bezier curve) |
|
99 |
path = revisionGraph.path([ |
|
100 |
'M', x, y, |
|
101 |
'C', x, y + controlPointDelta, x, parent_y - controlPointDelta, parent_x, parent_y]); |
|
102 |
} else if (!parent_commit.hasOwnProperty('vertical_children')) { |
|
103 |
// branch end (Bezier curve) |
|
104 |
path = revisionGraph.path([ |
|
105 |
'M', x, y, |
|
106 |
'C', parent_x, y + controlPointDelta, parent_x, parent_y, parent_x, parent_y]); |
|
80 | 107 |
} else { |
81 | 108 |
// path to a commit in a different branch (Bezier curve) |
82 | 109 |
path = revisionGraph.path([ |
83 | 110 |
'M', x, y, |
84 |
'C', x, y, x, y + (parent_y - y) / 2, x + (parent_x - x) / 2, y + (parent_y - y) / 2, |
|
85 |
'C', x + (parent_x - x) / 2, y + (parent_y - y) / 2, parent_x, parent_y-(parent_y-y)/2, parent_x, parent_y]); |
|
111 |
'C', parent_x, y, x, parent_y, parent_x, parent_y]); |
|
86 | 112 |
} |
87 | 113 |
} else { |
88 | 114 |
// vertical path ending at the bottom of the revisionGraph |
app/helpers/repositories_helper.rb | ||
---|---|---|
310 | 310 |
while (commit = commits.find { |commit| commits_by_scmid[commit.scmid][:space].nil? }) |
311 | 311 |
space = index_head(space + 1, commit, commits_by_scmid) |
312 | 312 |
end |
313 |
# Set vertical_children flag for commits that have children in the same column |
|
314 |
# for S-style connections between commits |
|
315 |
commits_by_scmid.each_value do |commit| |
|
316 |
commit[:parent_scmids].each do |scmid| |
|
317 |
if (parent = commits_by_scmid[scmid]) && parent[:space] == commit[:space] |
|
318 |
parent[:vertical_children] = true |
|
319 |
end |
|
320 |
end |
|
321 |
end |
|
313 | 322 |
return commits_by_scmid, space |
314 | 323 |
end |
315 | 324 |
|
316 |
- |
- « Previous
- 1
- …
- 8
- 9
- 10
- Next »