bzr branch
http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
| 3296.1.1
by Martin Pool If LockableFiles is destroyed while locked, just mutter | 1 | # Copyright (C) 2005, 2006, 2008 Canonical Ltd
 | 
| 1887.1.1
by Adeodato Simó Do not separate paragraphs in the copyright statement with blank lines, | 2 | #
 | 
| 1185.65.22
by Robert Collins lockable_files was extracted from branch.py - give it a copyright statement | 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.
 | |
| 1887.1.1
by Adeodato Simó Do not separate paragraphs in the copyright statement with blank lines, | 7 | #
 | 
| 1185.65.22
by Robert Collins lockable_files was extracted from branch.py - give it a copyright statement | 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.
 | |
| 1887.1.1
by Adeodato Simó Do not separate paragraphs in the copyright statement with blank lines, | 12 | #
 | 
| 1185.65.22
by Robert Collins lockable_files was extracted from branch.py - give it a copyright statement | 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 | ||
| 1185.65.29
by Robert Collins Implement final review suggestions. | 17 | from cStringIO import StringIO | 
| 3535.5.1
by John Arbash Meinel cleanup a few imports to be lazily loaded. | 18 | |
| 19 | from bzrlib.lazy_import import lazy_import | |
| 20 | lazy_import(globals(), """ | |
| 1185.65.29
by Robert Collins Implement final review suggestions. | 21 | import codecs
 | 
| 3535.5.1
by John Arbash Meinel cleanup a few imports to be lazily loaded. | 22 | import warnings
 | 
| 23 | ||
| 24 | from bzrlib import (
 | |
| 25 |     errors,
 | |
| 26 |     osutils,
 | |
| 27 |     transactions,
 | |
| 28 |     urlutils,
 | |
| 29 |     )
 | |
| 30 | """) | |
| 31 | ||
| 32 | from bzrlib.decorators import ( | |
| 33 | needs_read_lock, | |
| 34 | needs_write_lock, | |
| 35 |     )
 | |
| 3388.2.1
by Martin Pool Deprecate LockableFiles.get_utf8 | 36 | from bzrlib.symbol_versioning import ( | 
| 37 | deprecated_in, | |
| 38 | deprecated_method, | |
| 39 |     )
 | |
| 1685.1.45
by John Arbash Meinel Moved url functions into bzrlib.urlutils | 40 | |
| 1185.65.10
by Robert Collins Rename Controlfiles to LockableFiles. | 41 | |
| 1553.5.41
by Martin Pool Add new LockableFiles.LockDirStrategy; not used yet | 42 | # XXX: The tracking here of lock counts and whether the lock is held is
 | 
| 43 | # somewhat redundant with what's done in LockDir; the main difference is that
 | |
| 44 | # LockableFiles permits reentrancy.
 | |
| 1185.65.27
by Robert Collins Tweak storage towards mergability. | 45 | |
| 1185.66.3
by Aaron Bentley Renamed ControlFiles to LockableFiles | 46 | class LockableFiles(object): | 
| 1553.5.38
by Martin Pool More explanation for LockableFiles | 47 | """Object representing a set of related files locked within the same scope. | 
| 48 | ||
| 49 |     These files are used by a WorkingTree, Repository or Branch, and should
 | |
| 50 |     generally only be touched by that object.
 | |
| 51 | ||
| 52 |     LockableFiles also provides some policy on top of Transport for encoding
 | |
| 53 |     control files as utf-8.
 | |
| 54 | ||
| 1553.5.39
by Martin Pool More lock docs | 55 |     LockableFiles manage a lock count and can be locked repeatedly by
 | 
| 56 |     a single caller.  (The underlying lock implementation generally does not
 | |
| 57 |     support this.)
 | |
| 58 | ||
| 1553.5.38
by Martin Pool More explanation for LockableFiles | 59 |     Instances of this class are often called control_files.
 | 
| 60 |     
 | |
| 1553.5.43
by Martin Pool Get LockableFiles tests running against LockDir | 61 |     This object builds on top of a Transport, which is used to actually write
 | 
| 62 |     the files to disk, and an OSLock or LockDir, which controls how access to
 | |
| 63 |     the files is controlled.  The particular type of locking used is set when
 | |
| 64 |     the object is constructed.  In older formats OSLocks are used everywhere.
 | |
| 65 |     in newer formats a LockDir is used for Repositories and Branches, and 
 | |
| 66 |     OSLocks for the local filesystem.
 | |
| 3407.2.9
by Martin Pool doc | 67 | |
| 68 |     This class is now deprecated; code should move to using the Transport 
 | |
| 69 |     directly for file operations and using the lock or CountedLock for 
 | |
| 70 |     locking.
 | |
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 71 |     """
 | 
