/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
77
78
class LocalGitDir(GitDir):
79
    """An adapter to the '.git' dir used by git."""
80
0.200.139 by Jelmer Vernooij
Share more code between local and remote classes, support opening remote branches.
81
    _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.
82
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
83
    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.
84
        self._format = format
85
        self.root_transport = transport
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
86
        self._git = gitrepo
87
        if gitrepo.bare:
88
            self.transport = transport
89
        else:
90
            self.transport = transport.clone('.git')
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
91
        self._lockfiles = lockfiles
92
93
    def get_branch_transport(self, branch_format):
94
        if branch_format is None:
95
            return self.transport
0.200.138 by Jelmer Vernooij
Add initial infrastructure for accessing remote git repositories.
96
        if isinstance(branch_format, LocalGitBzrDirFormat):
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
97
            return self.transport
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
98
        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.
99
100
    get_repository_transport = get_branch_transport
101
    get_workingtree_transport = get_branch_transport
102
103
    def open_branch(self, ignored=None):
0.200.57 by Jelmer Vernooij
Fix more tests.
104
        """'create' a branch for this dir."""
105
        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.
106
        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.
107
108
    def open_repository(self, shared=False):
109
        """'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.
110
        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.
111
0.203.1 by Aaron Bentley
Make checkouts work
112
    def open_workingtree(self, recommend_upgrade=True):
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
113
        if self._git.bare:
114
            loc = urlutils.unescape_for_display(self.root_transport.base, 'ascii')
115
            raise errors.bzr_errors.NoWorkingTree(loc)
116
        else:
0.200.94 by Jelmer Vernooij
Eliminate (duplicate) git_ prefix.
117
            return workingtree.GitWorkingTree(self, self.open_repository(), 
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
118
                                                  self.open_branch())
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
119
0.200.109 by Jelmer Vernooij
Cope with new argument to cloning_metadir.
120
    def cloning_metadir(self, stacked=False):
121
        if stacked:
122
            return bzrlib.bzrdir.format_registry.make_bzrdir("pack-0.92")
123
        else:
124
            return bzrlib.bzrdir.format_registry.make_bzrdir("1.6")
0.203.1 by Aaron Bentley
Make checkouts work
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.138 by Jelmer Vernooij
Add initial infrastructure for accessing remote git repositories.
130
class LocalGitBzrDirFormat(bzrdir.BzrDirFormat):
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
131
    """The .git directory control format."""
132
0.200.148 by Jelmer Vernooij
Share more infrastructure between LocalGitDir and RemoteGitDir.
133
    _gitdir_class = LocalGitDir
0.200.108 by Jelmer Vernooij
Support bzr init --git.
134
    _lock_class = TransportLock
0.202.2 by David Allouche
GitRepository.get_inventory and .revision_tree work for the null revision. Support for testing GitRepository without disk data.
135
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
136
    @classmethod
137
    def _known_formats(self):
0.200.138 by Jelmer Vernooij
Add initial infrastructure for accessing remote git repositories.
138
        return set([LocalGitBzrDirFormat()])
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
139
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
140
    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.
141
        """Open this directory.
