45
44
ud = difflib.unified_diff(oldlines, newlines,
46
fromfile=old_label, tofile=new_label)
45
fromfile=old_filename+'\t',
46
tofile=new_filename+'\t')
48
49
# work-around for difflib being too smart for its own good
49
50
# if /dev/null is "1,0", patch won't recognize it as /dev/null
52
52
ud[2] = ud[2].replace('-1,0', '-0,0')
55
54
ud[2] = ud[2].replace('+1,0', '+0,0')
55
# work around for difflib emitting random spaces after the label
56
ud[0] = ud[0][:-2] + '\n'
57
ud[1] = ud[1][:-2] + '\n'
58
60
to_file.write(line)
141
141
oldtmpf.close() # and delete
146
def show_diff(b, revision, specific_files, external_diff_options=None):
144
def show_diff(b, from_spec, specific_files, external_diff_options=None,
145
revision2=None, output=None, b2=None):
147
146
"""Shortcut for showing the diff to the working tree.
153
None for each, or otherwise the old revision to compare against.
152
None for 'basis tree', or otherwise the old revision to compare against.
155
154
The more general form is show_diff_trees(), where the caller
156
155
supplies any two trees.
161
old_tree = b.basis_tree()
163
old_tree = b.revision_tree(b.lookup_revision(revision))
165
new_tree = b.working_tree()
167
show_diff_trees(old_tree, new_tree, sys.stdout, specific_files,
168
external_diff_options)
161
if from_spec is None:
163
old_tree = b.basis_tree()
165
old_tree = b.working_tree()
167
old_tree = b.repository.revision_tree(from_spec.in_history(b).rev_id)
169
if revision2 is None:
171
new_tree = b.working_tree()
173
new_tree = b2.working_tree()
175
new_tree = b.repository.revision_tree(revision2.in_history(b).rev_id)
177
return show_diff_trees(old_tree, new_tree, output, specific_files,
178
external_diff_options)
204
229
delta = compare_trees(old_tree, new_tree, want_unchanged=False,
205
230
specific_files=specific_files)
207
233
for path, file_id, kind in delta.removed:
208
print >>to_file, '*** removed %s %r' % (kind, path)
210
diff_file(old_label + path,
211
old_tree.get_file(file_id).readlines(),
235
print >>to_file, '=== removed %s %r' % (kind, path)
236
old_tree.inventory[file_id].diff(diff_file, old_label + path, old_tree,
237
DEVNULL, None, None, to_file)
216
238
for path, file_id, kind in delta.added:
217
print >>to_file, '*** added %s %r' % (kind, path)
222
new_tree.get_file(file_id).readlines(),
225
for old_path, new_path, file_id, kind, text_modified in delta.renamed:
226
print >>to_file, '*** renamed %s %r => %r' % (kind, old_path, new_path)
240
print >>to_file, '=== added %s %r' % (kind, path)
241
new_tree.inventory[file_id].diff(diff_file, new_label + path, new_tree,
242
DEVNULL, None, None, to_file,
244
for (old_path, new_path, file_id, kind,
245
text_modified, meta_modified) in delta.renamed:
247
prop_str = get_prop_change(meta_modified)
248
print >>to_file, '=== renamed %s %r => %r%s' % (
249
kind, old_path, new_path, prop_str)
250
_maybe_diff_file_or_symlink(old_label, old_path, old_tree, file_id,
251
new_label, new_path, new_tree,
252
text_modified, kind, to_file, diff_file)
253
for path, file_id, kind, text_modified, meta_modified in delta.modified:
255
prop_str = get_prop_change(meta_modified)
256
print >>to_file, '=== modified %s %r%s' % (kind, path, prop_str)
227
257
if text_modified:
228
diff_file(old_label + old_path,
229
old_tree.get_file(file_id).readlines(),
230
new_label + new_path,
231
new_tree.get_file(file_id).readlines(),
234
for path, file_id, kind in delta.modified:
235
print >>to_file, '*** modified %s %r' % (kind, path)
237
diff_file(old_label + path,
238
old_tree.get_file(file_id).readlines(),
240
new_tree.get_file(file_id).readlines(),
258
_maybe_diff_file_or_symlink(old_label, path, old_tree, file_id,
259
new_label, path, new_tree,
260
True, kind, to_file, diff_file)
264
def get_prop_change(meta_modified):
266
return " (properties changed)"
271
def _maybe_diff_file_or_symlink(old_label, old_path, old_tree, file_id,
272
new_label, new_path, new_tree, text_modified,
273
kind, to_file, diff_file):
275
new_entry = new_tree.inventory[file_id]
276
old_tree.inventory[file_id].diff(diff_file,
277
old_label + old_path, old_tree,
278
new_label + new_path, new_entry,