]> git.proxmox.com Git - mirror_frr.git/blame - git-reindent-branch.py
OSPFd: Update Segment Routing PR following review
[mirror_frr.git] / git-reindent-branch.py
CommitLineData
dceb5f8a
DL
1#!/usr/bin/env python
2# -*- coding: utf-8 -*-
3
4import sys, os
5import subprocess, argparse, tempfile
6import indent
7
8def run(cmd):
9 proc = subprocess.Popen(cmd, stdout = subprocess.PIPE)
10 rv = proc.communicate('')[0].decode('UTF-8')
11 proc.wait()
12 return rv
13
feda3ca3
DL
14clangfmt = run(['git', 'show', 'master:.clang-format'])
15
dceb5f8a
DL
16argp = argparse.ArgumentParser(description = 'git whitespace-fixing tool')
17argp.add_argument('branch', metavar='BRANCH', type = str, nargs = '?', default = 'HEAD')
18args = argp.parse_args()
19
20branch = args.branch
21commit = run(['git', 'rev-list', '-n', '1', branch, '--']).strip()
feda3ca3
DL
22
23# frr-3.1-dev = first commit that is on master but not on stable/3.0
24masterid = run(['git', 'rev-list', '-n', '1', 'frr-3.1-dev', '--']).strip()
25masterbase = run(['git', 'merge-base', commit, masterid]).strip()
26
27if masterbase == masterid:
28 refbranch = 'master'
29else:
30 refbranch = '3.0'
31
32sys.stderr.write('autodetected base: %s (can be 3.0 or master)\n' % refbranch)
33
34beforeid = run(['git', 'rev-list', '-n', '1', 'reindent-%s-before' % refbranch, '--']).strip()
35afterid = run(['git', 'rev-list', '-n', '1', 'reindent-%s-after' % refbranch, '--']).strip()
dceb5f8a
DL
36
37beforebase = run(['git', 'merge-base', commit, beforeid]).strip()
38afterbase = run(['git', 'merge-base', commit, afterid]).strip()
39
40if afterbase == afterid:
41 sys.stderr.write('this branch was already rebased\n')
42 sys.exit(1)
43
44if beforebase != beforeid:
feda3ca3 45 sys.stderr.write('you need to rebase your branch onto the tag "reindent-%s-before"\n' % refbranch)
dceb5f8a
DL
46 sys.exit(1)
47
feda3ca3 48revs = run(['git', 'rev-list', 'reindent-%s-before..%s' % (refbranch, commit)]).strip().split('\n')
92690ee6 49revs.reverse()
dceb5f8a
DL
50
51srcdir = os.getcwd()
52tmpdir = tempfile.mkdtemp('frrindent')
53os.chdir(tmpdir)
54
55sys.stderr.write('using temporary directory %s; %d revisions\n' % (tmpdir, len(revs)))
feda3ca3 56run(['git', 'clone', '-s', '-b', 'reindent-%s-after' % refbranch, srcdir, 'repo'])
dceb5f8a
DL
57os.chdir('repo')
58
feda3ca3
DL
59with open('.clang-format', 'w') as fd:
60 fd.write(clangfmt)
61
dceb5f8a
DL
62prev = beforeid
63for rev in revs:
64 filestat = run(['git', 'diff', '-z', '--name-status', prev, rev]).rstrip('\0').split('\0')
65 changes = zip(filestat[0::2], filestat[1::2])
66 sys.stderr.write('%s: %d files\n' % (rev, len(changes)))
67
68 for typ, name in changes:
69 if typ == 'D':
70 run(['git', 'rm', name])
71 elif typ in ['A', 'M']:
72 run(['git', 'checkout', rev, '--', name])
73 if name.endswith('.c') or name.endswith('.h'):
74 for d in ['babeld/', 'ldpd/', 'nhrpd/']:
75 if name.startswith(d):
76 break
77 else:
78 sys.stderr.write('\t%s\n' % name)
79 indent.wrap_file(name)
80 run(['git', 'add', name])
81
82 run(['git', 'commit', '-C', rev])
83 prev = rev
84
85run(['git', 'push', 'origin', 'HEAD:refs/heads/reindented-branch'])
86sys.stderr.write('\n\n"reindented-branch" should now be OK.\n')
87sys.stderr.write('you could use "git reset --hard reindented-branch" to set your current branch to the reindented output\n')
88sys.stderr.write('\033[31;1mplease always double-check the output\033[m\n')
89