/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
1
# Copyright (C) 2007 Canonical Ltd
2
#
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
7
#
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
12
#
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
17
"""An adapter between a Git control dir and a Bazaar BzrDir"""
18
0.200.123 by Jelmer Vernooij
Use central git module.
19
import os
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
20
0.200.109 by Jelmer Vernooij
Cope with new argument to cloning_metadir.
21
import bzrlib
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
22
from bzrlib.lazy_import import lazy_import
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
23
from bzrlib import (
24
    bzrdir,
25
    lockable_files,
26
    urlutils,
27
    )
28
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
29
lazy_import(globals(), """
0.200.108 by Jelmer Vernooij
Support bzr init --git.
30
from bzrlib.lockable_files import TransportLock
0.200.27 by David Allouche
Flat is better than nested, remove the gitlib hierarchy.
31
from bzrlib.plugins.git import (
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
32
    errors,
0.200.94 by Jelmer Vernooij
Eliminate (duplicate) git_ prefix.
33
    branch,
34
    repository,
35
    workingtree,
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
36
    )
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
37
""")
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
38
39
0.200.123 by Jelmer Vernooij
Use central git module.
40
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
41
class GitLock(object):
42
    """A lock that thunks through to Git."""
43
0.200.84 by Jelmer Vernooij
Fix lock_write argument.
44
    def lock_write(self, token=None):
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
45
        pass
46
47
    def lock_read(self):
48
        pass
49
50
    def unlock(self):
51
        pass
52
0.200.73 by Jelmer Vernooij
Implement GitLock.peek().
53
    def peek(self):
54
        pass
55
0.200.130 by Jelmer Vernooij
Make most tree inspection tests succeed.
56
    def validate_token(self, token):
57
        pass
58
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
59
60
class GitLockableFiles(lockable_files.LockableFiles):
61
    """Git specific lockable files abstraction."""
62
0.200.129 by Jelmer Vernooij
merge dulwich.
63
    def __init__(self, transport, lock):
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
64
        self._lock = lock
65
        self._transaction = None
66
        self._lock_mode = None
67
        self._lock_count = 0
0.200.129 by Jelmer Vernooij
merge dulwich.
68
        self._transport = transport
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
69
70
71
class GitDir(bzrdir.BzrDir):
72
    """An adapter to the '.git' dir used by git."""
73
0.200.148 by Jelmer Vernooij
Share more infrastructure between LocalGitDir and RemoteGitDir.
74
    def is_supported(self):
75
        return True
76
0.200.155 by Jelmer Vernooij
Fix formatting, remove catch-all for exceptions when opening local repositories.
77
    def cloning_metadir(self, stacked=False):
78
        if stacked:
79
            return bzrlib.bzrdir.format_registry.make_bzrdir("pack-0.92")
80
        else:
81
            return bzrlib.bzrdir.format_registry.make_bzrdir("1.6")
82
0.200.148 by Jelmer Vernooij
Share more infrastructure between LocalGitDir and RemoteGitDir.
83
84
class LocalGitDir(GitDir):
85
    """An adapter to the '.git' dir used by git."""
86
0.200.139 by Jelmer Vernooij
Share more code between local and remote classes, support opening remote branches.
87
    _gitrepository_class = repository.LocalGitRepository
0.202.2 by David Allouche
GitRepository.get_inventory and .revision_tree work for the null revision. Support for testing GitRepository without disk data.
88
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
89
    def __init__(self, transport, lockfiles, gitrepo, format):
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
90
        self._format = format
91
        self.root_transport = transport
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
92
        self._git = gitrepo
93
        if gitrepo.bare:
94
            self.transport = transport
95
        else:
96
            self.transport = transport.clone('.git')
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
97
        self._lockfiles = lockfiles
98
99
    def get_branch_transport(self, branch_format):
100
        if branch_format is None:
101
            return self.transport
