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
|
#!/usr/bin/env python
# encoding: utf-8
#
# Generates reviewboard compatible diffs from git-svn repositories.
#
# Licence: GPL v3
# Author: Aurélien Gâteau <agateau@kde.org>
#
# Based on a shell script by Riccardo Iaconelli <riccardo@kde.org>
import sys
from subprocess import *
USAGE="""
Prints a reviewboard-compatible diff from a git-svn repository on stdout.
Usage: reviewboarddiff <git-diff-args>
Examples:
reviewboarddiff HEAD : generates diff for uncommitted changes
reviewboarddiff HEAD^ : generates diff for latest commit
reviewboarddiff HEAD~3: generates diff for 3 latest commits
"""
def run(*args):
process = Popen(args, stdout=PIPE)
out, err = process.communicate()
if process.returncode != 0:
print >>sys.stderr, "Command '%s' failed:" % " ".join(args)
print >>sys.stderr, err
sys.exit(1)
return out.rstrip()
def add_suffix(line, suffix):
return line.rstrip() + suffix + "\n"
def generate_diff(diff_args):
wc_suffix = " (working copy)"
new_suffix = " (revision 0)"
rev_list = run("git", "rev-list", "--date-order", "--max-count=1", "git-svn")
rev = run("git", "svn", "find-rev", rev_list)
rev_suffix = " (revision %s)" % rev
out = Popen(["git", "diff", "--no-prefix"] + diff_args, stdout=PIPE).stdout
while True:
line = out.readline()
if not line:
break
"""
git outputs new files as
--- /dev/null
+++ /new/file
while svn prefers:
--- /new/file (revision 0)
+++ /new/file (working copy)
We skip the "--- /dev/null" line, read the next line (+++ /new/file)
and recreate "--- /new/file" from it
"""
if line.startswith("--- /dev/null"):
line = out.readline()
null_line = add_suffix(line.replace("+++", "---"), new_suffix)
sys.stdout.write(null_line)
# Add suffixes
if line.startswith("---"):
line = add_suffix(line, rev_suffix)
elif line.startswith("+++"):
line = add_suffix(line, wc_suffix)
sys.stdout.write(line)
return 0
def main(argv):
if len(argv) == 1:
print USAGE
return -1
return generate_diff(argv[1:])
if __name__=="__main__":
sys.exit(main(sys.argv))
# vi: ts=4 sw=4 et
|