/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 Branch and a Bazaar Branch"""
18
19
from bzrlib import (
20
    branch,
21
    config,
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
22
    revision,
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
23
    )
24
from bzrlib.decorators import needs_read_lock
25
0.200.20 by John Arbash Meinel
All tests are passing again
26
from bzrlib.plugins.git.gitlib import ids
27
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
28
29
class GitBranchConfig(config.BranchConfig):
30
    """BranchConfig that uses locations.conf in place of branch.conf"""
31
32
    def __init__(self, branch):
33
        config.BranchConfig.__init__(self, branch)
34
        # do not provide a BranchDataConfig
35
        self.option_sources = self.option_sources[0], self.option_sources[2]
36
37
    def set_user_option(self, name, value, local=False):
38
        """Force local to True"""
39
        config.BranchConfig.set_user_option(self, name, value, local=True)
40
41
42
class GitBranchFormat(branch.BranchFormat):
43
44
    def get_branch_description(self):
45
        return 'Git Branch'
46
47
48
class GitBranch(branch.Branch):
49
    """An adapter to git repositories for bzr Branch objects."""
50
51
    def __init__(self, gitdir, lockfiles):
52
        from bzrlib.plugins.git.gitlib import git_repository
53
        self.bzrdir = gitdir
54
        self.control_files = lockfiles
55
        self.repository = git_repository.GitRepository(gitdir, lockfiles)
56
        self.base = gitdir.root_transport.base
57
        if '.git' not in gitdir.root_transport.list_dir('.'):
58
            raise errors.NotBranchError(self.base)
59
        self._format = GitBranchFormat()
60
61
    def lock_write(self):
62
        self.control_files.lock_write()
63
64
    @needs_read_lock
65
    def last_revision(self):
66
        # perhaps should escape this ?
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
67
        head_git_id = self.repository._git.get_head()
68
        if head_git_id is None:
69
            return revision.NULL_REVISION
70
        return ids.convert_revision_id_git_to_bzr(head_git_id)
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
71
72
    @needs_read_lock
73
    def revision_history(self):
74
        node = self.last_revision()
0.200.20 by John Arbash Meinel
All tests are passing again
75
        if node == revision.NULL_REVISION:
76
            return []
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
77
        ancestors = self.repository.get_revision_graph(node)
78
        history = []
79
        while node is not None:
80
            history.append(node)
81
            if len(ancestors[node]) > 0:
82
                node = ancestors[node][0]
83
            else:
84
                node = None
85
        return list(reversed(history))
86
87
    def get_config(self):
88
        return GitBranchConfig(self)
89
90
    def lock_read(self):
91
        self.control_files.lock_read()
92
93
    def unlock(self):
94
        self.control_files.unlock()
95
96
    def get_push_location(self):
97
        """See Branch.get_push_location."""
98
        push_loc = self.get_config().get_user_option('push_location')
99
        return push_loc
100
101
    def set_push_location(self, location):
102
        """See Branch.set_push_location."""
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
103
        self.get_config().set_user_option('push_location', location,
0.200.18 by John Arbash Meinel
Start splitting up the Git{Branch,Dir,Repository} into separate modules, etc.
104
                                          local=True)
105
106