0.200.138 by Jelmer Vernooij
Add initial infrastructure for accessing remote git repositories.
102
        if isinstance(branch_format, LocalGitBzrDirFormat):
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
103
            return self.transport
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
104
        raise errors.bzr_errors.IncompatibleFormat(branch_format, self._format)
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
105
106
    get_repository_transport = get_branch_transport
107
    get_workingtree_transport = get_branch_transport
108
109
    def open_branch(self, ignored=None):
0.200.57 by Jelmer Vernooij
Fix more tests.
110
        """'create' a branch for this dir."""
111
        repo = self.open_repository()
0.200.147 by Jelmer Vernooij
Merge new dulwich; fetching objects from local repository works now; they aren't converted yet though.
112
        return branch.LocalGitBranch(self, repo, "HEAD", repo._git.head(), self._lockfiles)
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
113
114
    def open_repository(self, shared=False):
115
        """'open' a repository for this dir."""
0.202.2 by David Allouche
GitRepository.get_inventory and .revision_tree work for the null revision. Support for testing GitRepository without disk data.
116
        return self._gitrepository_class(self, self._lockfiles)
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
117
0.203.1 by Aaron Bentley
Make checkouts work
118
    def open_workingtree(self, recommend_upgrade=True):
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
119
        if self._git.bare:
120
            loc = urlutils.unescape_for_display(self.root_transport.base, 'ascii')
121
            raise errors.bzr_errors.NoWorkingTree(loc)
122
        else:
0.200.94 by Jelmer Vernooij
Eliminate (duplicate) git_ prefix.
123
            return workingtree.GitWorkingTree(self, self.open_repository(), 
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
124
                                                  self.open_branch())
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
125
0.200.108 by Jelmer Vernooij
Support bzr init --git.
126
    def create_repository(self, shared=False):
127
        return self.open_repository()
128
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
129
0.200.155 by Jelmer Vernooij
Fix formatting, remove catch-all for exceptions when opening local repositories.
130
class GitBzrDirFormat(bzrdir.BzrDirFormat):
131
    _lock_class = TransportLock
132
133
    def is_supported(self):
134
        return True
135
136
137
class LocalGitBzrDirFormat(GitBzrDirFormat):
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
138
    """The .git directory control format."""
139
0.200.148 by Jelmer Vernooij
Share more infrastructure between LocalGitDir and RemoteGitDir.
140
    _gitdir_class = LocalGitDir
0.202.2 by David Allouche
GitRepository.get_inventory and .revision_tree work for the null revision. Support for testing GitRepository without disk data.
141
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
142
    @classmethod
143
    def _known_formats(self):
0.200.138 by Jelmer Vernooij
Add initial infrastructure for accessing remote git repositories.
144
        return set([LocalGitBzrDirFormat()])
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
145
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
146
    def open(self, transport, _found=None):
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
147
        """Open this directory.
148
149
        """
0.200.123 by Jelmer Vernooij
Use central git module.
150
        from bzrlib.plugins.git import git
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
151
        # we dont grok readonly - git isn't integrated with transport.
152
        url = transport.base
153
        if url.startswith('readonly+'):
154
            url = url[len('readonly+'):]
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
155
156
        try:
0.200.119 by Jelmer Vernooij
Make API resemble that of python-git.
157
            gitrepo = git.repo.Repo(transport.local_abspath("."))
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
158
        except errors.bzr_errors.NotLocalUrl:
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
159
            raise errors.bzr_errors.NotBranchError(path=transport.base)
0.200.129 by Jelmer Vernooij
merge dulwich.
160
        lockfiles = GitLockableFiles(transport, GitLock())
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
161
        return self._gitdir_class(transport, lockfiles, gitrepo, self)
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
162
163
    @classmethod
164
    def probe_transport(klass, transport):
165
        """Our format is present if the transport ends in '.not/'."""
0.200.155 by Jelmer Vernooij
Fix formatting, remove catch-all for exceptions when opening local repositories.
166
        from bzrlib.plugins.git import git
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
167
        # little ugly, but works
168
        format = klass()