| 1185.65.10
by Robert Collins Rename Controlfiles to LockableFiles. | 72 | |
| 1553.5.47
by Martin Pool cleanup LockableFiles | 73 |     # _lock_mode: None, or 'r' or 'w'
 | 
| 1553.5.43
by Martin Pool Get LockableFiles tests running against LockDir | 74 | |
| 1553.5.47
by Martin Pool cleanup LockableFiles | 75 |     # _lock_count: If _lock_mode is true, a positive count of the number of
 | 
| 76 |     # times the lock has been taken *by this process*.   
 | |
| 77 | ||
| 1553.5.63
by Martin Pool Lock type is now mandatory for LockableFiles constructor | 78 | def __init__(self, transport, lock_name, lock_class): | 
| 1553.5.43
by Martin Pool Get LockableFiles tests running against LockDir | 79 | """Create a LockableFiles group | 
| 80 | ||
| 81 |         :param transport: Transport pointing to the directory holding the 
 | |
| 82 |             control files and lock.
 | |
| 83 |         :param lock_name: Name of the lock guarding these files.
 | |
| 1553.5.47
by Martin Pool cleanup LockableFiles | 84 |         :param lock_class: Class of lock strategy to use: typically
 | 
| 85 |             either LockDir or TransportLock.
 | |
| 1553.5.43
by Martin Pool Get LockableFiles tests running against LockDir | 86 |         """
 | 
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 87 | self._transport = transport | 
| 88 | self.lock_name = lock_name | |
| 89 | self._transaction = None | |
| 1553.5.47
by Martin Pool cleanup LockableFiles | 90 | self._lock_mode = None | 
| 91 | self._lock_count = 0 | |
| 1685.1.43
by John Arbash Meinel Bug in lockable files when _find_mode throws | 92 | self._find_modes() | 
| 1553.5.43
by Martin Pool Get LockableFiles tests running against LockDir | 93 | esc_name = self._escape(lock_name) | 
| 1608.2.1
by Martin Pool [merge] Storage filename escaping | 94 | self._lock = lock_class(transport, esc_name, | 
| 1553.5.59
by Martin Pool Pass file/mode bits through to creation of lock files/dirs | 95 | file_modebits=self._file_mode, | 
| 96 | dir_modebits=self._dir_mode) | |
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 97 | |
| 1553.5.60
by Martin Pool New LockableFiles.create_lock() method | 98 | def create_lock(self): | 
| 99 | """Create the lock. | |
| 100 | ||
| 101 |         This should normally be called only when the LockableFiles directory
 | |
| 102 |         is first created on disk.
 | |
| 103 |         """
 | |
| 1666.1.4
by Robert Collins * 'Metadir' is now the default disk format. This improves behaviour in | 104 | self._lock.create(mode=self._dir_mode) | 
| 1553.5.60
by Martin Pool New LockableFiles.create_lock() method | 105 | |
| 1553.5.53
by Martin Pool Add LockableFiles __repr__ | 106 | def __repr__(self): | 
| 107 | return '%s(%r)' % (self.__class__.__name__, | |
| 108 | self._transport) | |
| 1185.80.2
by John Arbash Meinel Traced double locking code to WorkingTree creating its own control files. | 109 | def __str__(self): | 
| 110 | return 'LockableFiles(%s, %s)' % (self.lock_name, self._transport.base) | |
| 111 | ||
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 112 | def __del__(self): | 
| 1608.2.1
by Martin Pool [merge] Storage filename escaping | 113 | if self.is_locked(): | 
| 3296.1.2
by Martin Pool LockableFiles should warn but not automatically unlock | 114 |             # do not automatically unlock; there should have been a
 | 
| 115 |             # try/finally to unlock this.
 | |
