source: trunk/scripts/git-migration/git-migrate @ 1891

Last change on this file since 1891 was 1891, checked in by broder, 16 years ago

Apparently git ls-files shows the status of the index, which doesn't
change after git reset --soft

  • Property svn:executable set to *
File size: 2.2 KB
RevLine 
[1866]1#!/usr/bin/python
2
[1874]3import os
[1866]4import sys
5import subprocess
[1869]6import shutil
[1866]7
8def clonePackage(base, pkg):
[1874]9    if not os.path.isdir('%s.git' % pkg):
10        if os.path.isdir(pkg):
11            shutil.rmtree(pkg)
12        # Use --no-follow-parent because we're going to handle that with
13        # grafts.
[1875]14        subprocess.check_call(['git', 'svn', 'clone',
15                               '--no-follow-parent',
[1874]16                               '-Aauthors',
17                               '-q',
[1875]18                               '--no-metadata',
19                               '%s/packages/%s' % (base, pkg)],
[1874]20                              stdout=subprocess.PIPE)
21       
22        # Then make the repository bare, because git-svn can't do this
23        shutil.move('%s/.git' % pkg, '%s.git' % pkg)
[1875]24        shutil.rmtree(pkg)
25        subprocess.check_call(['git', 'config', 'core.bare', 'true'],
26                              cwd='%s.git' % pkg)
[1876]27       
28    # Some of these repos have a rev where everything was deleted
29    # as a result of the move. We don't want that rev to exist.
[1891]30    p = subprocess.Popen(['git', 'ls-tree', 'HEAD'],
[1876]31                         cwd='%s.git' % pkg,
32                         stdout=subprocess.PIPE)
33    p.wait()
34    if len(p.stdout.read()) == 0:
[1888]35        subprocess.check_call(['git', 'reset', '--soft', 'HEAD^'],
[1876]36                              cwd='%s.git' % pkg)
[1866]37
38def cloneAllPackages(base):
39    for pkg in open('package-list'):
40        clonePackage(base, pkg.strip())
41
[1880]42def mergeHistory(old_pkg, new_pkg, n):
[1881]43    cwd = os.getcwd()
44    subprocess.check_call(['git', 'push',
45                           'file:///%s/%s.git' % (cwd, new_pkg),
46                           'master:refs/heads/%s' % old_pkg],
[1890]47                          cwd='%s.git' % old_pkg)
[1880]48
49def mergeHistories():
[1884]50    merges = []
51    for line in open('merges'):
[1880]52        line = line.strip()
[1889]53        if line == '' or line[0] == '#':
[1880]54            continue
55       
[1884]56        merges.append(line.split())
[1883]57   
[1884]58    for merge in merges:
59        mergeHistory(*merge)
[1880]60
[1866]61if __name__ == '__main__':
62    try:
63        base = sys.argv[1]
64    except:
65        base = 'svn://invirt.mit.edu/trunk'
66   
67    cloneAllPackages(base)
[1880]68    mergeHistories()
Note: See TracBrowser for help on using the repository browser.