diff options
author | Jannis Pohlmann <jannis.pohlmann@codethink.co.uk> | 2012-04-18 17:14:11 +0100 |
---|---|---|
committer | Jannis Pohlmann <jannis.pohlmann@codethink.co.uk> | 2012-04-18 17:14:11 +0100 |
commit | 6b762c363224860833ea20c9ba8109c0c210d419 (patch) | |
tree | a41776ac5c08759edee98d56e967a983ac8b67a9 /morphcacheserver | |
parent | 8f3b7be2e1130a94cf4de5e9e1b5a18d382efff8 (diff) | |
download | morph-6b762c363224860833ea20c9ba8109c0c210d419.tar.gz |
Add untested support for bundles.
Diffstat (limited to 'morphcacheserver')
-rw-r--r-- | morphcacheserver/repocache.py | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/morphcacheserver/repocache.py b/morphcacheserver/repocache.py index 1b6862cb..e6ab6401 100644 --- a/morphcacheserver/repocache.py +++ b/morphcacheserver/repocache.py @@ -44,13 +44,14 @@ class UnresolvedNamedReferenceError(cliapp.AppException): class RepoCache(object): - def __init__(self, app, dirname): + def __init__(self, app, repo_cache_dir, bundle_cache_dir): self.app = app - self.dirname = dirname + self.repo_cache_dir = repo_cache_dir + self.bundle_cache_dir = bundle_cache_dir def resolve_ref(self, repo_url, ref): quoted_url = self._quote_url(repo_url) - repo_dir = os.path.join(self.dirname, quoted_url) + repo_dir = os.path.join(self.repo_cache_dir, quoted_url) if not os.path.exists(repo_dir): raise RepositoryNotFoundError(repo_url) try: @@ -68,7 +69,7 @@ class RepoCache(object): def cat_file(self, repo_url, ref, filename): quoted_url = self._quote_url(repo_url) - repo_dir = os.path.join(self.dirname, quoted_url) + repo_dir = os.path.join(self.repo_cache_dir, quoted_url) if not self._is_valid_sha1(ref): raise UnresolvedNamedReferenceError(repo_url, ref) if not os.path.exists(repo_dir): @@ -79,6 +80,10 @@ class RepoCache(object): raise InvalidReferenceError(repo_url, ref) return self._cat_file(repo_dir, sha1, filename) + + def get_bundle_filename(self, repo_url): + quoted_url = self._quote_url(repo_url) + return os.path.join(self.bundle_dir, '%s.bndl' % quoted_url) def _quote_url(self, url): valid_chars = string.digits + string.letters + '%_' |