| 3535.5.1
by John Arbash Meinel cleanup a few imports to be lazily loaded. | 116 | warnings.warn("%r was gc'd while locked" % self) | 
| 1553.5.53
by Martin Pool Add LockableFiles __repr__ | 117 | |
| 1687.1.6
by Robert Collins Extend LockableFiles to support break_lock() calls. | 118 | def break_lock(self): | 
| 119 | """Break the lock of this lockable files group if it is held. | |
| 120 | ||
| 121 |         The current ui factory will be used to prompt for user conformation.
 | |
| 122 |         """
 | |
| 123 | self._lock.break_lock() | |
| 124 | ||
| 1185.69.2
by John Arbash Meinel Changed LockableFiles to take the root directory directly. Moved mode information into LockableFiles instead of Branch | 125 | def _escape(self, file_or_path): | 
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 126 | if not isinstance(file_or_path, basestring): | 
| 127 | file_or_path = '/'.join(file_or_path) | |
| 128 | if file_or_path == '': | |
| 1185.69.2
by John Arbash Meinel Changed LockableFiles to take the root directory directly. Moved mode information into LockableFiles instead of Branch | 129 | return u'' | 
| 3535.5.1
by John Arbash Meinel cleanup a few imports to be lazily loaded. | 130 | return urlutils.escape(osutils.safe_unicode(file_or_path)) | 
| 1185.69.2
by John Arbash Meinel Changed LockableFiles to take the root directory directly. Moved mode information into LockableFiles instead of Branch | 131 | |
| 132 | def _find_modes(self): | |
| 3416.2.1
by Martin Pool Add BzrDir._get_file_mode and _get_dir_mode | 133 | """Determine the appropriate modes for files and directories. | 
| 134 |         
 | |
| 135 |         :deprecated: Replaced by BzrDir._find_modes.
 | |
| 136 |         """
 | |
| 1185.69.2
by John Arbash Meinel Changed LockableFiles to take the root directory directly. Moved mode information into LockableFiles instead of Branch | 137 | try: | 
| 1534.4.28
by Robert Collins first cut at merge from integration. | 138 | st = self._transport.stat('.') | 
| 139 | except errors.TransportNotPossible: | |
| 1185.69.2
by John Arbash Meinel Changed LockableFiles to take the root directory directly. Moved mode information into LockableFiles instead of Branch | 140 | self._dir_mode = 0755 | 
| 141 | self._file_mode = 0644 | |
| 142 | else: | |
| 3107.2.1
by John Arbash Meinel Fix LockableFiles to not use modes that allow the user to write to things they create. | 143 |             # Check the directory mode, but also make sure the created
 | 
| 144 |             # directories and files are read-write for this user. This is
 | |
| 145 |             # mostly a workaround for filesystems which lie about being able to
 | |
| 146 |             # write to a directory (cygwin & win32)
 | |
| 147 | self._dir_mode = (st.st_mode & 07777) | 00700 | |
| 1185.69.2
by John Arbash Meinel Changed LockableFiles to take the root directory directly. Moved mode information into LockableFiles instead of Branch | 148 |             # Remove the sticky and execute bits for files
 | 
| 149 | self._file_mode = self._dir_mode & ~07111 | |
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 150 | |
| 3407.2.8
by Martin Pool Deprecate LockableFiles.controlfilename | 151 | @deprecated_method(deprecated_in((1, 6, 0))) | 
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 152 | def controlfilename(self, file_or_path): | 
| 3407.2.8
by Martin Pool Deprecate LockableFiles.controlfilename | 153 | """Return location relative to branch. | 
| 154 |         
 | |
| 155 |         :deprecated: Use Transport methods instead.
 | |
| 156 |         """
 | |
| 1185.69.2
by John Arbash Meinel Changed LockableFiles to take the root directory directly. Moved mode information into LockableFiles instead of Branch | 157 | return self._transport.abspath(self._escape(file_or_path)) | 
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 158 | |
| 1185.65.29
by Robert Collins Implement final review suggestions. | 159 |     @needs_read_lock
 | 
| 3407.2.1
by Martin Pool Deprecate LockableFiles.get | 160 | @deprecated_method(deprecated_in((1, 5, 0))) | 
| 1185.65.29
by Robert Collins Implement final review suggestions. | 161 | def get(self, relpath): | 
| 3407.2.1
by Martin Pool Deprecate LockableFiles.get | 162 | """Get a file as a bytestream. | 
| 163 |         
 | |
| 164 |         :deprecated: Use a Transport instead of LockableFiles.
 | |
| 165 |         """
 | |
