diff options
author | Junio C Hamano <gitster@pobox.com> | 2010-05-21 04:02:15 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2010-05-21 04:02:15 -0700 |
commit | af655431f53c20e3d0ed236544397c69974267f4 (patch) | |
tree | ddfc95bd3f768e98709cc2d7a445e64117d4c784 /git_remote_helpers/git/importer.py | |
parent | 78f17935a306dfd7a1f32c923e0b05a094bf0c25 (diff) | |
parent | 63a2f6139c33b7231baad8e3bfcc218ef6b63418 (diff) | |
download | git-af655431f53c20e3d0ed236544397c69974267f4.tar.gz git-af655431f53c20e3d0ed236544397c69974267f4.tar.xz |
Merge branch 'sr/remote-helper-export'
* sr/remote-helper-export:
t5800: testgit helper requires Python support
Makefile: Simplify handling of python scripts
remote-helpers: add tests for testgit helper
remote-helpers: add testgit helper
remote-helpers: add support for an export command
remote-helpers: allow requesing the path to the .git directory
fast-import: always create marks_file directories
clone: also configure url for bare clones
clone: pass the remote name to remote_get
Conflicts:
Makefile
Diffstat (limited to 'git_remote_helpers/git/importer.py')
-rw-r--r-- | git_remote_helpers/git/importer.py | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/git_remote_helpers/git/importer.py b/git_remote_helpers/git/importer.py new file mode 100644 index 000000000..af2919d92 --- /dev/null +++ b/git_remote_helpers/git/importer.py @@ -0,0 +1,38 @@ +import os +import subprocess + + +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 + + 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) + + args = ["git", "--git-dir=" + gitdir, "fast-import", "--quiet", "--export-marks=" + path] + + if os.path.exists(path): + args.append("--import-marks=" + path) + + subprocess.check_call(args) |