Show More
@@ -50,6 +50,9 class diffopts(object): | |||||
50 | defaultopts = diffopts() |
|
50 | defaultopts = diffopts() | |
51 |
|
51 | |||
52 | def unidiff(a, ad, b, bd, fn, r=None, opts=defaultopts): |
|
52 | def unidiff(a, ad, b, bd, fn, r=None, opts=defaultopts): | |
|
53 | def datetag(date): | |||
|
54 | return opts.git and '\n' or '\t%s\n' % date | |||
|
55 | ||||
53 | if not a and not b: return "" |
|
56 | if not a and not b: return "" | |
54 | epoch = util.datestr((0, 0)) |
|
57 | epoch = util.datestr((0, 0)) | |
55 |
|
58 | |||
@@ -58,19 +61,19 def unidiff(a, ad, b, bd, fn, r=None, op | |||||
58 | elif not a: |
|
61 | elif not a: | |
59 | b = splitnewlines(b) |
|
62 | b = splitnewlines(b) | |
60 | if a is None: |
|
63 | if a is None: | |
61 |
l1 = |
|
64 | l1 = '--- /dev/null%s' % datetag(epoch) | |
62 | else: |
|
65 | else: | |
63 |
l1 = "--- %s |
|
66 | l1 = "--- %s%s" % ("a/" + fn, datetag(ad)) | |
64 |
l2 = "+++ %s |
|
67 | l2 = "+++ %s%s" % ("b/" + fn, datetag(bd)) | |
65 | l3 = "@@ -0,0 +1,%d @@\n" % len(b) |
|
68 | l3 = "@@ -0,0 +1,%d @@\n" % len(b) | |
66 | l = [l1, l2, l3] + ["+" + e for e in b] |
|
69 | l = [l1, l2, l3] + ["+" + e for e in b] | |
67 | elif not b: |
|
70 | elif not b: | |
68 | a = splitnewlines(a) |
|
71 | a = splitnewlines(a) | |
69 |
l1 = "--- %s |
|
72 | l1 = "--- %s%s" % ("a/" + fn, datetag(ad)) | |
70 | if b is None: |
|
73 | if b is None: | |
71 |
l2 = |
|
74 | l2 = '+++ /dev/null%s' % datetag(epoch) | |
72 | else: |
|
75 | else: | |
73 |
l2 = "+++ %s |
|
76 | l2 = "+++ %s%s" % ("b/" + fn, datetag(bd)) | |
74 | l3 = "@@ -1,%d +0,0 @@\n" % len(a) |
|
77 | l3 = "@@ -1,%d +0,0 @@\n" % len(a) | |
75 | l = [l1, l2, l3] + ["-" + e for e in a] |
|
78 | l = [l1, l2, l3] + ["-" + e for e in a] | |
76 | else: |
|
79 | else: | |
@@ -79,8 +82,8 def unidiff(a, ad, b, bd, fn, r=None, op | |||||
79 | l = list(bunidiff(a, b, al, bl, "a/" + fn, "b/" + fn, opts=opts)) |
|
82 | l = list(bunidiff(a, b, al, bl, "a/" + fn, "b/" + fn, opts=opts)) | |
80 | if not l: return "" |
|
83 | if not l: return "" | |
81 | # difflib uses a space, rather than a tab |
|
84 | # difflib uses a space, rather than a tab | |
82 |
l[0] = "%s |
|
85 | l[0] = "%s%s" % (l[0][:-2], datetag(ad)) | |
83 |
l[1] = "%s |
|
86 | l[1] = "%s%s" % (l[1][:-2], datetag(bd)) | |
84 |
|
87 | |||
85 | for ln in xrange(len(l)): |
|
88 | for ln in xrange(len(l)): | |
86 | if l[ln][-1] != '\n': |
|
89 | if l[ln][-1] != '\n': |
General Comments 0
You need to be logged in to leave comments.
Login now