| 1185.65.29
by Robert Collins Implement final review suggestions. | 166 | relpath = self._escape(relpath) | 
| 167 | return self._transport.get(relpath) | |
| 168 | ||
| 169 |     @needs_read_lock
 | |
| 3388.2.1
by Martin Pool Deprecate LockableFiles.get_utf8 | 170 | @deprecated_method(deprecated_in((1, 5, 0))) | 
| 1185.65.29
by Robert Collins Implement final review suggestions. | 171 | def get_utf8(self, relpath): | 
| 3407.2.1
by Martin Pool Deprecate LockableFiles.get | 172 | """Get a file as a unicode stream. | 
| 173 |         
 | |
| 174 |         :deprecated: Use a Transport instead of LockableFiles.
 | |
| 175 |         """
 | |
| 1185.65.29
by Robert Collins Implement final review suggestions. | 176 | relpath = self._escape(relpath) | 
| 177 |         # DO NOT introduce an errors=replace here.
 | |
| 178 | return codecs.getreader('utf-8')(self._transport.get(relpath)) | |
| 179 | ||
| 1185.65.27
by Robert Collins Tweak storage towards mergability. | 180 |     @needs_write_lock
 | 
| 3407.2.7
by Martin Pool Deprecate LockableFiles.put_utf8 and put_bytes. | 181 | @deprecated_method(deprecated_in((1, 6, 0))) | 
| 1185.65.12
by Robert Collins Remove the only-used-once put_controlfiles, and change put_controlfile to put and put_utf8. | 182 | def put(self, path, file): | 
| 183 | """Write a file. | |
| 184 |         
 | |
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 185 |         :param path: The path to put the file, relative to the .bzr control
 | 
| 186 |                      directory
 | |
| 3407.2.7
by Martin Pool Deprecate LockableFiles.put_utf8 and put_bytes. | 187 |         :param file: A file-like or string object whose contents should be copied.
 | 
| 188 | ||
| 189 |         :deprecated: Use Transport methods instead.
 | |
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 190 |         """
 | 
| 1955.3.8
by John Arbash Meinel avoid some deprecation warnings in other parts of the code | 191 | self._transport.put_file(self._escape(path), file, mode=self._file_mode) | 
| 1185.65.12
by Robert Collins Remove the only-used-once put_controlfiles, and change put_controlfile to put and put_utf8. | 192 | |
| 1185.65.27
by Robert Collins Tweak storage towards mergability. | 193 |     @needs_write_lock
 | 
| 3407.2.7
by Martin Pool Deprecate LockableFiles.put_utf8 and put_bytes. | 194 | @deprecated_method(deprecated_in((1, 6, 0))) | 
| 2249.5.11
by John Arbash Meinel Audit Branch to ensure utf8 revision ids. | 195 | def put_bytes(self, path, a_string): | 
| 196 | """Write a string of bytes. | |
| 197 | ||
| 198 |         :param path: The path to put the bytes, relative to the transport root.
 | |
| 3407.2.7
by Martin Pool Deprecate LockableFiles.put_utf8 and put_bytes. | 199 |         :param a_string: A string object, whose exact bytes are to be copied.
 | 
| 200 | ||
| 201 |         :deprecated: Use Transport methods instead.
 | |
| 2249.5.11
by John Arbash Meinel Audit Branch to ensure utf8 revision ids. | 202 |         """
 | 
| 203 | self._transport.put_bytes(self._escape(path), a_string, | |
| 204 | mode=self._file_mode) | |
| 205 | ||
| 206 |     @needs_write_lock
 | |
| 3407.2.5
by Martin Pool Deprecate LockableFiles.put_utf8 | 207 | @deprecated_method(deprecated_in((1, 6, 0))) | 
| 1185.65.29
by Robert Collins Implement final review suggestions. | 208 | def put_utf8(self, path, a_string): | 
| 209 | """Write a string, encoding as utf-8. | |
| 1185.65.12
by Robert Collins Remove the only-used-once put_controlfiles, and change put_controlfile to put and put_utf8. | 210 | |
| 1185.65.29
by Robert Collins Implement final review suggestions. | 211 |         :param path: The path to put the string, relative to the transport root.
 | 
| 2249.5.11
by John Arbash Meinel Audit Branch to ensure utf8 revision ids. | 212 |         :param string: A string or unicode object whose contents should be copied.
 | 
| 3407.2.7
by Martin Pool Deprecate LockableFiles.put_utf8 and put_bytes. | 213 | |
| 214 |         :deprecated: Use Transport methods instead.
 | |
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 215 |         """
 | 
