Simplify out the need to know the CWD.
[invirt/scripts/git-migration.git] / git-migrate
index 796f937..458d903 100755 (executable)
@@ -27,12 +27,12 @@ def clonePackage(base, pkg):
         
     # Some of these repos have a rev where everything was deleted
     # as a result of the move. We don't want that rev to exist.
-    p = subprocess.Popen(['git', 'ls-files'],
+    p = subprocess.Popen(['git', 'ls-tree', 'HEAD'],
                          cwd='%s.git' % pkg,
                          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):
@@ -40,67 +40,22 @@ def cloneAllPackages(base):
         clonePackage(base, pkg.strip())
 
 def mergeHistory(old_pkg, new_pkg, n):
-    cwd = os.getcwd()
     subprocess.check_call(['git', 'push',
-                           'file:///%s/%s.git' % (cwd, new_pkg),
+                           '../%s.git' % new_pkg,
                            'master:refs/heads/%s' % old_pkg],
-                          cwd='%s.git' % new_pkg)
-    
-    graft = []
-    p = subprocess.Popen(['git', 'rev-list',
-                          '--reverse',
-                          '--skip=%s' % n,
-                          'master'],
-                         cwd='%s.git' % new_pkg,
-                         stdout=subprocess.PIPE)
-    p.wait()
-    new_rev = p.stdout.read().split()[0]
-    graft.append(new_rev)
-    
-    # If n isn't 0, then n has a parent commit already that we
-    # shouldn't forget about.
-    if n != 0:
-        p = subprocess.Popen(['git', 'rev-parse',
-                              '%s^' % new_rev],
-                             cwd='%s.git' % new_pkg,
-                             stdout=subprocess.PIPE)
-        p.wait()
-        graft.append(p.stdout.read().strip())
-    
-    # And regardless, the HEAD of old_pkg should be a parent of
-    # new_pkg
-    p = subprocess.Popen(['git', 'rev-parse',
-                          'master'],
-                         cwd='%s.git' % old_pkg,
-                         stdout=subprocess.PIPE)
-    p.wait()
-    graft.append(p.stdout.read().strip())
-    
-    f = open('%s.git/info/grafts' % new_pkg, 'a')
-    
-    print >>f, ' '.join(graft)
+                          cwd='%s.git' % old_pkg)
 
 def mergeHistories():
     merges = []
     for line in open('merges'):
         line = line.strip()
-        if line[0] == '#' or line == '':
+        if line == '' or line[0] == '#':
             continue
         
         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: