2010-03-29 18:48:28 +02:00
|
|
|
import os
|
|
|
|
import subprocess
|
|
|
|
|
2011-07-16 15:03:37 +02:00
|
|
|
from git_remote_helpers.util import check_call, check_output
|
2011-07-16 15:03:31 +02:00
|
|
|
|
2010-03-29 18:48:28 +02:00
|
|
|
|
|
|
|
class GitImporter(object):
|
|
|
|
"""An importer for testgit repositories.
|
|
|
|
|
|
|
|
This importer simply delegates to git fast-import.
|
|
|
|
"""
|
|
|
|
|
|
|
|
def __init__(self, repo):
|
|
|
|
"""Creates a new importer for the specified repo.
|
|
|
|
"""
|
|
|
|
|
|
|
|
self.repo = repo
|
|
|
|
|
2011-07-16 15:03:37 +02:00
|
|
|
def get_refs(self, gitdir):
|
|
|
|
"""Returns a dictionary with refs.
|
|
|
|
"""
|
|
|
|
args = ["git", "--git-dir=" + gitdir, "for-each-ref", "refs/heads"]
|
|
|
|
lines = check_output(args).strip().split('\n')
|
|
|
|
refs = {}
|
|
|
|
for line in lines:
|
|
|
|
value, name = line.split(' ')
|
|
|
|
name = name.strip('commit\t')
|
|
|
|
refs[name] = value
|
|
|
|
return refs
|
|
|
|
|
2010-03-29 18:48:28 +02:00
|
|
|
def do_import(self, base):
|
|
|
|
"""Imports a fast-import stream to the given directory.
|
|
|
|
|
|
|
|
Simply delegates to git fast-import.
|
|
|
|
"""
|
|
|
|
|
|
|
|
dirname = self.repo.get_base_path(base)
|
|
|
|
if self.repo.local:
|
|
|
|
gitdir = self.repo.gitpath
|
|
|
|
else:
|
|
|
|
gitdir = os.path.abspath(os.path.join(dirname, '.git'))
|
|
|
|
path = os.path.abspath(os.path.join(dirname, 'git.marks'))
|
|
|
|
|
|
|
|
if not os.path.exists(dirname):
|
|
|
|
os.makedirs(dirname)
|
|
|
|
|
2011-07-16 15:03:37 +02:00
|
|
|
refs_before = self.get_refs(gitdir)
|
|
|
|
|
2010-03-29 18:48:28 +02:00
|
|
|
args = ["git", "--git-dir=" + gitdir, "fast-import", "--quiet", "--export-marks=" + path]
|
|
|
|
|
|
|
|
if os.path.exists(path):
|
|
|
|
args.append("--import-marks=" + path)
|
|
|
|
|
2011-07-16 15:03:31 +02:00
|
|
|
check_call(args)
|
2011-07-16 15:03:37 +02:00
|
|
|
|
|
|
|
refs_after = self.get_refs(gitdir)
|
|
|
|
|
|
|
|
changed = {}
|
|
|
|
|
|
|
|
for name, value in refs_after.iteritems():
|
|
|
|
if refs_before.get(name) == value:
|
|
|
|
continue
|
|
|
|
|
|
|
|
changed[name] = value
|
|
|
|
|
|
|
|
return changed
|