| 1185.67.7
by Aaron Bentley Refactored a bit | 216 |         # IterableFile would not be needed if Transport.put took iterables
 | 
| 217 |         # instead of files.  ADHB 2005-12-25
 | |
| 1185.65.17
by Robert Collins Merge from integration, mode-changes are broken. | 218 |         # RBC 20060103 surely its not needed anyway, with codecs transcode
 | 
| 219 |         # file support ?
 | |
| 1185.69.2
by John Arbash Meinel Changed LockableFiles to take the root directory directly. Moved mode information into LockableFiles instead of Branch | 220 |         # JAM 20060103 We definitely don't want encode(..., 'replace')
 | 
| 221 |         # these are valuable files which should have exact contents.
 | |
| 1185.65.29
by Robert Collins Implement final review suggestions. | 222 | if not isinstance(a_string, basestring): | 
| 223 | raise errors.BzrBadParameterNotString(a_string) | |
| 2249.5.11
by John Arbash Meinel Audit Branch to ensure utf8 revision ids. | 224 | self.put_bytes(path, a_string.encode('utf-8')) | 
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 225 | |
| 2018.5.75
by Andrew Bennetts Add Repository.{dont_,}leave_lock_in_place. | 226 | def leave_in_place(self): | 
| 227 | """Set this LockableFiles to not clear the physical lock on unlock.""" | |
| 228 | self._lock.leave_in_place() | |
| 229 | ||
| 230 | def dont_leave_in_place(self): | |
| 231 | """Set this LockableFiles to clear the physical lock on unlock.""" | |
| 232 | self._lock.dont_leave_in_place() | |
| 233 | ||
| 2279.7.1
by Andrew Bennetts ``LockableFiles.lock_write()`` now accepts a ``token`` keyword argument, so that | 234 | def lock_write(self, token=None): | 
| 235 | """Lock this group of files for writing. | |
| 236 |         
 | |
| 237 |         :param token: if this is already locked, then lock_write will fail
 | |
| 238 |             unless the token matches the existing lock.
 | |
| 239 |         :returns: a token if this instance supports tokens, otherwise None.
 | |
| 240 |         :raises TokenLockingNotSupported: when a token is given but this
 | |
| 241 |             instance doesn't support using token locks.
 | |
| 242 |         :raises MismatchedToken: if the specified token doesn't match the token
 | |
| 243 |             of the existing lock.
 | |
| 2018.5.145
by Andrew Bennetts Add a brief explanation of what tokens are used for to lock_write docstrings. | 244 | |
| 245 |         A token should be passed in if you know that you have locked the object
 | |
| 246 |         some other way, and need to synchronise this object's state with that
 | |
| 247 |         fact.
 | |
| 2279.7.1
by Andrew Bennetts ``LockableFiles.lock_write()`` now accepts a ``token`` keyword argument, so that | 248 |         """
 | 
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 249 |         # TODO: Upgrade locking to support using a Transport,
 | 
| 250 |         # and potentially a remote locking protocol
 | |
