42
42
It's up to you how to actually draw the nodes and lines (straight,
43
43
curved, kinked, etc.) and to pick the actual colours for each index.
45
assert isinstance(start_revs, list)
46
def update_root_progress(step_number):
47
"""IFF our container received a root progress bar, then update it."""
48
if root_progress is not None:
49
root_progress.update(None, step_number)
48
53
graph_children = {}
49
for (revid, parent_revids) in graph.iter_ancestry(start_revs):
50
if parent_revids is None:
53
if parent_revids == (NULL_REVISION,):
54
graph_parents[revid] = ()
56
graph_parents[revid] = parent_revids
57
for parent in parent_revids:
58
graph_children.setdefault(parent, []).append(revid)
59
graph_children.setdefault(revid, [])
61
for ghost_child in graph_children[ghost]:
62
graph_parents[ghost_child] = [p for p in graph_parents[ghost_child]
54
update_root_progress(1)
55
progress_bar = ui.ui_factory.nested_progress_bar()
57
progress_bar.update("Arranging tree fragments")
58
for i, (revid, parent_revids) in enumerate(graph.iter_ancestry(start_revs)):
61
if parent_revids is None:
64
if parent_revids == (NULL_REVISION,):
65
graph_parents[revid] = ()
67
graph_parents[revid] = parent_revids
68
for parent in parent_revids:
69
graph_children.setdefault(parent, []).append(revid)
70
graph_children.setdefault(revid, [])
72
progress_bar.finished()
74
update_root_progress(2)
75
progress_bar = ui.ui_factory.nested_progress_bar()
77
progress_bar.update("Removing ghosts", 0, len(ghosts))
78
for i, ghost in enumerate(ghosts):
80
progress_bar.update(None, i)
81
for ghost_child in graph_children[ghost]:
82
graph_parents[ghost_child] = [p for p in graph_parents[ghost_child]
85
progress_bar.finished()
64
86
graph_parents["top:"] = start_revs
66
88
if len(graph_parents)>0:
149
180
columns = [list(empty_column)]
152
for branch_id in branch_ids:
153
branch_line = branch_lines[branch_id]
155
# Find the col_index for the direct parent branch. This will be the
156
# starting point when looking for a free column.
159
if len(branch_id) > 1:
160
parent_revno = branch_id[0:-1]
161
if parent_revno in revno_index:
162
parent_index = revno_index[parent_revno]
163
parent_node = linegraph[parent_index][1]
165
parent_col_index = parent_node[0]
168
col_search_order = _branch_line_col_search_order(columns,
170
color = reduce(lambda x, y: x+y, branch_id, 0)
174
last_rev_index = None
175
for rev_index in branch_line:
177
if broken_line_length and \
178
rev_index - last_rev_index > broken_line_length:
179
line_range.append(last_rev_index+1)
180
line_range.append(rev_index-1)
182
line_range.extend(range(last_rev_index+1, rev_index))
184
line_range.append(rev_index)
185
last_rev_index = rev_index
188
if broken_line_length and \
189
parent_index - last_rev_index > broken_line_length:
190
line_range.append(last_rev_index+1)
192
line_range.extend(range(last_rev_index+1, parent_index))
194
col_index = _find_free_column(columns,
198
node = (col_index, color)
199
for rev_index in branch_line:
200
linegraph[rev_index][1] = node
201
columns[col_index][rev_index] = True
203
for rev_index in branch_line:
208
end_of_merge) = merge_sorted_revisions[rev_index]
210
linegraph[rev_index][4] = graph_children[revid]
211
col_index = linegraph[rev_index][1][0]
213
for parent_revid in graph_parents[revid]:
214
if parent_revid in revid_index:
216
parent_index = revid_index[parent_revid]
183
update_root_progress(4)
184
progress_bar = ui.ui_factory.nested_progress_bar()
186
progress_bar.update("Organizing edges", 0, len(branch_ids))
187
for i, branch_id in enumerate(branch_ids):
189
progress_bar.update(None, i)
190
branch_line = branch_lines[branch_id]
192
# Find the col_index for the direct parent branch. This will be the
193
# starting point when looking for a free column.
196
if len(branch_id) > 1:
197
parent_revno = branch_id[0:-1]
198
if parent_revno in revno_index:
199
parent_index = revno_index[parent_revno]
217
200
parent_node = linegraph[parent_index][1]
219
202
parent_col_index = parent_node[0]
205
col_search_order = _branch_line_col_search_order(columns,
207
color = reduce(lambda x, y: x+y, branch_id, 0)
211
last_rev_index = None
212
for rev_index in branch_line:
214
if broken_line_length and \
215
rev_index - last_rev_index > broken_line_length:
216
line_range.append(last_rev_index+1)
217
line_range.append(rev_index-1)
221
parent_col_index = None
223
_line_col_search_order(columns,
227
# If this line is really long, break it.
228
if len(branch_id) > 0 and \
229
broken_line_length and \
230
parent_index - rev_index > broken_line_length:
231
child_line_col_index = \
232
_find_free_column(columns,
236
_mark_column_as_used(columns,
237
child_line_col_index,
240
# Recall _line_col_search_order to reset it back to
219
line_range.extend(range(last_rev_index+1, rev_index))
221
line_range.append(rev_index)
222
last_rev_index = rev_index
225
if broken_line_length and \
226
parent_index - last_rev_index > broken_line_length:
227
line_range.append(last_rev_index+1)
229
line_range.extend(range(last_rev_index+1, parent_index))
231
col_index = _find_free_column(columns,
235
node = (col_index, color)
236
for rev_index in branch_line:
237
linegraph[rev_index][1] = node
238
columns[col_index][rev_index] = True
240
for rev_index in branch_line:
245
end_of_merge) = merge_sorted_revisions[rev_index]
247
linegraph[rev_index][4] = graph_children[revid]
248
col_index = linegraph[rev_index][1][0]
250
for parent_revid in graph_parents[revid]:
251
if parent_revid in revid_index:
253
parent_index = revid_index[parent_revid]
254
parent_node = linegraph[parent_index][1]
256
parent_col_index = parent_node[0]
258
parent_col_index = None
242
259
col_search_order = \
243
260
_line_col_search_order(columns,
244
261
parent_col_index,
246
parent_col_line_index = \
247
_find_free_column(columns,
251
_mark_column_as_used(columns,
252
parent_col_line_index,
254
lines.append((rev_index,
256
(child_line_col_index,
257
parent_col_line_index)))
259
line_col_index = col_index
260
if parent_index - rev_index >1:
261
line_range = range(rev_index + 1, parent_index)
263
_find_free_column(columns,
267
_mark_column_as_used(columns,
270
lines.append((rev_index,
264
# If this line is really long, break it.
265
if len(branch_id) > 0 and \
266
broken_line_length and \
267
parent_index - rev_index > broken_line_length:
268
child_line_col_index = \
269
_find_free_column(columns,
273
_mark_column_as_used(columns,
274
child_line_col_index,
277
# Recall _line_col_search_order to reset it back to
280
_line_col_search_order(columns,
283
parent_col_line_index = \
284
_find_free_column(columns,
288
_mark_column_as_used(columns,
289
parent_col_line_index,
291
lines.append((rev_index,
293
(child_line_col_index,
294
parent_col_line_index)))
296
line_col_index = col_index
297
if parent_index - rev_index >1:
298
line_range = range(rev_index + 1, parent_index)
300
_find_free_column(columns,
304
_mark_column_as_used(columns,
307
lines.append((rev_index,
311
progress_bar.finished()
274
for (child_index, parent_index, line_col_indexes) in lines:
275
(child_col_index, child_color) = linegraph[child_index][1]
276
(parent_col_index, parent_color) = linegraph[parent_index][1]
278
if len(line_col_indexes) == 1:
279
if parent_index - child_index == 1:
280
linegraph[child_index][2].append(
313
update_root_progress(5)
314
progress_bar = ui.ui_factory.nested_progress_bar()
316
progress_bar.update("Prettifying graph", 0, len(lines))
317
for i, (child_index, parent_index, line_col_indexes) in enumerate(lines):
319
progress_bar.update(None, i)
320
(child_col_index, child_color) = linegraph[child_index][1]
321
(parent_col_index, parent_color) = linegraph[parent_index][1]
323
if len(line_col_indexes) == 1:
324
if parent_index - child_index == 1:
325
linegraph[child_index][2].append(
330
# line from the child's column to the lines column
331
linegraph[child_index][2].append(
335
# lines down the line's column
336
for line_part_index in range(child_index+1, parent_index-1):
337
linegraph[line_part_index][2].append(
338
(line_col_indexes[0],
341
# line from the line's column to the parent's column
342
linegraph[parent_index-1][2].append(
343
(line_col_indexes[0],
285
348
# line from the child's column to the lines column
286
349
linegraph[child_index][2].append(
287
350
(child_col_index,
288
351
line_col_indexes[0],
290
# lines down the line's column
291
for line_part_index in range(child_index+1, parent_index-1):
292
linegraph[line_part_index][2].append(
293
(line_col_indexes[0],
354
linegraph[child_index+1][2].append(
355
(line_col_indexes[0],
360
linegraph[parent_index-2][2].append(
296
364
# line from the line's column to the parent's column
297
365
linegraph[parent_index-1][2].append(
298
(line_col_indexes[0],
366
(line_col_indexes[1],
299
367
parent_col_index,
303
# line from the child's column to the lines column
304
linegraph[child_index][2].append(
309
linegraph[child_index+1][2].append(
310
(line_col_indexes[0],
315
linegraph[parent_index-2][2].append(
319
# line from the line's column to the parent's column
320
linegraph[parent_index-1][2].append(
321
(line_col_indexes[1],
370
progress_bar.finished()
324
371
return (linegraph, revid_index, len(columns))
326
373
return (linegraph, revid_index, 0)