381
364
except errors.NoRepositoryPresent:
384
return False, ([], repository)
385
return True, (bzrdir.list_branches(), None)
387
for branches, repo in BzrDir.find_bzrdirs(transport,
367
return False, (None, repository)
369
branch = bzrdir.open_branch()
370
except errors.NotBranchError:
371
return True, (None, None)
373
return True, (branch, None)
375
for branch, repo in BzrDir.find_bzrdirs(transport, evaluate=evaluate):
389
376
if repo is not None:
390
ret.extend(repo.find_branches())
391
if branches is not None:
377
branches.extend(repo.find_branches())
378
if branch is not None:
379
branches.append(branch)
395
382
def destroy_repository(self):
396
383
"""Destroy the repository in this BzrDir"""
2399
2358
def set_branch_format(self, format):
2400
2359
self._branch_format = format
2402
def require_stacking(self, stack_on=None, possible_transports=None,
2404
"""We have a request to stack, try to ensure the formats support it.
2406
:param stack_on: If supplied, it is the URL to a branch that we want to
2407
stack on. Check to see if that format supports stacking before
2410
# Stacking is desired. requested by the target, but does the place it
2411
# points at support stacking? If it doesn't then we should
2412
# not implicitly upgrade. We check this here.
2413
new_repo_format = None
2414
new_branch_format = None
2416
# a bit of state for get_target_branch so that we don't try to open it
2417
# 2 times, for both repo *and* branch
2418
target = [None, False, None] # target_branch, checked, upgrade anyway
2419
def get_target_branch():
2421
# We've checked, don't check again
2423
if stack_on is None:
2424
# No target format, that means we want to force upgrading
2425
target[:] = [None, True, True]
2428
target_dir = BzrDir.open(stack_on,
2429
possible_transports=possible_transports)
2430
except errors.NotBranchError:
2431
# Nothing there, don't change formats
2432
target[:] = [None, True, False]
2434
except errors.JailBreak:
2435
# JailBreak, JFDI and upgrade anyway
2436
target[:] = [None, True, True]
2439
target_branch = target_dir.open_branch()
2440
except errors.NotBranchError:
2441
# No branch, don't upgrade formats
2442
target[:] = [None, True, False]
2444
target[:] = [target_branch, True, False]
2447
if (not _skip_repo and
2448
not self.repository_format.supports_external_lookups):
2449
# We need to upgrade the Repository.
2450
target_branch, _, do_upgrade = get_target_branch()
2451
if target_branch is None:
2452
# We don't have a target branch, should we upgrade anyway?
2454
# stack_on is inaccessible, JFDI.
2455
# TODO: bad monkey, hard-coded formats...
2456
if self.repository_format.rich_root_data:
2457
new_repo_format = pack_repo.RepositoryFormatKnitPack5RichRoot()
2459
new_repo_format = pack_repo.RepositoryFormatKnitPack5()
2461
# If the target already supports stacking, then we know the
2462
# project is already able to use stacking, so auto-upgrade
2464
new_repo_format = target_branch.repository._format
2465
if not new_repo_format.supports_external_lookups:
2466
# target doesn't, source doesn't, so don't auto upgrade
2468
new_repo_format = None
2469
if new_repo_format is not None:
2470
self.repository_format = new_repo_format
2471
note('Source repository format does not support stacking,'
2472
' using format:\n %s',
2473
new_repo_format.get_format_description())
2361
def require_stacking(self):
2475
2362
if not self.get_branch_format().supports_stacking():
2476
# We just checked the repo, now lets check if we need to
2477
# upgrade the branch format
2478
target_branch, _, do_upgrade = get_target_branch()
2479
if target_branch is None:
2481
# TODO: bad monkey, hard-coded formats...
2482
new_branch_format = branch.BzrBranchFormat7()
2363
# We need to make a stacked branch, but the default format for the
2364
# target doesn't support stacking. So force a branch that *can*
2366
from bzrlib.branch import BzrBranchFormat7
2367
branch_format = BzrBranchFormat7()
2368
self.set_branch_format(branch_format)
2369
mutter("using %r for stacking" % (branch_format,))
2370
from bzrlib.repofmt import pack_repo
2371
if self.repository_format.rich_root_data:
2372
bzrdir_format_name = '1.6.1-rich-root'
2373
repo_format = pack_repo.RepositoryFormatKnitPack5RichRoot()
2484
new_branch_format = target_branch._format
2485
if not new_branch_format.supports_stacking():
2486
new_branch_format = None
2487
if new_branch_format is not None:
2488
# Does support stacking, use its format.
2489
self.set_branch_format(new_branch_format)
2490
note('Source branch format does not support stacking,'
2491
' using format:\n %s',
2492
new_branch_format.get_format_description())
2375
bzrdir_format_name = '1.6'
2376
repo_format = pack_repo.RepositoryFormatKnitPack5()
2377
note('Source format does not support stacking, using format:'
2379
bzrdir_format_name, repo_format.get_format_description())
2380
self.repository_format = repo_format
2494
2382
def get_converter(self, format=None):
2495
2383
"""See BzrDirFormat.get_converter()."""
2615
2503
def convert(self, to_convert, pb):
2616
2504
"""See Converter.convert()."""
2617
2505
self.bzrdir = to_convert
2619
warnings.warn("pb parameter to convert() is deprecated")
2620
self.pb = ui.ui_factory.nested_progress_bar()
2622
ui.ui_factory.note('starting upgrade from format 4 to 5')
2623
if isinstance(self.bzrdir.transport, local.LocalTransport):
2624
self.bzrdir.get_workingtree_transport(None).delete('stat-cache')
2625
self._convert_to_weaves()
2626
return BzrDir.open(self.bzrdir.root_transport.base)
2507
self.pb.note('starting upgrade from format 4 to 5')
2508
if isinstance(self.bzrdir.transport, local.LocalTransport):
2509
self.bzrdir.get_workingtree_transport(None).delete('stat-cache')
2510
self._convert_to_weaves()
2511
return BzrDir.open(self.bzrdir.root_transport.base)
2630
2513
def _convert_to_weaves(self):
2631
ui.ui_factory.note('note: upgrade may be faster if all store files are ungzipped first')
2514
self.pb.note('note: upgrade may be faster if all store files are ungzipped first')
2633
2516
# TODO permissions
2634
2517
stat = self.bzrdir.transport.stat('weaves')
2872
2755
def convert(self, to_convert, pb):
2873
2756
"""See Converter.convert()."""
2874
2757
self.bzrdir = to_convert
2875
pb = ui.ui_factory.nested_progress_bar()
2877
ui.ui_factory.note('starting upgrade from format 5 to 6')
2878
self._convert_to_prefixed()
2879
return BzrDir.open(self.bzrdir.root_transport.base)
2759
self.pb.note('starting upgrade from format 5 to 6')
2760
self._convert_to_prefixed()
2761
return BzrDir.open(self.bzrdir.root_transport.base)
2883
2763
def _convert_to_prefixed(self):
2884
2764
from bzrlib.store import TransportStore
2885
2765
self.bzrdir.transport.delete('branch-format')
2886
2766
for store_name in ["weaves", "revision-store"]:
2887
ui.ui_factory.note("adding prefixes to %s" % store_name)
2767
self.pb.note("adding prefixes to %s" % store_name)
2888
2768
store_transport = self.bzrdir.transport.clone(store_name)
2889
2769
store = TransportStore(store_transport, prefixed=True)
2890
2770
for urlfilename in store_transport.list_dir('.'):
3248
3115
stack_on_pwd=stack_on_pwd, repo_format_name=repo_format_name,
3249
3116
make_working_trees=make_working_trees, shared_repo=shared_repo,
3251
return self._initialize_on_transport_ex_rpc(client, path, transport,
3252
use_existing_dir, create_prefix, force_new_repo, stacked_on,
3253
stack_on_pwd, repo_format_name, make_working_trees, shared_repo)
3255
def _initialize_on_transport_ex_rpc(self, client, path, transport,
3256
use_existing_dir, create_prefix, force_new_repo, stacked_on,
3257
stack_on_pwd, repo_format_name, make_working_trees, shared_repo):
3259
3119
args.append(self._serialize_NoneTrueFalse(use_existing_dir))
3260
3120
args.append(self._serialize_NoneTrueFalse(create_prefix))
3272
3132
args.append(self._serialize_NoneString(repo_format_name))
3273
3133
args.append(self._serialize_NoneTrueFalse(make_working_trees))
3274
3134
args.append(self._serialize_NoneTrueFalse(shared_repo))
3275
request_network_name = self._network_name or \
3135
if self._network_name is None:
3136
self._network_name = \
3276
3137
BzrDirFormat.get_default_format().network_name()
3278
response = client.call('BzrDirFormat.initialize_ex_1.16',
3279
request_network_name, path, *args)
3139
response = client.call('BzrDirFormat.initialize_ex',
3140
self.network_name(), path, *args)
3280
3141
except errors.UnknownSmartMethod:
3281
client._medium._remember_remote_is_before((1,16))
3282
3142
local_dir_format = BzrDirMetaFormat1()
3283
3143
self._supply_sub_formats_to(local_dir_format)
3284
3144
return local_dir_format.initialize_on_transport_ex(transport,
3676
3521
stack_on = self._get_full_stack_on()
3523
# Stacking is desired. requested by the target, but does the place it
3524
# points at support stacking? If it doesn't then we should
3525
# not implicitly upgrade. We check this here.
3678
3526
format = self._bzrdir._format
3679
format.require_stacking(stack_on=stack_on,
3680
possible_transports=[self._bzrdir.root_transport])
3527
if not (format.repository_format.supports_external_lookups
3528
and format.get_branch_format().supports_stacking()):
3529
# May need to upgrade - but only do if the target also
3530
# supports stacking. Note that this currently wastes
3531
# network round trips to check - but we only do this
3532
# when the source can't stack so it will fade away
3533
# as people do upgrade.
3534
branch_format = None
3537
target_dir = BzrDir.open(stack_on,
3538
possible_transports=[self._bzrdir.root_transport])
3539
except errors.NotBranchError:
3540
# Nothing there, don't change formats
3542
except errors.JailBreak:
3543
# stack_on is inaccessible, JFDI.
3544
if format.repository_format.rich_root_data:
3545
repo_format = pack_repo.RepositoryFormatKnitPack6RichRoot()
3547
repo_format = pack_repo.RepositoryFormatKnitPack6()
3548
branch_format = branch.BzrBranchFormat7()
3551
target_branch = target_dir.open_branch()
3552
except errors.NotBranchError:
3553
# No branch, don't change formats
3556
branch_format = target_branch._format
3557
repo_format = target_branch.repository._format
3558
if not (branch_format.supports_stacking()
3559
and repo_format.supports_external_lookups):
3560
# Doesn't stack itself, don't force an upgrade
3561
branch_format = None
3563
if branch_format and repo_format:
3564
# Does support stacking, use its format.
3565
format.repository_format = repo_format
3566
format.set_branch_format(branch_format)
3567
note('Source format does not support stacking, '
3568
'using format: \'%s\'\n %s\n',
3569
branch_format.get_format_description(),
3570
repo_format.get_format_description())
3681
3571
if not self._require_stacking:
3682
3572
# We have picked up automatic stacking somewhere.
3683
3573
note('Using default stacking branch %s at %s', self._stack_on,
3726
3616
format_registry.register('weave', BzrDirFormat6,
3727
3617
'Pre-0.8 format. Slower than knit and does not'
3728
3618
' support checkouts or shared repositories.',
3730
3619
deprecated=True)
3731
3620
format_registry.register_metadir('metaweave',
3732
3621
'bzrlib.repofmt.weaverepo.RepositoryFormat7',
3733
3622
'Transitional format in 0.8. Slower than knit.',
3734
3623
branch_format='bzrlib.branch.BzrBranchFormat5',
3735
3624
tree_format='bzrlib.workingtree.WorkingTreeFormat3',
3737
3625
deprecated=True)
3738
3626
format_registry.register_metadir('knit',
3739
3627
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit1',
3740
3628
'Format using knits. Recommended for interoperation with bzr <= 0.14.',
3741
3629
branch_format='bzrlib.branch.BzrBranchFormat5',
3742
3630
tree_format='bzrlib.workingtree.WorkingTreeFormat3',
3744
3631
deprecated=True)
3745
3632
format_registry.register_metadir('dirstate',
3746
3633
'bzrlib.repofmt.knitrepo.RepositoryFormatKnit1',
3891
3772
'bzrlib.repofmt.groupcompress_repo.RepositoryFormatCHK1',
3892
3773
help='pack-1.9 with 255-way hashed CHK inv, group compress, rich roots '
3894
'http://doc.bazaar.canonical.com/latest/developers/development-repo.html '
3896
branch_format='bzrlib.branch.BzrBranchFormat7',
3897
tree_format='bzrlib.workingtree.WorkingTreeFormat6',
3902
format_registry.register_metadir('development7-rich-root',
3903
'bzrlib.repofmt.groupcompress_repo.RepositoryFormatCHK2',
3904
help='pack-1.9 with 255-way hashed CHK inv, bencode revision, group compress, '
3905
'rich roots. Please read '
3906
'http://doc.bazaar.canonical.com/latest/developers/development-repo.html '
3908
branch_format='bzrlib.branch.BzrBranchFormat7',
3909
tree_format='bzrlib.workingtree.WorkingTreeFormat6',
3914
format_registry.register_metadir('2a',
3915
'bzrlib.repofmt.groupcompress_repo.RepositoryFormat2a',
3916
help='First format for bzr 2.0 series.\n'
3917
'Uses group-compress storage.\n'
3918
'Provides rich roots which are a one-way transition.\n',
3919
# 'storage in packs, 255-way hashed CHK inventory, bencode revision, group compress, '
3920
# 'rich roots. Supported by bzr 1.16 and later.',
3921
branch_format='bzrlib.branch.BzrBranchFormat7',
3922
tree_format='bzrlib.workingtree.WorkingTreeFormat6',
3775
'http://doc.bazaar-vcs.org/latest/developers/development-repo.html '
3777
branch_format='bzrlib.branch.BzrBranchFormat7',
3778
tree_format='bzrlib.workingtree.WorkingTreeFormat6',
3923
3780
experimental=True,
3926
3783
# The following format should be an alias for the rich root equivalent
3927
3784
# of the default format
3928
3785
format_registry.register_metadir('default-rich-root',
3929
'bzrlib.repofmt.groupcompress_repo.RepositoryFormat2a',
3930
branch_format='bzrlib.branch.BzrBranchFormat7',
3931
tree_format='bzrlib.workingtree.WorkingTreeFormat6',
3786
'bzrlib.repofmt.pack_repo.RepositoryFormatKnitPack4',
3787
help='Default format, rich root variant. (needed for bzr-svn and bzr-git).',
3788
branch_format='bzrlib.branch.BzrBranchFormat6',
3789
tree_format='bzrlib.workingtree.WorkingTreeFormat4',
3936
3792
# The current format that is made on 'bzr init'.
3937
format_registry.set_default('2a')
3793
format_registry.set_default('pack-0.92')