111
def show(self, to_file, show_ids=False, show_unchanged=False,
112
short_status=False, indent='',
114
"""Output this delta in status-like form to to_file.
116
:param to_file: A file-like object where the output is displayed.
118
:param show_ids: Output the file ids if True.
120
:param show_unchanged: Output the unchanged files if True.
122
:param short_status: Single-line status if True.
124
:param indent: Added at the beginning of all output lines (for merged
127
:param filter: A callable receiving a path and a file id and
128
returning True if the path should be displayed.
131
def decorate_path(path, kind, meta_modified=None):
132
if kind == 'directory':
134
elif kind == 'symlink':
140
def show_more_renamed(item):
141
(oldpath, file_id, kind,
142
text_modified, meta_modified, newpath) = item
143
dec_new_path = decorate_path(newpath, kind, meta_modified)
144
to_file.write(' => %s' % dec_new_path)
145
if text_modified or meta_modified:
146
extra_modified.append((newpath, file_id, kind,
147
text_modified, meta_modified))
149
def show_more_kind_changed(item):
150
(path, file_id, old_kind, new_kind) = item
151
to_file.write(' (%s => %s)' % (old_kind, new_kind))
153
def show_path(path, file_id, kind, meta_modified,
154
default_format, with_file_id_format):
155
dec_path = decorate_path(path, kind, meta_modified)
157
to_file.write(with_file_id_format % dec_path)
159
to_file.write(default_format % dec_path)
161
def show_list(files, long_status_name, short_status_letter,
162
default_format='%s', with_file_id_format='%-30s',
167
prefix = short_status_letter
170
prefix = indent + prefix + ' '
173
path, file_id, kind = item[:3]
174
if (filter is not None and not filter(path, file_id)):
176
if not header_shown and not short_status:
177
to_file.write(indent + long_status_name + ':\n')
181
meta_modified = item[4]
183
to_file.write(prefix)
184
show_path(path, file_id, kind, meta_modified,
185
default_format, with_file_id_format)
186
if show_more is not None:
189
to_file.write(' %s' % file_id)
192
show_list(self.removed, 'removed', 'D')#
193
show_list(self.added, 'added', 'A')
195
# Reorder self.renamed tuples so that all lists share the same
196
# order for their 3 first fields and that they also begin like
197
# the self.modified tuples
198
renamed = [(p, i, k, tm, mm, np)
199
for p, np, i, k, tm, mm in self.renamed]
200
show_list(renamed, 'renamed', 'R', with_file_id_format='%s',
201
show_more=show_more_renamed)
202
show_list(self.kind_changed, 'kind changed', 'K',
203
with_file_id_format='%s',
204
show_more=show_more_kind_changed)
205
show_list(self.modified + extra_modified, 'modified', 'M')
207
show_list(self.unchanged, 'unchanged', 'S')
209
show_list(self.unversioned, 'unknown', ' ')
211
110
def get_changes_as_text(self, show_ids=False, show_unchanged=False,
214
113
output = StringIO.StringIO()
215
self.show(output, show_ids, show_unchanged, short_status)
114
report_delta(output, self, short_status, show_ids, show_unchanged)
216
115
return output.getvalue()
437
335
versioned_change = versioned_change_map[versioned]
438
336
reporter.report(file_id, path, versioned_change, renamed, modified,
439
337
exe_change, kind)
339
def report_delta(to_file, delta, short_status=False, show_ids=False,
340
show_unchanged=False, indent='', filter=None):
341
"""Output this delta in status-like form to to_file.
343
:param to_file: A file-like object where the output is displayed.
345
:param delta: A TreeDelta containing the changes to be displayed
347
:param short_status: Single-line status if True.
349
:param show_ids: Output the file ids if True.
351
:param show_unchanged: Output the unchanged files if True.
353
:param indent: Added at the beginning of all output lines (for merged
356
:param filter: A callable receiving a path and a file id and
357
returning True if the path should be displayed.
360
def decorate_path(path, kind, meta_modified=None):
361
if kind == 'directory':
363
elif kind == 'symlink':
369
def show_more_renamed(item):
370
(oldpath, file_id, kind,
371
text_modified, meta_modified, newpath) = item
372
dec_new_path = decorate_path(newpath, kind, meta_modified)
373
to_file.write(' => %s' % dec_new_path)
374
if text_modified or meta_modified:
375
extra_modified.append((newpath, file_id, kind,
376
text_modified, meta_modified))
378
def show_more_kind_changed(item):
379
(path, file_id, old_kind, new_kind) = item
380
to_file.write(' (%s => %s)' % (old_kind, new_kind))
382
def show_path(path, file_id, kind, meta_modified,
383
default_format, with_file_id_format):
384
dec_path = decorate_path(path, kind, meta_modified)
386
to_file.write(with_file_id_format % dec_path)
388
to_file.write(default_format % dec_path)
390
def show_list(files, long_status_name, short_status_letter,
391
default_format='%s', with_file_id_format='%-30s',
396
prefix = short_status_letter
399
prefix = indent + prefix + ' '
402
path, file_id, kind = item[:3]
403
if (filter is not None and not filter(path, file_id)):
405
if not header_shown and not short_status:
406
to_file.write(indent + long_status_name + ':\n')
410
meta_modified = item[4]
412
to_file.write(prefix)
413
show_path(path, file_id, kind, meta_modified,
414
default_format, with_file_id_format)
415
if show_more is not None:
418
to_file.write(' %s' % file_id)
421
show_list(delta.removed, 'removed', 'D')
422
show_list(delta.added, 'added', 'A')
424
# Reorder delta.renamed tuples so that all lists share the same
425
# order for their 3 first fields and that they also begin like
426
# the delta.modified tuples
427
renamed = [(p, i, k, tm, mm, np)
428
for p, np, i, k, tm, mm in delta.renamed]
429
show_list(renamed, 'renamed', 'R', with_file_id_format='%s',
430
show_more=show_more_renamed)
431
show_list(delta.kind_changed, 'kind changed', 'K',
432
with_file_id_format='%s',
433
show_more=show_more_kind_changed)
434
show_list(delta.modified + extra_modified, 'modified', 'M')
436
show_list(delta.unchanged, 'unchanged', 'S')
438
show_list(delta.unversioned, 'unknown', ' ')