stdout=subprocess.PIPE)
p.wait()
if len(p.stdout.read()) == 0:
- subprocess.check_call(['git', 'reset', 'HEAD^'],
+ subprocess.check_call(['git', 'reset', '--soft', 'HEAD^'],
cwd='%s.git' % pkg)
def cloneAllPackages(base):
print >>f, ' '.join(graft)
def mergeHistories():
- for line in open('grafts'):
+ merges = []
+ for line in open('merges'):
line = line.strip()
if line[0] == '#' or line == '':
continue
- old_pkg, new_pkg, n = line.split()
- mergeHistory(old_pkg, new_pkg, int(n))
+ merges.append(line.split())
+
+ for merge in merges:
+ mergeHistory(*merge)
+
+ for line in open('package-list'):
+ line = line.strip()
+ subprocess.check_call(['git', 'filter-branch',
+ '--',
+ '--all'],
+ cwd='%s.git' % line)
+
+ for merge in merges:
+ shutil.rmtree('%s.git' % merge[0])
if __name__ == '__main__':
try: