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
108
def get_changes_as_text(self, show_ids=False, show_unchanged=False,
214
111
output = StringIO.StringIO()
215
self.show(output, show_ids, show_unchanged, short_status)
112
report_delta(output, self, short_status, show_ids, show_unchanged)
216
113
return output.getvalue()
437
338
versioned_change = versioned_change_map[versioned]
438
339
reporter.report(file_id, path, versioned_change, renamed, modified,
439
340
exe_change, kind)
342
def report_delta(to_file, delta, short_status=False, show_ids=False,
343
show_unchanged=False, indent='', filter=None):
344
"""Output this delta in status-like form to to_file.
346
:param to_file: A file-like object where the output is displayed.
348
:param delta: A TreeDelta containing the changes to be displayed
350
:param short_status: Single-line status if True.
352
:param show_ids: Output the file ids if True.
354
:param show_unchanged: Output the unchanged files if True.
356
:param indent: Added at the beginning of all output lines (for merged
359
:param filter: A callable receiving a path and a file id and
360
returning True if the path should be displayed.
363
def decorate_path(path, kind, meta_modified=None):
364
if kind == 'directory':
366
elif kind == 'symlink':
372
def show_more_renamed(item):
373
(oldpath, file_id, kind,
374
text_modified, meta_modified, newpath) = item
375
dec_new_path = decorate_path(newpath, kind, meta_modified)
376
to_file.write(' => %s' % dec_new_path)
377
if text_modified or meta_modified:
378
extra_modified.append((newpath, file_id, kind,
379
text_modified, meta_modified))
381
def show_more_kind_changed(item):
382
(path, file_id, old_kind, new_kind) = item
383
to_file.write(' (%s => %s)' % (old_kind, new_kind))
385
def show_path(path, file_id, kind, meta_modified,
386
default_format, with_file_id_format):
387
dec_path = decorate_path(path, kind, meta_modified)
389
to_file.write(with_file_id_format % dec_path)
391
to_file.write(default_format % dec_path)
393
def show_list(files, long_status_name, short_status_letter,
394
default_format='%s', with_file_id_format='%-30s',
399
prefix = short_status_letter
402
prefix = indent + prefix + ' '
405
path, file_id, kind = item[:3]
406
if (filter is not None and not filter(path, file_id)):
408
if not header_shown and not short_status:
409
to_file.write(indent + long_status_name + ':\n')
413
meta_modified = item[4]
415
to_file.write(prefix)
416
show_path(path, file_id, kind, meta_modified,
417
default_format, with_file_id_format)
418
if show_more is not None:
421
to_file.write(' %s' % file_id)
424
show_list(delta.removed, 'removed', 'D')
425
show_list(delta.added, 'added', 'A')
426
show_list(delta.missing, 'missing', '!')
428
# Reorder delta.renamed tuples so that all lists share the same
429
# order for their 3 first fields and that they also begin like
430
# the delta.modified tuples
431
renamed = [(p, i, k, tm, mm, np)
432
for p, np, i, k, tm, mm in delta.renamed]
433
show_list(renamed, 'renamed', 'R', with_file_id_format='%s',
434
show_more=show_more_renamed)
435
show_list(delta.kind_changed, 'kind changed', 'K',
436
with_file_id_format='%s',
437
show_more=show_more_kind_changed)
438
show_list(delta.modified + extra_modified, 'modified', 'M')
440
show_list(delta.unchanged, 'unchanged', 'S')
442
show_list(delta.unversioned, 'unknown', ' ')