| 251 | if self._lock_mode: | |
| 1594.2.22
by Robert Collins Ensure that lockable files calls finish() on transactions.: | 252 | if self._lock_mode != 'w' or not self.get_transaction().writeable(): | 
| 1694.2.6
by Martin Pool [merge] bzr.dev | 253 | raise errors.ReadOnlyError(self) | 
| 2279.7.1
by Andrew Bennetts ``LockableFiles.lock_write()`` now accepts a ``token`` keyword argument, so that | 254 | self._lock.validate_token(token) | 
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 255 | self._lock_count += 1 | 
| 2018.14.1
by Andrew Bennetts Update to current hpss branch? Fix lots of test failures. | 256 | return self._token_from_lock | 
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 257 | else: | 
| 2279.7.1
by Andrew Bennetts ``LockableFiles.lock_write()`` now accepts a ``token`` keyword argument, so that | 258 | token_from_lock = self._lock.lock_write(token=token) | 
| 1185.80.2
by John Arbash Meinel Traced double locking code to WorkingTree creating its own control files. | 259 |             #traceback.print_stack()
 | 
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 260 | self._lock_mode = 'w' | 
| 261 | self._lock_count = 1 | |
| 1563.2.34
by Robert Collins Remove the commit and rollback transaction methods as misleading, and implement a WriteTransaction | 262 | self._set_transaction(transactions.WriteTransaction()) | 
| 2018.14.1
by Andrew Bennetts Update to current hpss branch? Fix lots of test failures. | 263 | self._token_from_lock = token_from_lock | 
| 2279.7.1
by Andrew Bennetts ``LockableFiles.lock_write()`` now accepts a ``token`` keyword argument, so that | 264 | return token_from_lock | 
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 265 | |
| 266 | def lock_read(self): | |
| 267 | if self._lock_mode: | |
| 3376.2.4
by Martin Pool Remove every assert statement from bzrlib! | 268 | if self._lock_mode not in ('r', 'w'): | 
| 269 | raise ValueError("invalid lock mode %r" % (self._lock_mode,)) | |
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 270 | self._lock_count += 1 | 
| 271 | else: | |
| 1553.5.47
by Martin Pool cleanup LockableFiles | 272 | self._lock.lock_read() | 
| 1185.80.2
by John Arbash Meinel Traced double locking code to WorkingTree creating its own control files. | 273 |             #traceback.print_stack()
 | 
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 274 | self._lock_mode = 'r' | 
| 275 | self._lock_count = 1 | |
| 276 | self._set_transaction(transactions.ReadOnlyTransaction()) | |
| 277 |             # 5K may be excessive, but hey, its a knob.
 | |
| 278 | self.get_transaction().set_cache_size(5000) | |
| 279 | ||
| 280 | def unlock(self): | |
| 281 | if not self._lock_mode: | |
| 1553.5.36
by Martin Pool Clean up duplicate BranchNotLocked error and rename to ObjectNotLocked | 282 | raise errors.LockNotHeld(self) | 
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 283 | if self._lock_count > 1: | 
| 284 | self._lock_count -= 1 | |
| 285 | else: | |
| 1185.80.2
by John Arbash Meinel Traced double locking code to WorkingTree creating its own control files. | 286 |             #traceback.print_stack()
 | 
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 287 | self._finish_transaction() | 
| 1687.1.6
by Robert Collins Extend LockableFiles to support break_lock() calls. | 288 | try: | 
| 289 | self._lock.unlock() | |
| 290 | finally: | |
| 291 | self._lock_mode = self._lock_count = None | |
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 292 | |
| 1553.5.35
by Martin Pool Start break-lock --show | 293 | def is_locked(self): | 
| 294 | """Return true if this LockableFiles group is locked""" | |
| 295 | return self._lock_count >= 1 | |
| 296 | ||
| 1694.2.6
by Martin Pool [merge] bzr.dev | 297 | def get_physical_lock_status(self): | 
| 298 | """Return physical lock status. | |
| 299 |         
 | |
| 300 |         Returns true if a lock is held on the transport. If no lock is held, or
 | |
| 301 |         the underlying locking mechanism does not support querying lock
 | |
| 302 |         status, false is returned.
 | |
| 303 |         """
 | |
| 304 | try: | |
| 305 | return self._lock.peek() is not None | |
| 306 | except NotImplementedError: | |
| 307 | return False | |
| 308 | ||
| 1185.65.1
by Aaron Bentley Refactored out ControlFiles and RevisionStore from _Branch | 309 | def get_transaction(self): | 
| 310 | """Return the current active transaction. | |
| 311 | ||
| 312 |         If no transaction is active, this returns a passthrough object
 | |
| 313 |         for which all data is immediately flushed and no caching happens.
 | |
| 314 |         """
 | |
