17
17
"""Weave-era branch implementations."""
19
from __future__ import absolute_import
21
19
from bzrlib import (
26
from bzrlib.decorators import (
31
from bzrlib.lock import LogicalLockResult
32
24
from bzrlib.trace import mutter
34
26
from bzrlib.branch import (
36
BranchWriteLockResult,
38
from bzrlib.branchfmt.fullhistory import (
39
28
FullHistoryBzrBranch,
43
32
class BzrBranch4(FullHistoryBzrBranch):
44
33
"""Branch format 4."""
46
def lock_write(self, token=None):
47
"""Lock the branch for write operations.
49
:param token: A token to permit reacquiring a previously held and
51
:return: A BranchWriteLockResult.
53
if not self.is_locked():
55
# All-in-one needs to always unlock/lock.
56
self.repository._warn_if_deprecated(self)
57
self.repository.lock_write()
59
return BranchWriteLockResult(self.unlock,
60
self.control_files.lock_write(token=token))
62
self.repository.unlock()
66
"""Lock the branch for read operations.
68
:return: A bzrlib.lock.LogicalLockResult.
70
if not self.is_locked():
72
# All-in-one needs to always unlock/lock.
73
self.repository._warn_if_deprecated(self)
74
self.repository.lock_read()
76
self.control_files.lock_read()
77
return LogicalLockResult(self.unlock)
79
self.repository.unlock()
82
@only_raises(errors.LockNotHeld, errors.LockBroken)
84
if self.control_files._lock_count == 2 and self.conf_store is not None:
85
self.conf_store.save_changes()
87
self.control_files.unlock()
89
# All-in-one needs to always unlock/lock.
90
self.repository.unlock()
91
if not self.control_files.is_locked():
92
# we just released the lock
93
self._clear_cached_state()
95
def _get_checkout_format(self, lightweight=False):
35
def _get_checkout_format(self):
96
36
"""Return the most suitable metadir for a checkout of this branch.
98
38
from bzrlib.plugins.weave_fmt.repository import RepositoryFormat7
99
39
from bzrlib.bzrdir import BzrDirMetaFormat1
100
40
format = BzrDirMetaFormat1()
102
format.set_branch_format(self._format)
103
format.repository_format = self.bzrdir._format.repository_format
105
format.repository_format = RepositoryFormat7()
41
format.repository_format = RepositoryFormat7()
134
70
It does not support binding.
137
def initialize(self, a_bzrdir, name=None, repository=None,
138
append_revisions_only=None):
73
def initialize(self, a_bzrdir, name=None, repository=None):
139
74
"""Create a branch of this format in a_bzrdir.
141
76
:param a_bzrdir: The bzrdir to initialize the branch in
142
77
:param name: Name of colocated branch to create, if any
143
78
:param repository: Repository for this branch (unused)
145
if append_revisions_only:
146
raise errors.UpgradeRequired(a_bzrdir.user_url)
147
80
if repository is not None:
148
81
raise NotImplementedError(
149
82
"initialize(repository=<not None>) on %r" % (self,))
194
127
return "Branch format 4"
196
129
def open(self, a_bzrdir, name=None, _found=False, ignore_fallbacks=False,
197
found_repository=None, possible_transports=None):
130
found_repository=None):
198
131
"""See BranchFormat.open()."""
200
name = a_bzrdir._get_selected_branch()
202
133
raise errors.NoColocatedBranchSupport(self)
204
135
# we are being called directly and must probe.
209
140
_control_files=a_bzrdir._control_files,
210
141
a_bzrdir=a_bzrdir,
212
_repository=found_repository,
213
possible_transports=possible_transports)
143
_repository=found_repository)
215
145
def __str__(self):
216
146
return "Bazaar-NG branch format 4"