sapling/hggit/gitrepo.py

71 lines
1.9 KiB
Python
Raw Normal View History

import os
from mercurial import util
try:
from mercurial.error import RepoError
except ImportError:
from mercurial.repo import RepoError
try:
from mercurial.peer import peerrepository
except ImportError:
from mercurial.repo import repository as peerrepository
from overlay import overlayrepo
from mercurial.node import bin
class gitrepo(peerrepository):
2009-08-01 20:55:54 +04:00
capabilities = ['lookup']
2010-07-05 20:54:06 +04:00
def _capabilities(self):
return self.capabilities
def __init__(self, ui, path, create):
2009-07-07 20:46:14 +04:00
if create: # pragma: no cover
raise util.Abort('Cannot create a git repository.')
self.ui = ui
self.path = path
self.localrepo = None
2010-07-05 20:54:06 +04:00
def url(self):
return self.path
2009-08-01 20:55:54 +04:00
def lookup(self, key):
if isinstance(key, str):
return key
2010-07-05 20:54:06 +04:00
def local(self):
if not self.path:
raise RepoError
2010-07-05 20:54:06 +04:00
def heads(self):
return []
2010-07-05 20:54:06 +04:00
def listkeys(self, namespace):
if namespace == 'namespaces':
return {'bookmarks':''}
elif namespace == 'bookmarks':
if self.localrepo is not None:
handler = self.localrepo.githandler
handler.export_commits()
refs = handler.fetch_pack(self.path)
reqrefs = refs
convertlist, commits = handler.getnewgitcommits(reqrefs)
newcommits = [bin(c) for c in commits]
b = overlayrepo(handler, newcommits, refs)
stripped_refs = dict([
(ref[11:], b.node(refs[ref]))
for ref in refs.keys()
if ref.startswith('refs/heads/')])
return stripped_refs
2010-07-05 20:54:06 +04:00
return {}
def pushkey(self, namespace, key, old, new):
return False
instance = gitrepo
def islocal(path):
u = util.url(path)
return not u.scheme or u.scheme == 'file'