169
        # delegate to the main opening code. This pays a double rtt cost at the
170
        # moment, so perhaps we want probe_transport to return the opened thing
171
        # rather than an openener ? or we could return a curried thing with the
172
        # dir to open already instantiated ? Needs more thought.
173
        try:
174
            format.open(transport)
175
            return format
0.200.155 by Jelmer Vernooij
Fix formatting, remove catch-all for exceptions when opening local repositories.
176
        except git.errors.NotGitRepository, e:
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
177
            raise errors.bzr_errors.NotBranchError(path=transport.base)
178
        raise errors.bzr_errors.NotBranchError(path=transport.base)
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
179
0.200.69 by Jelmer Vernooij
Implement GitBzrDirFormat.get_format_description.
180
    def get_format_description(self):
181
        return "Local Git Repository"
182
0.200.108 by Jelmer Vernooij
Support bzr init --git.
183
    def get_format_string(self):
184
        return "Local Git Repository"
185
186
    def initialize_on_transport(self, transport):
187
        from bzrlib.transport.local import LocalTransport
0.200.123 by Jelmer Vernooij
Use central git module.
188
        from bzrlib.plugins.git import git
0.200.108 by Jelmer Vernooij
Support bzr init --git.
189
190
        if not isinstance(transport, LocalTransport):
191
            raise NotImplementedError(self.initialize, 
192
                "Can't create Git Repositories/branches on "
193
                "non-local transports")
194
195
        git.repo.Repo.create(transport.local_abspath(".")) 
196
        return self.open(transport)
197
0.200.133 by Jelmer Vernooij
Unmark as deprecated.
198
    def is_supported(self):
199
        return True
0.200.139 by Jelmer Vernooij
Share more code between local and remote classes, support opening remote branches.
200
201
0.200.155 by Jelmer Vernooij
Fix formatting, remove catch-all for exceptions when opening local repositories.
202
class RemoteGitBzrDirFormat(GitBzrDirFormat):
0.200.139 by Jelmer Vernooij
Share more code between local and remote classes, support opening remote branches.
203
    """The .git directory control format."""
204
205
    @classmethod
206
    def _known_formats(self):
207
        return set([RemoteGitBzrDirFormat()])
208
209
    def open(self, transport, _found=None):
210
        """Open this directory.
211
212
        """
213
        from bzrlib.plugins.git.remote import RemoteGitDir, GitSmartTransport
214
        if not isinstance(transport, GitSmartTransport):
215
            raise errors.bzr_errors.NotBranchError(transport.base)
216
        # we dont grok readonly - git isn't integrated with transport.
217
        url = transport.base
218
        if url.startswith('readonly+'):
219
            url = url[len('readonly+'):]
220
221
        lockfiles = GitLockableFiles(transport, GitLock())
222
        return RemoteGitDir(transport, lockfiles, self)
223
224
    @classmethod
225
    def probe_transport(klass, transport):
226
        """Our format is present if the transport ends in '.not/'."""
227
        # little ugly, but works
228
        format = klass()
229
        from bzrlib.plugins.git.remote import GitSmartTransport
230
        if not isinstance(transport, GitSmartTransport):
231
            raise errors.bzr_errors.NotBranchError(transport.base)
232
        # The only way to know a path exists and contains a valid repository 
233
        # is to do a request against it:
234
        try:
235
            transport.fetch_pack(lambda x: [], None, lambda x: None, 
236
                                 lambda x: mutter("git: %s" % x))
237
        except GitProtocolException, e:
238
            raise errors.bzr_errors.NotBranchError(path=transport.base)
239
        else:
240
            return format
241
        raise errors.bzr_errors.NotBranchError(path=transport.base)
242
243
    def get_format_description(self):
244
        return "Remote Git Repository"
245
246
    def get_format_string(self):
247
        return "Remote Git Repository"
248
249
    def initialize_on_transport(self, transport):
250
        raise errors.bzr_errors.UninitializableFormat(self)
251