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
636
581
# a new backup directory.
638
583
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)
584
new_path = self.root_transport.abspath('backup.bzr')
585
pb.note('making backup of %s' % (old_path,))
586
pb.note(' to %s' % (new_path,))
587
self.root_transport.copy_tree('.bzr', 'backup.bzr')
642
588
return (old_path, new_path)
704
650
next_transport = found_bzrdir.root_transport.clone('..')
705
if (found_bzrdir.user_url == next_transport.base):
651
if (found_bzrdir.root_transport.base == next_transport.base):
706
652
# top of the file system
708
654
# find the next containing bzrdir
725
671
repository = found_bzrdir.open_repository()
726
672
except errors.NoRepositoryPresent:
727
673
return None, False
728
if found_bzrdir.user_url == self.user_url:
674
if found_bzrdir.root_transport.base == self.root_transport.base:
729
675
return repository, True
730
676
elif repository.is_shared():
731
677
return repository, True
749
def get_branch_transport(self, branch_format, name=None):
695
def get_branch_transport(self, branch_format):
750
696
"""Get the transport for use by branch format in this BzrDir.
752
698
Note that bzr dirs that do not support format strings will raise
847
793
:param _transport: the transport this dir is based at.
849
795
self._format = _format
850
# these are also under the more standard names of
851
# control_transport and user_transport
852
796
self.transport = _transport.clone('.bzr')
853
797
self.root_transport = _transport
854
798
self._mode_check_done = False
857
def user_transport(self):
858
return self.root_transport
861
def control_transport(self):
862
return self.transport
864
800
def is_control_filename(self, filename):
865
801
"""True if filename is the name of a path which is reserved for bzrdir's.
940
876
BzrDir._check_supported(format, _unsupported)
941
877
return format.open(transport, _found=True)
943
def open_branch(self, name=None, unsupported=False,
944
ignore_fallbacks=False):
879
def open_branch(self, unsupported=False, ignore_fallbacks=False):
945
880
"""Open the branch object at this BzrDir if one is present.
947
882
If unsupported is True, then no longer supported branch formats can
1086
1021
raise NotImplementedError(self.open_workingtree)
1088
def has_branch(self, name=None):
1023
def has_branch(self):
1089
1024
"""Tell if this bzrdir contains a branch.
1091
1026
Note: if you're going to open the branch, you should just go ahead
1373
1308
self.create_hook(hooks.HookPoint('pre_open',
1374
1309
"Invoked before attempting to open a BzrDir with the transport "
1375
1310
"that the open will use.", (1, 14), None))
1376
self.create_hook(hooks.HookPoint('post_repo_init',
1377
"Invoked after a repository has been initialized. "
1378
"post_repo_init is called with a "
1379
"bzrlib.bzrdir.RepoInitHookParams.",
1382
1312
# install the default hooks
1383
1313
BzrDir.hooks = BzrDirHooks()
1386
class RepoInitHookParams(object):
1387
"""Object holding parameters passed to *_repo_init hooks.
1389
There are 4 fields that hooks may wish to access:
1391
:ivar repository: Repository created
1392
:ivar format: Repository format
1393
:ivar bzrdir: The bzrdir for the repository
1394
:ivar shared: The repository is shared
1397
def __init__(self, repository, format, a_bzrdir, shared):
1398
"""Create a group of RepoInitHook parameters.
1400
:param repository: Repository created
1401
:param format: Repository format
1402
:param bzrdir: The bzrdir for the repository
1403
:param shared: The repository is shared
1405
self.repository = repository
1406
self.format = format
1407
self.bzrdir = a_bzrdir
1408
self.shared = shared
1410
def __eq__(self, other):
1411
return self.__dict__ == other.__dict__
1415
return "<%s for %s>" % (self.__class__.__name__,
1418
return "<%s for %s>" % (self.__class__.__name__,
1422
1316
class BzrDirPreSplitOut(BzrDir):
1423
1317
"""A common class for the all-in-one formats."""
1463
1357
tree.clone(result)
1466
def create_branch(self, name=None):
1360
def create_branch(self):
1467
1361
"""See BzrDir.create_branch."""
1468
return self._format.get_branch_format().initialize(self, name=name)
1362
return self._format.get_branch_format().initialize(self)
1470
def destroy_branch(self, name=None):
1364
def destroy_branch(self):
1471
1365
"""See BzrDir.destroy_branch."""
1472
1366
raise errors.UnsupportedOperation(self.destroy_branch, self)
1529
1423
raise errors.UnsupportedOperation(self.destroy_workingtree_metadata,
1532
def get_branch_transport(self, branch_format, name=None):
1426
def get_branch_transport(self, branch_format):
1533
1427
"""See BzrDir.get_branch_transport()."""
1534
if name is not None:
1535
raise errors.NoColocatedBranchSupport(self)
1536
1428
if branch_format is None:
1537
1429
return self.transport
1571
1463
format = BzrDirFormat.get_default_format()
1572
1464
return not isinstance(self._format, format.__class__)
1574
def open_branch(self, name=None, unsupported=False,
1575
ignore_fallbacks=False):
1466
def open_branch(self, unsupported=False, ignore_fallbacks=False):
1576
1467
"""See BzrDir.open_branch."""
1577
1468
from bzrlib.branch import BzrBranchFormat4
1578
1469
format = BzrBranchFormat4()
1579
1470
self._check_supported(format, unsupported)
1580
return format.open(self, name, _found=True)
1471
return format.open(self, _found=True)
1582
1473
def sprout(self, url, revision_id=None, force_new_repo=False,
1583
1474
possible_transports=None, accelerator_tree=None,
1644
1535
This is a deprecated format and may be removed after sept 2006.
1647
def has_workingtree(self):
1648
"""See BzrDir.has_workingtree."""
1651
1538
def open_repository(self):
1652
1539
"""See BzrDir.open_repository."""
1653
1540
from bzrlib.repofmt.weaverepo import RepositoryFormat5
1669
1556
This is a deprecated format and may be removed after sept 2006.
1672
def has_workingtree(self):
1673
"""See BzrDir.has_workingtree."""
1676
1559
def open_repository(self):
1677
1560
"""See BzrDir.open_repository."""
1678
1561
from bzrlib.repofmt.weaverepo import RepositoryFormat6
1700
1583
"""See BzrDir.can_convert_format()."""
1703
def create_branch(self, name=None):
1586
def create_branch(self):
1704
1587
"""See BzrDir.create_branch."""
1705
return self._format.get_branch_format().initialize(self, name=name)
1588
return self._format.get_branch_format().initialize(self)
1707
def destroy_branch(self, name=None):
1590
def destroy_branch(self):
1708
1591
"""See BzrDir.create_branch."""
1709
if name is not None:
1710
raise errors.NoColocatedBranchSupport(self)
1711
1592
self.transport.delete_tree('branch')
1713
1594
def create_repository(self, shared=False):
1756
1637
format = BranchFormat.find_format(self)
1757
1638
return format.get_reference(self)
1759
def get_branch_transport(self, branch_format, name=None):
1640
def get_branch_transport(self, branch_format):
1760
1641
"""See BzrDir.get_branch_transport()."""
1761
if name is not None:
1762
raise errors.NoColocatedBranchSupport(self)
1763
1642
# XXX: this shouldn't implicitly create the directory if it's just
1764
1643
# promising to get a transport -- mbp 20090727
1765
1644
if branch_format is None:
1803
1682
return self.transport.clone('checkout')
1805
def has_workingtree(self):
1806
"""Tell if this bzrdir contains a working tree.
1808
This will still raise an exception if the bzrdir has a workingtree that
1809
is remote & inaccessible.
1811
Note: if you're going to open the working tree, you should just go
1812
ahead and try, and not ask permission first.
1814
from bzrlib.workingtree import WorkingTreeFormat
1816
WorkingTreeFormat.find_format(self)
1817
except errors.NoWorkingTree:
1821
1684
def needs_format_conversion(self, format=None):
1822
1685
"""See BzrDir.needs_format_conversion()."""
1823
1686
if format is None:
1837
1700
except errors.NoRepositoryPresent:
1839
for branch in self.list_branches():
1840
if not isinstance(branch._format,
1703
if not isinstance(self.open_branch()._format,
1841
1704
format.get_branch_format().__class__):
1842
1705
# the branch needs an upgrade.
1707
except errors.NotBranchError:
1845
1710
my_wt = self.open_workingtree(recommend_upgrade=False)
1846
1711
if not isinstance(my_wt._format,
1854
def open_branch(self, name=None, unsupported=False,
1855
ignore_fallbacks=False):
1719
def open_branch(self, unsupported=False, ignore_fallbacks=False):
1856
1720
"""See BzrDir.open_branch."""
1857
1721
format = self.find_branch_format()
1858
1722
self._check_supported(format, unsupported)
1859
return format.open(self, name=name,
1860
_found=True, ignore_fallbacks=ignore_fallbacks)
1723
return format.open(self, _found=True, ignore_fallbacks=ignore_fallbacks)
1862
1725
def open_repository(self, unsupported=False):
1863
1726
"""See BzrDir.open_repository."""
1895
1758
Once a format is deprecated, just deprecate the initialize and open
1896
1759
methods on the format class. Do not deprecate the object, as the
1897
1760
object will be created every system load.
1899
:cvar colocated_branches: Whether this formats supports colocated branches.
1902
1763
_default_format = None
1920
1781
_lock_file_name = 'branch-lock'
1922
colocated_branches = False
1923
"""Whether co-located branches are supported for this control dir format.
1926
1783
# _lock_class must be set in subclasses to the lock type, typ.
1927
1784
# TransportLock or LockDir
1945
1802
def probe_transport(klass, transport):
1946
1803
"""Return the .bzrdir style format present in a directory."""
1948
format_string = transport.get_bytes(".bzr/branch-format")
1805
format_string = transport.get(".bzr/branch-format").read()
1949
1806
except errors.NoSuchFile:
1950
1807
raise errors.NotBranchError(path=transport.base)
2727
2584
def convert(self, to_convert, pb):
2728
2585
"""See Converter.convert()."""
2729
2586
self.bzrdir = to_convert
2731
warnings.warn("pb parameter to convert() is deprecated")
2732
self.pb = ui.ui_factory.nested_progress_bar()
2734
ui.ui_factory.note('starting upgrade from format 4 to 5')
2735
if isinstance(self.bzrdir.transport, local.LocalTransport):
2736
self.bzrdir.get_workingtree_transport(None).delete('stat-cache')
2737
self._convert_to_weaves()
2738
return BzrDir.open(self.bzrdir.user_url)
2588
self.pb.note('starting upgrade from format 4 to 5')
2589
if isinstance(self.bzrdir.transport, local.LocalTransport):
2590
self.bzrdir.get_workingtree_transport(None).delete('stat-cache')
2591
self._convert_to_weaves()
2592
return BzrDir.open(self.bzrdir.root_transport.base)
2742
2594
def _convert_to_weaves(self):
2743
ui.ui_factory.note('note: upgrade may be faster if all store files are ungzipped first')
2595
self.pb.note('note: upgrade may be faster if all store files are ungzipped first')
2745
2597
# TODO permissions
2746
2598
stat = self.bzrdir.transport.stat('weaves')
2774
2626
self.pb.clear()
2775
2627
self._write_all_weaves()
2776
2628
self._write_all_revs()
2777
ui.ui_factory.note('upgraded to weaves:')
2778
ui.ui_factory.note(' %6d revisions and inventories' % len(self.revisions))
2779
ui.ui_factory.note(' %6d revisions not present' % len(self.absent_revisions))
2780
ui.ui_factory.note(' %6d texts' % self.text_count)
2629
self.pb.note('upgraded to weaves:')
2630
self.pb.note(' %6d revisions and inventories', len(self.revisions))
2631
self.pb.note(' %6d revisions not present', len(self.absent_revisions))
2632
self.pb.note(' %6d texts', self.text_count)
2781
2633
self._cleanup_spare_files_after_format4()
2782
2634
self.branch._transport.put_bytes(
2783
2635
'branch-format',
2851
2703
len(self.known_revisions))
2852
2704
if not self.branch.repository.has_revision(rev_id):
2853
2705
self.pb.clear()
2854
ui.ui_factory.note('revision {%s} not present in branch; '
2855
'will be converted as a ghost' %
2706
self.pb.note('revision {%s} not present in branch; '
2707
'will be converted as a ghost',
2857
2709
self.absent_revisions.add(rev_id)
2984
2836
def convert(self, to_convert, pb):
2985
2837
"""See Converter.convert()."""
2986
2838
self.bzrdir = to_convert
2987
pb = ui.ui_factory.nested_progress_bar()
2989
ui.ui_factory.note('starting upgrade from format 5 to 6')
2990
self._convert_to_prefixed()
2991
return BzrDir.open(self.bzrdir.user_url)
2840
self.pb.note('starting upgrade from format 5 to 6')
2841
self._convert_to_prefixed()
2842
return BzrDir.open(self.bzrdir.root_transport.base)
2995
2844
def _convert_to_prefixed(self):
2996
2845
from bzrlib.store import TransportStore
2997
2846
self.bzrdir.transport.delete('branch-format')
2998
2847
for store_name in ["weaves", "revision-store"]:
2999
ui.ui_factory.note("adding prefixes to %s" % store_name)
2848
self.pb.note("adding prefixes to %s" % store_name)
3000
2849
store_transport = self.bzrdir.transport.clone(store_name)
3001
2850
store = TransportStore(store_transport, prefixed=True)
3002
2851
for urlfilename in store_transport.list_dir('.'):
3029
2878
from bzrlib.repofmt.weaverepo import RepositoryFormat7
3030
2879
from bzrlib.branch import BzrBranchFormat5
3031
2880
self.bzrdir = to_convert
3032
self.pb = ui.ui_factory.nested_progress_bar()
3034
2883
self.total = 20 # the steps we know about
3035
2884
self.garbage_inventories = []
3036
2885
self.dir_mode = self.bzrdir._get_dir_mode()
3037
2886
self.file_mode = self.bzrdir._get_file_mode()
3039
ui.ui_factory.note('starting upgrade from format 6 to metadir')
2888
self.pb.note('starting upgrade from format 6 to metadir')
3040
2889
self.bzrdir.transport.put_bytes(
3041
2890
'branch-format',
3042
2891
"Converting to format 6",
3093
2942
has_checkout = True
3094
2943
if not has_checkout:
3095
ui.ui_factory.note('No working tree.')
2944
self.pb.note('No working tree.')
3096
2945
# If some checkout files are there, we may as well get rid of them.
3097
2946
for name, mandatory in checkout_files:
3098
2947
if name in bzrcontents:
3115
2964
'branch-format',
3116
2965
BzrDirMetaFormat1().get_format_string(),
3117
2966
mode=self.file_mode)
3119
return BzrDir.open(self.bzrdir.user_url)
2967
return BzrDir.open(self.bzrdir.root_transport.base)
3121
2969
def make_lock(self, name):
3122
2970
"""Make a lock for the new control dir name."""
3157
3005
def convert(self, to_convert, pb):
3158
3006
"""See Converter.convert()."""
3159
3007
self.bzrdir = to_convert
3160
self.pb = ui.ui_factory.nested_progress_bar()
3163
3011
self.step('checking repository format')
3169
3017
if not isinstance(repo._format, self.target_format.repository_format.__class__):
3170
3018
from bzrlib.repository import CopyConverter
3171
ui.ui_factory.note('starting repository conversion')
3019
self.pb.note('starting repository conversion')
3172
3020
converter = CopyConverter(self.target_format.repository_format)
3173
3021
converter.convert(repo, pb)
3174
for branch in self.bzrdir.list_branches():
3023
branch = self.bzrdir.open_branch()
3024
except errors.NotBranchError:
3175
3027
# TODO: conversions of Branch and Tree should be done by
3176
3028
# InterXFormat lookups/some sort of registry.
3177
3029
# Avoid circular imports
3233
3084
def __init__(self):
3234
3085
BzrDirMetaFormat1.__init__(self)
3235
# XXX: It's a bit ugly that the network name is here, because we'd
3236
# like to believe that format objects are stateless or at least
3237
# immutable, However, we do at least avoid mutating the name after
3238
# it's returned. See <https://bugs.edge.launchpad.net/bzr/+bug/504102>
3239
3086
self._network_name = None
3242
return "%s(_network_name=%r)" % (self.__class__.__name__,
3245
3088
def get_format_description(self):
3246
if self._network_name:
3247
real_format = network_format_registry.get(self._network_name)
3248
return 'Remote: ' + real_format.get_format_description()
3249
3089
return 'bzr remote bzrdir'
3251
3091
def get_format_string(self):
3384
3224
args.append(self._serialize_NoneString(repo_format_name))
3385
3225
args.append(self._serialize_NoneTrueFalse(make_working_trees))
3386
3226
args.append(self._serialize_NoneTrueFalse(shared_repo))
3387
request_network_name = self._network_name or \
3227
if self._network_name is None:
3228
self._network_name = \
3388
3229
BzrDirFormat.get_default_format().network_name()
3390
3231
response = client.call('BzrDirFormat.initialize_ex_1.16',
3391
request_network_name, path, *args)
3232
self.network_name(), path, *args)
3392
3233
except errors.UnknownSmartMethod:
3393
3234
client._medium._remember_remote_is_before((1,16))
3394
3235
local_dir_format = BzrDirMetaFormat1()
3644
3485
experimental_pairs.append((key, help))
3646
3487
output += wrapped(key, help, info)
3647
output += "\nSee :doc:`formats-help` for more about storage formats."
3488
output += "\nSee ``bzr help formats`` for more about storage formats."
3648
3489
other_output = ""
3649
3490
if len(experimental_pairs) > 0:
3650
3491
other_output += "Experimental formats are shown below.\n\n"
3704
3545
stack_on = urlutils.rebase_url(self._stack_on,
3705
3546
self._stack_on_pwd,
3547
branch.bzrdir.root_transport.base)
3707
3548
except errors.InvalidRebaseURLs:
3708
3549
stack_on = self._get_full_stack_on()
3838
3679
format_registry.register('weave', BzrDirFormat6,
3839
3680
'Pre-0.8 format. Slower than knit and does not'
3840
3681
' support checkouts or shared repositories.',
3842
3682
deprecated=True)
3843
3683
format_registry.register_metadir('metaweave',
3844
3684
'bzrlib.repofmt.weaverepo.RepositoryFormat7',
3845
3685
'Transitional format in 0.8. Slower than knit.',
3846
3686
branch_format='bzrlib.branch.BzrBranchFormat5',
3847
3687
tree_format='bzrlib.workingtree.WorkingTreeFormat3',
3849
3688
deprecated=True)
3850
3689
format_registry.register_metadir('knit',
3851
3690
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit1',
3852
3691
'Format using knits. Recommended for interoperation with bzr <= 0.14.',
3853
3692
branch_format='bzrlib.branch.BzrBranchFormat5',
3854
3693
tree_format='bzrlib.workingtree.WorkingTreeFormat3',
3856
3694
deprecated=True)
3857
3695
format_registry.register_metadir('dirstate',
3858
3696
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit1',
3862
3700
# this uses bzrlib.workingtree.WorkingTreeFormat4 because importing
3863
3701
# directly from workingtree_4 triggers a circular import.
3864
3702
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3866
3703
deprecated=True)
3867
3704
format_registry.register_metadir('dirstate-tags',
3868
3705
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit1',
3871
3708
' Incompatible with bzr < 0.15.',
3872
3709
branch_format='bzrlib.branch.BzrBranchFormat6',
3873
3710
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3875
3711
deprecated=True)
3876
3712
format_registry.register_metadir('rich-root',
3877
3713
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit4',
3880
3716
branch_format='bzrlib.branch.BzrBranchFormat6',
3881
3717
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3883
3718
deprecated=True)
3884
3719
format_registry.register_metadir('dirstate-with-subtree',
3885
3720
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit3',
3896
3731
help='New in 0.92: Pack-based format with data compatible with '
3897
3732
'dirstate-tags format repositories. Interoperates with '
3898
3733
'bzr repositories before 0.92 but cannot be read by bzr < 0.92. '
3734
'Previously called knitpack-experimental. '
3735
'For more information, see '
3736
'http://doc.bazaar-vcs.org/latest/developers/packrepo.html.',
3900
3737
branch_format='bzrlib.branch.BzrBranchFormat6',
3901
3738
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3905
3742
help='New in 0.92: Pack-based format with data compatible with '
3906
3743
'dirstate-with-subtree format repositories. Interoperates with '
3907
3744
'bzr repositories before 0.92 but cannot be read by bzr < 0.92. '
3745
'Previously called knitpack-experimental. '
3746
'For more information, see '
3747
'http://doc.bazaar-vcs.org/latest/developers/packrepo.html.',
3909
3748
branch_format='bzrlib.branch.BzrBranchFormat6',
3910
3749
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3917
3756
'(needed for bzr-svn and bzr-git).',
3918
3757
branch_format='bzrlib.branch.BzrBranchFormat6',
3919
3758
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3922
3760
format_registry.register_metadir('1.6',
3923
3761
'bzrlib.repofmt.pack_repo.RepositoryFormatKnitPack5',
3926
3764
'not present locally.',
3927
3765
branch_format='bzrlib.branch.BzrBranchFormat7',
3928
3766
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3931
3768
format_registry.register_metadir('1.6.1-rich-root',
3932
3769
'bzrlib.repofmt.pack_repo.RepositoryFormatKnitPack5RichRoot',
3934
3771
'(needed for bzr-svn and bzr-git).',
3935
3772
branch_format='bzrlib.branch.BzrBranchFormat7',
3936
3773
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3939
3775
format_registry.register_metadir('1.9',
3940
3776
'bzrlib.repofmt.pack_repo.RepositoryFormatKnitPack6',
3943
3779
'performance for most operations.',
3944
3780
branch_format='bzrlib.branch.BzrBranchFormat7',
3945
3781
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3948
3783
format_registry.register_metadir('1.9-rich-root',
3949
3784
'bzrlib.repofmt.pack_repo.RepositoryFormatKnitPack6RichRoot',
3951
3786
'(needed for bzr-svn and bzr-git).',
3952
3787
branch_format='bzrlib.branch.BzrBranchFormat7',
3953
3788
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3956
3790
format_registry.register_metadir('1.14',
3957
3791
'bzrlib.repofmt.pack_repo.RepositoryFormatKnitPack6',
3973
3807
'to and from rich-root-pack (and anything compatible with '
3974
3808
'rich-root-pack) format repositories. Repositories and branches in '
3975
3809
'this format can only be read by bzr.dev. Please read '
3976
'http://doc.bazaar.canonical.com/latest/developers/development-repo.html '
3810
'http://doc.bazaar-vcs.org/latest/developers/development-repo.html '
3978
3812
branch_format='bzrlib.branch.BzrBranchFormat7',
3979
3813
tree_format='bzrlib.workingtree.WorkingTreeFormat6',
3980
3814
experimental=True,
3984
3817
format_registry.register_metadir('development-subtree',
3985
3818
'bzrlib.repofmt.pack_repo.RepositoryFormatPackDevelopment2Subtree',
3987
3820
'from pack-0.92-subtree (and anything compatible with '
3988
3821
'pack-0.92-subtree) format repositories. Repositories and branches in '
3989
3822
'this format can only be read by bzr.dev. Please read '
3990
'http://doc.bazaar.canonical.com/latest/developers/development-repo.html '
3823
'http://doc.bazaar-vcs.org/latest/developers/development-repo.html '
3992
3825
branch_format='bzrlib.branch.BzrBranchFormat7',
3993
3826
tree_format='bzrlib.workingtree.WorkingTreeFormat6',
3994
3827
experimental=True,
3996
3828
alias=False, # Restore to being an alias when an actual development subtree format is added
3997
3829
# This current non-alias status is simply because we did not introduce a
3998
3830
# chk based subtree format.
4003
3835
'bzrlib.repofmt.groupcompress_repo.RepositoryFormatCHK1',
4004
3836
help='pack-1.9 with 255-way hashed CHK inv, group compress, rich roots '
4006
'http://doc.bazaar.canonical.com/latest/developers/development-repo.html '
3838
'http://doc.bazaar-vcs.org/latest/developers/development-repo.html '
4008
3840
branch_format='bzrlib.branch.BzrBranchFormat7',
4009
3841
tree_format='bzrlib.workingtree.WorkingTreeFormat6',
4015
3847
'bzrlib.repofmt.groupcompress_repo.RepositoryFormatCHK2',
4016
3848
help='pack-1.9 with 255-way hashed CHK inv, bencode revision, group compress, '
4017
3849
'rich roots. Please read '
4018
'http://doc.bazaar.canonical.com/latest/developers/development-repo.html '
3850
'http://doc.bazaar-vcs.org/latest/developers/development-repo.html '
4020
3852
branch_format='bzrlib.branch.BzrBranchFormat7',
4021
3853
tree_format='bzrlib.workingtree.WorkingTreeFormat6',