File: diff.py

package info (click to toggle)
galileo 0.5.1-4
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 392 kB
  • ctags: 578
  • sloc: python: 3,462; xml: 23; makefile: 14
file content (106 lines) | stat: -rwxr-xr-x 2,721 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#!/usr/bin/env python

import os

from analysedump import readdump


def s2a(s):
    return [ord(c) for c in s]


def LCS(X, Y):
    m = len(X)
    n = len(Y)
    C = [[0] * (n + 1) for i in range(m + 1)]
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if X[i - 1] == Y[j - 1]:
                C[i][j] = C[i - 1][j - 1] + 1
            else:
                C[i][j] = max(C[i][j - 1], C[i - 1][j])
    return C

SYMBOLS = {0: ' ',
           -1: '-',
           1: '+'}


def _diff(C, X, Y, i, j):
    while (i, j) != (0, 0):
        if i > 0 and j > 0 and X[i - 1] == Y[j - 1]:
            yield (0, X[i - 1])
            i -= 1
            j -= 1
        elif j > 0 and ((i == 0) or (C[i][j - 1] >= C[i - 1][j])):
            yield (1, Y[j - 1])
            j -= 1
        elif i > 0 and ((j == 0) or C[i][j - 1] < C[i - 1][j]):
            yield (-1, X[i - 1])
            i -= 1
        else:
            assert False, ' '.join(str(c) for c in [i, j, C[i][j - 1], C[i - 1][j]])


def diff(X, Y, maxL=20):

    start = 0
    oldmode = 0
    s = []
    while start < len(X) and start < len(Y) and X[start] == Y[start]:
        if len(s) == maxL:
            print SYMBOLS[oldmode], ' '.join('%02X' % i for i in s)
            s = []
        s.append(X[start])
        start += 1
    print SYMBOLS[oldmode], ' '.join('%02X' % i for i in s)
    s = []
    X = X[start:]
    Y = Y[start:]

    C = LCS(X, Y)
    for chunk in reversed(list(_diff(C, X, Y, len(X), len(Y)))):
        if s and ((len(s) == maxL) or chunk[0] != oldmode):
            print SYMBOLS[oldmode], ' '.join('%02X' % i for i in s)
            s = []
        s.append(chunk[1])
        oldmode = chunk[0]
    # Print the last one
    print SYMBOLS[oldmode], ' '.join('%02X' % i for i in s)
    return oldmode * len(s)


def dumpdiff(dump1, dump2):
    with open(dump1) as f:
        data1, resp1 = readdump(f)

    with open(dump2) as f:
        data2, resp2 = readdump(f)

    diff(data1, data2)
    print '-' * 20
    diff(resp1, resp2)


def diffdir(basedir):

    for root, dirs, files in os.walk(basedir):
        files = sorted(files)
        for i in range(0, len(files) - 1):
            print files[i]
            print files[i + 1]
            try:
                dumpdiff(os.path.join(root, files[i]), os.path.join(root, files[i + 1]))
            except RuntimeError:
                print 'Trouble with %s and %s' % (files[i], files[i + 1])
            print '------------------------------------'


if __name__ == "__main__":
    import sys
    if len(sys.argv) == 2:
        # one param
        diffdir(sys.argv[1])
    elif len(sys.argv) == 3:
        # Two params
        dumpdiff(sys.argv[1], sys.argv[2])