142
143
        """
0.200.123 by Jelmer Vernooij
Use central git module.
144
        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.
145
        # we dont grok readonly - git isn't integrated with transport.
146
        url = transport.base
147
        if url.startswith('readonly+'):
148
            url = url[len('readonly+'):]
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
149
150
        try:
0.200.119 by Jelmer Vernooij
Make API resemble that of python-git.
151
            gitrepo = git.repo.Repo(transport.local_abspath("."))
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
152
        except errors.bzr_errors.NotLocalUrl:
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
153
            raise errors.bzr_errors.NotBranchError(path=transport.base)
0.200.129 by Jelmer Vernooij
merge dulwich.
154
        lockfiles = GitLockableFiles(transport, GitLock())
0.200.90 by Jelmer Vernooij
Basic support for opening working trees.
155
        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.
156
157
    @classmethod
158
    def probe_transport(klass, transport):
159
        """Our format is present if the transport ends in '.not/'."""
160
        # little ugly, but works
161
        format = klass()
162
        # delegate to the main opening code. This pays a double rtt cost at the
163
        # moment, so perhaps we want probe_transport to return the opened thing
164
        # rather than an openener ? or we could return a curried thing with the
165
        # dir to open already instantiated ? Needs more thought.
166
        try:
167
            format.open(transport)
168
            return format
169
        except Exception, e:
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
170
            raise errors.bzr_errors.NotBranchError(path=transport.base)
171
        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.
172
0.200.69 by Jelmer Vernooij
Implement GitBzrDirFormat.get_format_description.
173
    def get_format_description(self):
174
        return "Local Git Repository"
175
0.200.108 by Jelmer Vernooij
Support bzr init --git.
176
    def get_format_string(self):
177
        return "Local Git Repository"
178
179
    def initialize_on_transport(self, transport):
180
        from bzrlib.transport.local import LocalTransport
0.200.123 by Jelmer Vernooij
Use central git module.
181
        from bzrlib.plugins.git import git
0.200.108 by Jelmer Vernooij
Support bzr init --git.
182
183
        if not isinstance(transport, LocalTransport):
184
            raise NotImplementedError(self.initialize, 
185
                "Can't create Git Repositories/branches on "
186
                "non-local transports")
187
188
        git.repo.Repo.create(transport.local_abspath(".")) 
189
        return self.open(transport)
190
0.200.133 by Jelmer Vernooij
Unmark as deprecated.
191
    def is_supported(self):
192
        return True
0.200.139 by Jelmer Vernooij
Share more code between local and remote classes, support opening remote branches.
193
194
195
class RemoteGitBzrDirFormat(bzrdir.BzrDirFormat):
196
    """The .git directory control format."""
197
198
    _lock_class = TransportLock
199
200
    @classmethod
201
    def _known_formats(self):
202
        return set([RemoteGitBzrDirFormat()])
203
204
    def open(self, transport, _found=None):
205
        """Open this directory.
206
207
        """
208
        from bzrlib.plugins.git.remote import RemoteGitDir, GitSmartTransport
209
        if not isinstance(transport, GitSmartTransport):
210
            raise errors.bzr_errors.NotBranchError(transport.base)
211
        # we dont grok readonly - git isn't integrated with transport.
212
        url = transport.base
213
        if url.startswith('readonly+'):
214
            url = url[len('readonly+'):]
215
216
        lockfiles = GitLockableFiles(transport, GitLock())
217
        return RemoteGitDir(transport, lockfiles, self)
218
219
    @classmethod
220
    def probe_transport(klass, transport):
221
        """Our format is present if the transport ends in '.not/'."""
222
        # little ugly, but works
223
        format = klass()
224
        from bzrlib.plugins.git.remote import GitSmartTransport
225
        if not isinstance(transport, GitSmartTransport):
226
            raise errors.bzr_errors.NotBranchError(transport.base)
227
        # The only way to know a path exists and contains a valid repository 
228
        # is to do a request against it:
229
        try:
230
            transport.fetch_pack(lambda x: [], None, lambda x: None, 
231
                                 lambda x: mutter("git: %s" % x))
232
        except GitProtocolException, e:
233
            raise errors.bzr_errors.NotBranchError(path=transport.base)
234
        else:
235
            return format
236
        raise errors.bzr_errors.NotBranchError(path=transport.base)
237
238
    def get_format_description(self):
239
        return "Remote Git Repository"
240
241
    def get_format_string(self):
242
        return "Remote Git Repository"
243
244
    def initialize_on_transport(self, transport):
245
        raise errors.bzr_errors.UninitializableFormat(self)
246
247
    def is_supported(self):
248
        return True