| 315 | if self._transaction is None: | |
| 316 | return transactions.PassThroughTransaction() | |
| 317 | else: | |
| 318 | return self._transaction | |
| 319 | ||
| 320 | def _set_transaction(self, new_transaction): | |
| 321 | """Set a new active transaction.""" | |
| 322 | if self._transaction is not None: | |
| 323 | raise errors.LockError('Branch %s is in a transaction already.' % | |
| 324 | self) | |
| 325 | self._transaction = new_transaction | |
| 326 | ||
| 327 | def _finish_transaction(self): | |
| 328 | """Exit the current transaction.""" | |
| 329 | if self._transaction is None: | |
| 330 | raise errors.LockError('Branch %s is not in a transaction' % | |
| 331 | self) | |
| 332 | transaction = self._transaction | |
| 333 | self._transaction = None | |
| 334 | transaction.finish() | |
| 1553.5.40
by Martin Pool Factor locking strategy out of LockableFiles so that we can use LockDirs in new formats. | 335 | |
| 336 | ||
| 1553.5.45
by Martin Pool Clean up Transport-based locks for old branches | 337 | class TransportLock(object): | 
| 338 | """Locking method which uses transport-dependent locks. | |
| 339 | ||
| 340 |     On the local filesystem these transform into OS-managed locks.
 | |
| 341 | ||
| 342 |     These do not guard against concurrent access via different
 | |
| 343 |     transports.
 | |
| 344 | ||
| 345 |     This is suitable for use only in WorkingTrees (which are at present
 | |
| 346 |     always local).
 | |
| 1553.5.40
by Martin Pool Factor locking strategy out of LockableFiles so that we can use LockDirs in new formats. | 347 |     """
 | 
| 1553.5.59
by Martin Pool Pass file/mode bits through to creation of lock files/dirs | 348 | def __init__(self, transport, escaped_name, file_modebits, dir_modebits): | 
| 1553.5.40
by Martin Pool Factor locking strategy out of LockableFiles so that we can use LockDirs in new formats. | 349 | self._transport = transport | 
| 350 | self._escaped_name = escaped_name | |
| 1553.5.59
by Martin Pool Pass file/mode bits through to creation of lock files/dirs | 351 | self._file_modebits = file_modebits | 
| 352 | self._dir_modebits = dir_modebits | |
| 1553.5.40
by Martin Pool Factor locking strategy out of LockableFiles so that we can use LockDirs in new formats. | 353 | |
| 1687.1.6
by Robert Collins Extend LockableFiles to support break_lock() calls. | 354 | def break_lock(self): | 
| 355 | raise NotImplementedError(self.break_lock) | |
| 356 | ||
| 2018.5.75
by Andrew Bennetts Add Repository.{dont_,}leave_lock_in_place. | 357 | def leave_in_place(self): | 
| 358 | raise NotImplementedError(self.leave_in_place) | |
| 359 | ||
| 2018.5.76
by Andrew Bennetts Testing that repository.{dont_,}leave_lock_in_place raises NotImplementedError if lock_write returns None. | 360 | def dont_leave_in_place(self): | 
| 361 | raise NotImplementedError(self.dont_leave_in_place) | |
| 362 | ||
| 2279.7.1
by Andrew Bennetts ``LockableFiles.lock_write()`` now accepts a ``token`` keyword argument, so that | 363 | def lock_write(self, token=None): | 
| 364 | if token is not None: | |
| 365 | raise errors.TokenLockingNotSupported(self) | |
| 1553.5.40
by Martin Pool Factor locking strategy out of LockableFiles so that we can use LockDirs in new formats. | 366 | self._lock = self._transport.lock_write(self._escaped_name) | 
| 367 | ||
| 368 | def lock_read(self): | |
| 369 | self._lock = self._transport.lock_read(self._escaped_name) | |
| 370 | ||
| 371 | def unlock(self): | |
| 372 | self._lock.unlock() | |
| 373 | self._lock = None | |
| 374 | ||
| 1694.2.6
by Martin Pool [merge] bzr.dev | 375 | def peek(self): | 
| 376 | raise NotImplementedError() | |
| 377 | ||
| 1666.1.4
by Robert Collins * 'Metadir' is now the default disk format. This improves behaviour in | 378 | def create(self, mode=None): | 
| 1553.5.59
by Martin Pool Pass file/mode bits through to creation of lock files/dirs | 379 | """Create lock mechanism""" | 
| 380 |         # for old-style locks, create the file now
 | |
| 1955.3.8
by John Arbash Meinel avoid some deprecation warnings in other parts of the code | 381 | self._transport.put_bytes(self._escaped_name, '', | 
| 1553.5.60
by Martin Pool New LockableFiles.create_lock() method | 382 | mode=self._file_modebits) | 
| 2279.7.1
by Andrew Bennetts ``LockableFiles.lock_write()`` now accepts a ``token`` keyword argument, so that | 383 | |
| 384 | def validate_token(self, token): | |
| 385 | if token is not None: | |
| 386 | raise errors.TokenLockingNotSupported(self) | |
| 387 |