97
revno_index[revno_sequence] = rev_index
99
branch_id = revno_sequence[0:-1]
102
if branch_id not in branch_lines:
104
branch_lines[branch_id] = branch_line
106
branch_line = branch_lines[branch_id]
108
branch_line.append(rev_index)
107
branch_ids = branch_lines.keys()
109
def branch_id_cmp(x, y):
110
"""Compaire branch_id's first by the number of digits, then reversed
116
return cmp(len_x, len_y)
118
branch_ids.sort(branch_id_cmp)
119
# This will hold a tuple of (child_index, parent_index, col_index) for each
120
# line that needs to be drawn. If col_index is not none, then the line is
121
# drawn along that column, else the the line can be drawn directly between
122
# the child and parent because either the child and parent are in the same
123
# branch line, or the child and parent are 1 row apart.
125
empty_column = [False for i in range(len(graph_parents))]
126
# This will hold a bit map for each cell. If the cell is true, then the
127
# cell allready contains a node or line. This use when deciding what column
128
# to place a branch line or line in, without it overlaping something else.
129
columns = [list(empty_column)]
132
for branch_id in branch_ids:
133
branch_line = branch_lines[branch_id]
135
# Find the col_index for the direct parent branch. This will be the
136
# starting point when looking for a free column.
139
if len(branch_id) > 1:
140
parent_revno = branch_id[0:-1]
141
if parent_revno in revno_index:
142
parent_index = revno_index[parent_revno]
143
parent_node = linegraph[parent_index][1]
145
parent_col_index = parent_node[0]
148
col_search_order = _branch_line_col_search_order(columns,
150
color = reduce(lambda x, y: x+y, branch_id, 0)
154
last_rev_index = None
155
for rev_index in branch_line:
157
if BROKEN_LINE_LENGTH and \
158
rev_index - last_rev_index > BROKEN_LINE_LENGTH:
159
line_range.append(last_rev_index+1)
160
line_range.append(rev_index-1)
162
line_range.extend(range(last_rev_index+1, rev_index))
164
line_range.append(rev_index)
165
last_rev_index = rev_index
168
if BROKEN_LINE_LENGTH and \
169
parent_index - last_rev_index > BROKEN_LINE_LENGTH:
170
line_range.append(last_rev_index+1)
172
line_range.extend(range(last_rev_index+1, parent_index))
174
col_index = _find_free_column(columns,
178
node = (col_index, color)
179
for rev_index in branch_line:
180
linegraph[rev_index][1] = node
181
columns[col_index][rev_index] = True
183
for rev_index in branch_line:
188
end_of_merge) = merge_sorted_revisions[rev_index]
190
linegraph[rev_index][4] = graph_children[revid]
191
col_index = linegraph[rev_index][1][0]
193
for parent_revid in graph_parents[revid]:
194
if parent_revid in revid_index:
196
parent_index = revid_index[parent_revid]
111
branch_ids = branch_lines.keys()
113
def branch_id_cmp(x, y):
114
"""Compaire branch_id's first by the number of digits, then reversed
120
return cmp(len_x, len_y)
122
branch_ids.sort(branch_id_cmp)
123
# This will hold a tuple of (child_index, parent_index, col_index) for each
124
# line that needs to be drawn. If col_index is not none, then the line is
125
# drawn along that column, else the the line can be drawn directly between
126
# the child and parent because either the child and parent are in the same
127
# branch line, or the child and parent are 1 row apart.
129
empty_column = [False for i in range(len(graph_parents))]
130
# This will hold a bit map for each cell. If the cell is true, then the
131
# cell allready contains a node or line. This use when deciding what column
132
# to place a branch line or line in, without it overlaping something else.
133
columns = [list(empty_column)]
136
for branch_id in branch_ids:
137
branch_line = branch_lines[branch_id]
139
# Find the col_index for the direct parent branch. This will be the
140
# starting point when looking for a free column.
143
if len(branch_id) > 1:
144
parent_revno = branch_id[0:-1]
145
if parent_revno in revno_index:
146
parent_index = revno_index[parent_revno]
197
147
parent_node = linegraph[parent_index][1]
199
149
parent_col_index = parent_node[0]
152
col_search_order = _branch_line_col_search_order(columns,
154
color = reduce(lambda x, y: x+y, branch_id, 0)
158
last_rev_index = None
159
for rev_index in branch_line:
161
if broken_line_length and \
162
rev_index - last_rev_index > broken_line_length:
163
line_range.append(last_rev_index+1)
164
line_range.append(rev_index-1)
201
parent_col_index = None
203
_line_col_search_order(columns,
207
# If this line is really long, break it.
208
if len(branch_id) > 0 and \
209
BROKEN_LINE_LENGTH and \
210
parent_index - rev_index > BROKEN_LINE_LENGTH:
211
child_line_col_index = \
212
_find_free_column(columns,
216
_mark_column_as_used(columns,
217
child_line_col_index,
220
# Recall _line_col_search_order to reset it back to
166
line_range.extend(range(last_rev_index+1, rev_index))
168
line_range.append(rev_index)
169
last_rev_index = rev_index
172
if broken_line_length and \
173
parent_index - last_rev_index > broken_line_length:
174
line_range.append(last_rev_index+1)
176
line_range.extend(range(last_rev_index+1, parent_index))
178
col_index = _find_free_column(columns,
182
node = (col_index, color)
183
for rev_index in branch_line:
184
linegraph[rev_index][1] = node
185
columns[col_index][rev_index] = True
187
for rev_index in branch_line:
192
end_of_merge) = merge_sorted_revisions[rev_index]
194
linegraph[rev_index][4] = graph_children[revid]
195
col_index = linegraph[rev_index][1][0]
197
for parent_revid in graph_parents[revid]:
198
if parent_revid in revid_index:
200
parent_index = revid_index[parent_revid]
201
parent_node = linegraph[parent_index][1]
203
parent_col_index = parent_node[0]
205
parent_col_index = None
222
206
col_search_order = \
223
207
_line_col_search_order(columns,
224
208
parent_col_index,
226
parent_col_line_index = \
227
_find_free_column(columns,
231
_mark_column_as_used(columns,
232
parent_col_line_index,
234
lines.append((rev_index,
236
(child_line_col_index,
237
parent_col_line_index)))
239
line_col_index = col_index
240
if parent_index - rev_index >1:
241
line_range = range(rev_index + 1, parent_index)
243
_find_free_column(columns,
247
_mark_column_as_used(columns,
250
lines.append((rev_index,
254
for (child_index, parent_index, line_col_indexes) in lines:
255
(child_col_index, child_color) = linegraph[child_index][1]
256
(parent_col_index, parent_color) = linegraph[parent_index][1]
211
# If this line is really long, break it.
212
if len(branch_id) > 0 and \
213
broken_line_length and \
214
parent_index - rev_index > broken_line_length:
215
child_line_col_index = \
216
_find_free_column(columns,
220
_mark_column_as_used(columns,
221
child_line_col_index,
224
# Recall _line_col_search_order to reset it back to
227
_line_col_search_order(columns,
230
parent_col_line_index = \
231
_find_free_column(columns,
235
_mark_column_as_used(columns,
236
parent_col_line_index,
238
lines.append((rev_index,
240
(child_line_col_index,
241
parent_col_line_index)))
243
line_col_index = col_index
244
if parent_index - rev_index >1:
245
line_range = range(rev_index + 1, parent_index)
247
_find_free_column(columns,
251
_mark_column_as_used(columns,
254
lines.append((rev_index,
258
if len(line_col_indexes) == 1:
259
if parent_index - child_index == 1:
260
linegraph[child_index][2].append(
258
for (child_index, parent_index, line_col_indexes) in lines:
259
(child_col_index, child_color) = linegraph[child_index][1]
260
(parent_col_index, parent_color) = linegraph[parent_index][1]
262
if len(line_col_indexes) == 1:
263
if parent_index - child_index == 1:
264
linegraph[child_index][2].append(
269
# line from the child's column to the lines column
270
linegraph[child_index][2].append(
274
# lines down the line's column
275
for line_part_index in range(child_index+1, parent_index-1):
276
linegraph[line_part_index][2].append(
277
(line_col_indexes[0],
280
# line from the line's column to the parent's column
281
linegraph[parent_index-1][2].append(
282
(line_col_indexes[0],
265
287
# line from the child's column to the lines column
266
288
linegraph[child_index][2].append(
267
289
(child_col_index,
268
290
line_col_indexes[0],
270
# lines down the line's column
271
for line_part_index in range(child_index+1, parent_index-1):
272
linegraph[line_part_index][2].append(
273
(line_col_indexes[0],
293
linegraph[child_index+1][2].append(
294
(line_col_indexes[0],
299
linegraph[parent_index-2][2].append(
276
303
# line from the line's column to the parent's column
277
304
linegraph[parent_index-1][2].append(
278
(line_col_indexes[0],
305
(line_col_indexes[1],
279
306
parent_col_index,
283
# line from the child's column to the lines column
284
linegraph[child_index][2].append(
289
linegraph[child_index+1][2].append(
290
(line_col_indexes[0],
295
linegraph[parent_index-2][2].append(
299
# line from the line's column to the parent's column
300
linegraph[parent_index-1][2].append(
301
(line_col_indexes[1],
308
return (linegraph, revid_index, len(columns))
310
return (linegraph, revid_index, 0)
306
return (linegraph, revid_index, len(columns))
308
313
def _branch_line_col_search_order(columns, parent_col_index):
309
314
for col_index in range(parent_col_index, len(columns)):