1
# Copyright (C) 2006-2010 Canonical Ltd
1
# Copyright (C) 2005, 2006, 2007, 2008, 2009 Canonical Ltd
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
91
class ControlComponent(object):
92
"""Abstract base class for control directory components.
94
This provides interfaces that are common across bzrdirs,
95
repositories, branches, and workingtree control directories.
97
They all expose two urls and transports: the *user* URL is the
98
one that stops above the control directory (eg .bzr) and that
99
should normally be used in messages, and the *control* URL is
100
under that in eg .bzr/checkout and is used to read the control
103
This can be used as a mixin and is intended to fit with
108
def control_transport(self):
109
raise NotImplementedError
112
def control_url(self):
113
return self.control_transport.base
116
def user_transport(self):
117
raise NotImplementedError
121
return self.user_transport.base
124
class BzrDir(ControlComponent):
125
91
"""A .bzr control diretory.
127
93
BzrDir instances let you create or open any of the things that can be
294
260
# copied, and finally if we are copying up to a specific
295
261
# revision_id then we can use the pending-ancestry-result which
296
262
# does not require traversing all of history to describe it.
297
if (result_repo.user_url == result.user_url
298
and not require_stacking and
263
if (result_repo.bzrdir.root_transport.base ==
264
result.root_transport.base and not require_stacking and
299
265
revision_id is not None):
300
266
fetch_spec = graph.PendingAncestryResult(
301
267
[revision_id], local_repo)
388
354
for subdir in sorted(subdirs, reverse=True):
389
355
pending.append(current_transport.clone(subdir))
391
def list_branches(self):
392
"""Return a sequence of all branches local to this control directory.
396
return [self.open_branch()]
397
except errors.NotBranchError:
401
358
def find_branches(transport):
402
359
"""Find all branches under a transport.
414
371
except errors.NoRepositoryPresent:
417
return False, ([], repository)
418
return True, (bzrdir.list_branches(), None)
420
for branches, repo in BzrDir.find_bzrdirs(transport,
374
return False, (None, repository)
376
branch = bzrdir.open_branch()
377
except errors.NotBranchError:
378
return True, (None, None)
380
return True, (branch, None)
382
for branch, repo in BzrDir.find_bzrdirs(transport, evaluate=evaluate):
422
383
if repo is not None:
423
ret.extend(repo.find_branches())
424
if branches is not None:
384
branches.extend(repo.find_branches())
385
if branch is not None:
386
branches.append(branch)
428
389
def destroy_repository(self):
429
390
"""Destroy the repository in this BzrDir"""
430
391
raise NotImplementedError(self.destroy_repository)
432
def create_branch(self, name=None):
393
def create_branch(self):
433
394
"""Create a branch in this BzrDir.
435
:param name: Name of the colocated branch to create, None for
438
396
The bzrdir's format will control what branch format is created.
439
397
For more control see BranchFormatXX.create(a_bzrdir).
441
399
raise NotImplementedError(self.create_branch)
443
def destroy_branch(self, name=None):
444
"""Destroy a branch in this BzrDir.
446
:param name: Name of the branch to destroy, None for the default
401
def destroy_branch(self):
402
"""Destroy the branch in this BzrDir"""
449
403
raise NotImplementedError(self.destroy_branch)
499
453
except errors.NoRepositoryPresent:
500
454
repository = None
502
if (found_bzrdir.user_url != self.user_url
503
and not repository.is_shared()):
456
if ((found_bzrdir.root_transport.base !=
457
self.root_transport.base) and not repository.is_shared()):
504
458
# Don't look higher, can't use a higher shared repo.
505
459
repository = None
621
575
:return: Tuple with old path name and new path name
623
def name_gen(base='backup.bzr'):
625
name = "%s.~%d~" % (base, counter)
626
while self.root_transport.has(name):
628
name = "%s.~%d~" % (base, counter)
631
backup_dir=name_gen()
632
577
pb = ui.ui_factory.nested_progress_bar()
634
579
# FIXME: bug 300001 -- the backup fails if the backup directory
635
580
# already exists, but it should instead either remove it or make
636
581
# a new backup directory.
583
# FIXME: bug 262450 -- the backup directory should have the same
584
# permissions as the .bzr directory (probably a bug in copy_tree)
638
585
old_path = self.root_transport.abspath('.bzr')
639
new_path = self.root_transport.abspath(backup_dir)
640
ui.ui_factory.note('making backup of %s\n to %s' % (old_path, new_path,))
641
self.root_transport.copy_tree('.bzr', backup_dir)
586
new_path = self.root_transport.abspath('backup.bzr')
587
pb.note('making backup of %s' % (old_path,))
588
pb.note(' to %s' % (new_path,))
589
self.root_transport.copy_tree('.bzr', 'backup.bzr')
642
590
return (old_path, new_path)
704
652
next_transport = found_bzrdir.root_transport.clone('..')
705
if (found_bzrdir.user_url == next_transport.base):
653
if (found_bzrdir.root_transport.base == next_transport.base):
706
654
# top of the file system
708
656
# find the next containing bzrdir
725
673
repository = found_bzrdir.open_repository()
726
674
except errors.NoRepositoryPresent:
727
675
return None, False
728
if found_bzrdir.user_url == self.user_url:
676
if found_bzrdir.root_transport.base == self.root_transport.base:
729
677
return repository, True
730
678
elif repository.is_shared():
731
679
return repository, True
737
685
raise errors.NoRepositoryPresent(self)
738
686
return found_repo
740
def get_branch_reference(self, name=None):
688
def get_branch_reference(self):
741
689
"""Return the referenced URL for the branch in this bzrdir.
743
:param name: Optional colocated branch name
744
691
:raises NotBranchError: If there is no Branch.
745
:raises NoColocatedBranchSupport: If a branch name was specified
746
but colocated branches are not supported.
747
692
:return: The URL the branch in this bzrdir references if it is a
748
693
reference branch, or None for regular branches.
751
raise errors.NoColocatedBranchSupport(self)
754
def get_branch_transport(self, branch_format, name=None):
697
def get_branch_transport(self, branch_format):
755
698
"""Get the transport for use by branch format in this BzrDir.
757
700
Note that bzr dirs that do not support format strings will raise
852
795
:param _transport: the transport this dir is based at.
854
797
self._format = _format
855
# these are also under the more standard names of
856
# control_transport and user_transport
857
798
self.transport = _transport.clone('.bzr')
858
799
self.root_transport = _transport
859
800
self._mode_check_done = False
862
def user_transport(self):
863
return self.root_transport
866
def control_transport(self):
867
return self.transport
869
802
def is_control_filename(self, filename):
870
803
"""True if filename is the name of a path which is reserved for bzrdir's.
945
878
BzrDir._check_supported(format, _unsupported)
946
879
return format.open(transport, _found=True)
948
def open_branch(self, name=None, unsupported=False,
949
ignore_fallbacks=False):
881
def open_branch(self, unsupported=False, ignore_fallbacks=False):
950
882
"""Open the branch object at this BzrDir if one is present.
952
884
If unsupported is True, then no longer supported branch formats can
999
931
raise errors.NotBranchError(path=url)
1000
932
a_transport = new_t
1002
def _get_tree_branch(self, name=None):
934
def _get_tree_branch(self):
1003
935
"""Return the branch and tree, if any, for this bzrdir.
1005
:param name: Name of colocated branch to open.
1007
937
Return None for tree if not present or inaccessible.
1008
938
Raise NotBranchError if no branch is present.
1009
939
:return: (tree, branch)
1012
942
tree = self.open_workingtree()
1013
943
except (errors.NoWorkingTree, errors.NotLocalUrl):
1015
branch = self.open_branch(name=name)
945
branch = self.open_branch()
1017
if name is not None:
1018
branch = self.open_branch(name=name)
1020
branch = tree.branch
1021
948
return tree, branch
1096
1023
raise NotImplementedError(self.open_workingtree)
1098
def has_branch(self, name=None):
1025
def has_branch(self):
1099
1026
"""Tell if this bzrdir contains a branch.
1101
1028
Note: if you're going to open the branch, you should just go ahead
1383
1310
self.create_hook(hooks.HookPoint('pre_open',
1384
1311
"Invoked before attempting to open a BzrDir with the transport "
1385
1312
"that the open will use.", (1, 14), None))
1386
self.create_hook(hooks.HookPoint('post_repo_init',
1387
"Invoked after a repository has been initialized. "
1388
"post_repo_init is called with a "
1389
"bzrlib.bzrdir.RepoInitHookParams.",
1392
1314
# install the default hooks
1393
1315
BzrDir.hooks = BzrDirHooks()
1396
class RepoInitHookParams(object):
1397
"""Object holding parameters passed to *_repo_init hooks.
1399
There are 4 fields that hooks may wish to access:
1401
:ivar repository: Repository created
1402
:ivar format: Repository format
1403
:ivar bzrdir: The bzrdir for the repository
1404
:ivar shared: The repository is shared
1407
def __init__(self, repository, format, a_bzrdir, shared):
1408
"""Create a group of RepoInitHook parameters.
1410
:param repository: Repository created
1411
:param format: Repository format
1412
:param bzrdir: The bzrdir for the repository
1413
:param shared: The repository is shared
1415
self.repository = repository
1416
self.format = format
1417
self.bzrdir = a_bzrdir
1418
self.shared = shared
1420
def __eq__(self, other):
1421
return self.__dict__ == other.__dict__
1425
return "<%s for %s>" % (self.__class__.__name__,
1428
return "<%s for %s>" % (self.__class__.__name__,
1432
1318
class BzrDirPreSplitOut(BzrDir):
1433
1319
"""A common class for the all-in-one formats."""
1473
1359
tree.clone(result)
1476
def create_branch(self, name=None):
1362
def create_branch(self):
1477
1363
"""See BzrDir.create_branch."""
1478
return self._format.get_branch_format().initialize(self, name=name)
1364
return self._format.get_branch_format().initialize(self)
1480
def destroy_branch(self, name=None):
1366
def destroy_branch(self):
1481
1367
"""See BzrDir.destroy_branch."""
1482
1368
raise errors.UnsupportedOperation(self.destroy_branch, self)
1539
1425
raise errors.UnsupportedOperation(self.destroy_workingtree_metadata,
1542
def get_branch_transport(self, branch_format, name=None):
1428
def get_branch_transport(self, branch_format):
1543
1429
"""See BzrDir.get_branch_transport()."""
1544
if name is not None:
1545
raise errors.NoColocatedBranchSupport(self)
1546
1430
if branch_format is None:
1547
1431
return self.transport
1581
1465
format = BzrDirFormat.get_default_format()
1582
1466
return not isinstance(self._format, format.__class__)
1584
def open_branch(self, name=None, unsupported=False,
1585
ignore_fallbacks=False):
1468
def open_branch(self, unsupported=False, ignore_fallbacks=False):
1586
1469
"""See BzrDir.open_branch."""
1587
1470
from bzrlib.branch import BzrBranchFormat4
1588
1471
format = BzrBranchFormat4()
1589
1472
self._check_supported(format, unsupported)
1590
return format.open(self, name, _found=True)
1473
return format.open(self, _found=True)
1592
1475
def sprout(self, url, revision_id=None, force_new_repo=False,
1593
1476
possible_transports=None, accelerator_tree=None,
1654
1537
This is a deprecated format and may be removed after sept 2006.
1657
def has_workingtree(self):
1658
"""See BzrDir.has_workingtree."""
1661
1540
def open_repository(self):
1662
1541
"""See BzrDir.open_repository."""
1663
1542
from bzrlib.repofmt.weaverepo import RepositoryFormat5
1679
1558
This is a deprecated format and may be removed after sept 2006.
1682
def has_workingtree(self):
1683
"""See BzrDir.has_workingtree."""
1686
1561
def open_repository(self):
1687
1562
"""See BzrDir.open_repository."""
1688
1563
from bzrlib.repofmt.weaverepo import RepositoryFormat6
1710
1585
"""See BzrDir.can_convert_format()."""
1713
def create_branch(self, name=None):
1588
def create_branch(self):
1714
1589
"""See BzrDir.create_branch."""
1715
return self._format.get_branch_format().initialize(self, name=name)
1590
return self._format.get_branch_format().initialize(self)
1717
def destroy_branch(self, name=None):
1592
def destroy_branch(self):
1718
1593
"""See BzrDir.create_branch."""
1719
if name is not None:
1720
raise errors.NoColocatedBranchSupport(self)
1721
1594
self.transport.delete_tree('branch')
1723
1596
def create_repository(self, shared=False):
1746
1619
def destroy_workingtree_metadata(self):
1747
1620
self.transport.delete_tree('checkout')
1749
def find_branch_format(self, name=None):
1622
def find_branch_format(self):
1750
1623
"""Find the branch 'format' for this bzrdir.
1752
1625
This might be a synthetic object for e.g. RemoteBranch and SVN.
1754
1627
from bzrlib.branch import BranchFormat
1755
return BranchFormat.find_format(self, name=name)
1628
return BranchFormat.find_format(self)
1757
1630
def _get_mkdir_mode(self):
1758
1631
"""Figure out the mode to use when creating a bzrdir subdir."""
1760
1633
lockable_files.TransportLock)
1761
1634
return temp_control._dir_mode
1763
def get_branch_reference(self, name=None):
1636
def get_branch_reference(self):
1764
1637
"""See BzrDir.get_branch_reference()."""
1765
1638
from bzrlib.branch import BranchFormat
1766
format = BranchFormat.find_format(self, name=name)
1767
return format.get_reference(self, name=name)
1639
format = BranchFormat.find_format(self)
1640
return format.get_reference(self)
1769
def get_branch_transport(self, branch_format, name=None):
1642
def get_branch_transport(self, branch_format):
1770
1643
"""See BzrDir.get_branch_transport()."""
1771
if name is not None:
1772
raise errors.NoColocatedBranchSupport(self)
1773
1644
# XXX: this shouldn't implicitly create the directory if it's just
1774
1645
# promising to get a transport -- mbp 20090727
1775
1646
if branch_format is None:
1813
1684
return self.transport.clone('checkout')
1815
def has_workingtree(self):
1816
"""Tell if this bzrdir contains a working tree.
1818
This will still raise an exception if the bzrdir has a workingtree that
1819
is remote & inaccessible.
1821
Note: if you're going to open the working tree, you should just go
1822
ahead and try, and not ask permission first.
1824
from bzrlib.workingtree import WorkingTreeFormat
1826
WorkingTreeFormat.find_format(self)
1827
except errors.NoWorkingTree:
1831
1686
def needs_format_conversion(self, format=None):
1832
1687
"""See BzrDir.needs_format_conversion()."""
1833
1688
if format is None:
1847
1702
except errors.NoRepositoryPresent:
1849
for branch in self.list_branches():
1850
if not isinstance(branch._format,
1705
if not isinstance(self.open_branch()._format,
1851
1706
format.get_branch_format().__class__):
1852
1707
# the branch needs an upgrade.
1709
except errors.NotBranchError:
1855
1712
my_wt = self.open_workingtree(recommend_upgrade=False)
1856
1713
if not isinstance(my_wt._format,
1864
def open_branch(self, name=None, unsupported=False,
1865
ignore_fallbacks=False):
1721
def open_branch(self, unsupported=False, ignore_fallbacks=False):
1866
1722
"""See BzrDir.open_branch."""
1867
format = self.find_branch_format(name=name)
1723
format = self.find_branch_format()
1868
1724
self._check_supported(format, unsupported)
1869
return format.open(self, name=name,
1870
_found=True, ignore_fallbacks=ignore_fallbacks)
1725
return format.open(self, _found=True, ignore_fallbacks=ignore_fallbacks)
1872
1727
def open_repository(self, unsupported=False):
1873
1728
"""See BzrDir.open_repository."""
1905
1760
Once a format is deprecated, just deprecate the initialize and open
1906
1761
methods on the format class. Do not deprecate the object, as the
1907
1762
object will be created every system load.
1909
:cvar colocated_branches: Whether this formats supports colocated branches.
1912
1765
_default_format = None
1930
1783
_lock_file_name = 'branch-lock'
1932
colocated_branches = False
1933
"""Whether co-located branches are supported for this control dir format.
1936
1785
# _lock_class must be set in subclasses to the lock type, typ.
1937
1786
# TransportLock or LockDir
1955
1804
def probe_transport(klass, transport):
1956
1805
"""Return the .bzrdir style format present in a directory."""
1958
format_string = transport.get_bytes(".bzr/branch-format")
1807
format_string = transport.get(".bzr/branch-format").read()
1959
1808
except errors.NoSuchFile:
1960
1809
raise errors.NotBranchError(path=transport.base)
2737
2586
def convert(self, to_convert, pb):
2738
2587
"""See Converter.convert()."""
2739
2588
self.bzrdir = to_convert
2741
warnings.warn("pb parameter to convert() is deprecated")
2742
self.pb = ui.ui_factory.nested_progress_bar()
2744
ui.ui_factory.note('starting upgrade from format 4 to 5')
2745
if isinstance(self.bzrdir.transport, local.LocalTransport):
2746
self.bzrdir.get_workingtree_transport(None).delete('stat-cache')
2747
self._convert_to_weaves()
2748
return BzrDir.open(self.bzrdir.user_url)
2590
self.pb.note('starting upgrade from format 4 to 5')
2591
if isinstance(self.bzrdir.transport, local.LocalTransport):
2592
self.bzrdir.get_workingtree_transport(None).delete('stat-cache')
2593
self._convert_to_weaves()
2594
return BzrDir.open(self.bzrdir.root_transport.base)
2752
2596
def _convert_to_weaves(self):
2753
ui.ui_factory.note('note: upgrade may be faster if all store files are ungzipped first')
2597
self.pb.note('note: upgrade may be faster if all store files are ungzipped first')
2755
2599
# TODO permissions
2756
2600
stat = self.bzrdir.transport.stat('weaves')
2784
2628
self.pb.clear()
2785
2629
self._write_all_weaves()
2786
2630
self._write_all_revs()
2787
ui.ui_factory.note('upgraded to weaves:')
2788
ui.ui_factory.note(' %6d revisions and inventories' % len(self.revisions))
2789
ui.ui_factory.note(' %6d revisions not present' % len(self.absent_revisions))
2790
ui.ui_factory.note(' %6d texts' % self.text_count)
2631
self.pb.note('upgraded to weaves:')
2632
self.pb.note(' %6d revisions and inventories', len(self.revisions))
2633
self.pb.note(' %6d revisions not present', len(self.absent_revisions))
2634
self.pb.note(' %6d texts', self.text_count)
2791
2635
self._cleanup_spare_files_after_format4()
2792
2636
self.branch._transport.put_bytes(
2793
2637
'branch-format',
2861
2705
len(self.known_revisions))
2862
2706
if not self.branch.repository.has_revision(rev_id):
2863
2707
self.pb.clear()
2864
ui.ui_factory.note('revision {%s} not present in branch; '
2865
'will be converted as a ghost' %
2708
self.pb.note('revision {%s} not present in branch; '
2709
'will be converted as a ghost',
2867
2711
self.absent_revisions.add(rev_id)
2994
2838
def convert(self, to_convert, pb):
2995
2839
"""See Converter.convert()."""
2996
2840
self.bzrdir = to_convert
2997
pb = ui.ui_factory.nested_progress_bar()
2999
ui.ui_factory.note('starting upgrade from format 5 to 6')
3000
self._convert_to_prefixed()
3001
return BzrDir.open(self.bzrdir.user_url)
2842
self.pb.note('starting upgrade from format 5 to 6')
2843
self._convert_to_prefixed()
2844
return BzrDir.open(self.bzrdir.root_transport.base)
3005
2846
def _convert_to_prefixed(self):
3006
2847
from bzrlib.store import TransportStore
3007
2848
self.bzrdir.transport.delete('branch-format')
3008
2849
for store_name in ["weaves", "revision-store"]:
3009
ui.ui_factory.note("adding prefixes to %s" % store_name)
2850
self.pb.note("adding prefixes to %s" % store_name)
3010
2851
store_transport = self.bzrdir.transport.clone(store_name)
3011
2852
store = TransportStore(store_transport, prefixed=True)
3012
2853
for urlfilename in store_transport.list_dir('.'):
3039
2880
from bzrlib.repofmt.weaverepo import RepositoryFormat7
3040
2881
from bzrlib.branch import BzrBranchFormat5
3041
2882
self.bzrdir = to_convert
3042
self.pb = ui.ui_factory.nested_progress_bar()
3044
2885
self.total = 20 # the steps we know about
3045
2886
self.garbage_inventories = []
3046
2887
self.dir_mode = self.bzrdir._get_dir_mode()
3047
2888
self.file_mode = self.bzrdir._get_file_mode()
3049
ui.ui_factory.note('starting upgrade from format 6 to metadir')
2890
self.pb.note('starting upgrade from format 6 to metadir')
3050
2891
self.bzrdir.transport.put_bytes(
3051
2892
'branch-format',
3052
2893
"Converting to format 6",
3103
2944
has_checkout = True
3104
2945
if not has_checkout:
3105
ui.ui_factory.note('No working tree.')
2946
self.pb.note('No working tree.')
3106
2947
# If some checkout files are there, we may as well get rid of them.
3107
2948
for name, mandatory in checkout_files:
3108
2949
if name in bzrcontents:
3125
2966
'branch-format',
3126
2967
BzrDirMetaFormat1().get_format_string(),
3127
2968
mode=self.file_mode)
3129
return BzrDir.open(self.bzrdir.user_url)
2969
return BzrDir.open(self.bzrdir.root_transport.base)
3131
2971
def make_lock(self, name):
3132
2972
"""Make a lock for the new control dir name."""
3167
3007
def convert(self, to_convert, pb):
3168
3008
"""See Converter.convert()."""
3169
3009
self.bzrdir = to_convert
3170
self.pb = ui.ui_factory.nested_progress_bar()
3173
3013
self.step('checking repository format')
3179
3019
if not isinstance(repo._format, self.target_format.repository_format.__class__):
3180
3020
from bzrlib.repository import CopyConverter
3181
ui.ui_factory.note('starting repository conversion')
3021
self.pb.note('starting repository conversion')
3182
3022
converter = CopyConverter(self.target_format.repository_format)
3183
3023
converter.convert(repo, pb)
3184
for branch in self.bzrdir.list_branches():
3025
branch = self.bzrdir.open_branch()
3026
except errors.NotBranchError:
3185
3029
# TODO: conversions of Branch and Tree should be done by
3186
3030
# InterXFormat lookups/some sort of registry.
3187
3031
# Avoid circular imports
3243
3086
def __init__(self):
3244
3087
BzrDirMetaFormat1.__init__(self)
3245
# XXX: It's a bit ugly that the network name is here, because we'd
3246
# like to believe that format objects are stateless or at least
3247
# immutable, However, we do at least avoid mutating the name after
3248
# it's returned. See <https://bugs.edge.launchpad.net/bzr/+bug/504102>
3249
3088
self._network_name = None
3252
return "%s(_network_name=%r)" % (self.__class__.__name__,
3255
3090
def get_format_description(self):
3256
if self._network_name:
3257
real_format = network_format_registry.get(self._network_name)
3258
return 'Remote: ' + real_format.get_format_description()
3259
3091
return 'bzr remote bzrdir'
3261
3093
def get_format_string(self):
3394
3226
args.append(self._serialize_NoneString(repo_format_name))
3395
3227
args.append(self._serialize_NoneTrueFalse(make_working_trees))
3396
3228
args.append(self._serialize_NoneTrueFalse(shared_repo))
3397
request_network_name = self._network_name or \
3229
if self._network_name is None:
3230
self._network_name = \
3398
3231
BzrDirFormat.get_default_format().network_name()
3400
3233
response = client.call('BzrDirFormat.initialize_ex_1.16',
3401
request_network_name, path, *args)
3234
self.network_name(), path, *args)
3402
3235
except errors.UnknownSmartMethod:
3403
3236
client._medium._remember_remote_is_before((1,16))
3404
3237
local_dir_format = BzrDirMetaFormat1()
3654
3487
experimental_pairs.append((key, help))
3656
3489
output += wrapped(key, help, info)
3657
output += "\nSee :doc:`formats-help` for more about storage formats."
3490
output += "\nSee ``bzr help formats`` for more about storage formats."
3658
3491
other_output = ""
3659
3492
if len(experimental_pairs) > 0:
3660
3493
other_output += "Experimental formats are shown below.\n\n"
3714
3547
stack_on = urlutils.rebase_url(self._stack_on,
3715
3548
self._stack_on_pwd,
3549
branch.bzrdir.root_transport.base)
3717
3550
except errors.InvalidRebaseURLs:
3718
3551
stack_on = self._get_full_stack_on()
3848
3681
format_registry.register('weave', BzrDirFormat6,
3849
3682
'Pre-0.8 format. Slower than knit and does not'
3850
3683
' support checkouts or shared repositories.',
3852
3684
deprecated=True)
3853
3685
format_registry.register_metadir('metaweave',
3854
3686
'bzrlib.repofmt.weaverepo.RepositoryFormat7',
3855
3687
'Transitional format in 0.8. Slower than knit.',
3856
3688
branch_format='bzrlib.branch.BzrBranchFormat5',
3857
3689
tree_format='bzrlib.workingtree.WorkingTreeFormat3',
3859
3690
deprecated=True)
3860
3691
format_registry.register_metadir('knit',
3861
3692
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit1',
3862
3693
'Format using knits. Recommended for interoperation with bzr <= 0.14.',
3863
3694
branch_format='bzrlib.branch.BzrBranchFormat5',
3864
3695
tree_format='bzrlib.workingtree.WorkingTreeFormat3',
3866
3696
deprecated=True)
3867
3697
format_registry.register_metadir('dirstate',
3868
3698
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit1',
3872
3702
# this uses bzrlib.workingtree.WorkingTreeFormat4 because importing
3873
3703
# directly from workingtree_4 triggers a circular import.
3874
3704
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3876
3705
deprecated=True)
3877
3706
format_registry.register_metadir('dirstate-tags',
3878
3707
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit1',
3881
3710
' Incompatible with bzr < 0.15.',
3882
3711
branch_format='bzrlib.branch.BzrBranchFormat6',
3883
3712
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3885
3713
deprecated=True)
3886
3714
format_registry.register_metadir('rich-root',
3887
3715
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit4',
3890
3718
branch_format='bzrlib.branch.BzrBranchFormat6',
3891
3719
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3893
3720
deprecated=True)
3894
3721
format_registry.register_metadir('dirstate-with-subtree',
3895
3722
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit3',
3906
3733
help='New in 0.92: Pack-based format with data compatible with '
3907
3734
'dirstate-tags format repositories. Interoperates with '
3908
3735
'bzr repositories before 0.92 but cannot be read by bzr < 0.92. '
3736
'Previously called knitpack-experimental. '
3737
'For more information, see '
3738
'http://doc.bazaar-vcs.org/latest/developers/packrepo.html.',
3910
3739
branch_format='bzrlib.branch.BzrBranchFormat6',
3911
3740
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3915
3744
help='New in 0.92: Pack-based format with data compatible with '
3916
3745
'dirstate-with-subtree format repositories. Interoperates with '
3917
3746
'bzr repositories before 0.92 but cannot be read by bzr < 0.92. '
3747
'Previously called knitpack-experimental. '
3748
'For more information, see '
3749
'http://doc.bazaar-vcs.org/latest/developers/packrepo.html.',
3919
3750
branch_format='bzrlib.branch.BzrBranchFormat6',
3920
3751
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3927
3758
'(needed for bzr-svn and bzr-git).',
3928
3759
branch_format='bzrlib.branch.BzrBranchFormat6',
3929
3760
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3932
3762
format_registry.register_metadir('1.6',
3933
3763
'bzrlib.repofmt.pack_repo.RepositoryFormatKnitPack5',
3936
3766
'not present locally.',
3937
3767
branch_format='bzrlib.branch.BzrBranchFormat7',
3938
3768
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3941
3770
format_registry.register_metadir('1.6.1-rich-root',
3942
3771
'bzrlib.repofmt.pack_repo.RepositoryFormatKnitPack5RichRoot',
3944
3773
'(needed for bzr-svn and bzr-git).',
3945
3774
branch_format='bzrlib.branch.BzrBranchFormat7',
3946
3775
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3949
3777
format_registry.register_metadir('1.9',
3950
3778
'bzrlib.repofmt.pack_repo.RepositoryFormatKnitPack6',
3953
3781
'performance for most operations.',
3954
3782
branch_format='bzrlib.branch.BzrBranchFormat7',
3955
3783
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3958
3785
format_registry.register_metadir('1.9-rich-root',
3959
3786
'bzrlib.repofmt.pack_repo.RepositoryFormatKnitPack6RichRoot',
3961
3788
'(needed for bzr-svn and bzr-git).',
3962
3789
branch_format='bzrlib.branch.BzrBranchFormat7',
3963
3790
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3966
3792
format_registry.register_metadir('1.14',
3967
3793
'bzrlib.repofmt.pack_repo.RepositoryFormatKnitPack6',
3983
3809
'to and from rich-root-pack (and anything compatible with '
3984
3810
'rich-root-pack) format repositories. Repositories and branches in '
3985
3811
'this format can only be read by bzr.dev. Please read '
3986
'http://doc.bazaar.canonical.com/latest/developers/development-repo.html '
3812
'http://doc.bazaar-vcs.org/latest/developers/development-repo.html '
3988
3814
branch_format='bzrlib.branch.BzrBranchFormat7',
3989
3815
tree_format='bzrlib.workingtree.WorkingTreeFormat6',
3990
3816
experimental=True,
3994
3819
format_registry.register_metadir('development-subtree',
3995
3820
'bzrlib.repofmt.pack_repo.RepositoryFormatPackDevelopment2Subtree',
3997
3822
'from pack-0.92-subtree (and anything compatible with '
3998
3823
'pack-0.92-subtree) format repositories. Repositories and branches in '
3999
3824
'this format can only be read by bzr.dev. Please read '
4000
'http://doc.bazaar.canonical.com/latest/developers/development-repo.html '
3825
'http://doc.bazaar-vcs.org/latest/developers/development-repo.html '
4002
3827
branch_format='bzrlib.branch.BzrBranchFormat7',
4003
3828
tree_format='bzrlib.workingtree.WorkingTreeFormat6',
4004
3829
experimental=True,
4006
3830
alias=False, # Restore to being an alias when an actual development subtree format is added
4007
3831
# This current non-alias status is simply because we did not introduce a
4008
3832
# chk based subtree format.
4013
3837
'bzrlib.repofmt.groupcompress_repo.RepositoryFormatCHK1',
4014
3838
help='pack-1.9 with 255-way hashed CHK inv, group compress, rich roots '
4016
'http://doc.bazaar.canonical.com/latest/developers/development-repo.html '
3840
'http://doc.bazaar-vcs.org/latest/developers/development-repo.html '
4018
3842
branch_format='bzrlib.branch.BzrBranchFormat7',
4019
3843
tree_format='bzrlib.workingtree.WorkingTreeFormat6',
4025
3849
'bzrlib.repofmt.groupcompress_repo.RepositoryFormatCHK2',
4026
3850
help='pack-1.9 with 255-way hashed CHK inv, bencode revision, group compress, '
4027
3851
'rich roots. Please read '
4028
'http://doc.bazaar.canonical.com/latest/developers/development-repo.html '
3852
'http://doc.bazaar-vcs.org/latest/developers/development-repo.html '
4030
3854
branch_format='bzrlib.branch.BzrBranchFormat7',
4031
3855
tree_format='bzrlib.workingtree.WorkingTreeFormat6',