Rev 4840: (vila, in file:///home/pqm/archives/thelove/bzr/2.1/
Canonical.com Patch Queue Manager
pqm at pqm.ubuntu.com
Thu May 6 09:46:26 BST 2010
At file:///home/pqm/archives/thelove/bzr/2.1/
------------------------------------------------------------
revno: 4840 [merge]
revision-id: pqm at pqm.ubuntu.com-20100506084624-ii9nk3id2c5210us
parent: pqm at pqm.ubuntu.com-20100430085048-eh08ih9dborzlvk2
parent: bialix at ukr.net-20100504134614-x6z7qqw53sy6zayb
committer: Canonical.com Patch Queue Manager <pqm at pqm.ubuntu.com>
branch nick: 2.1
timestamp: Thu 2010-05-06 09:46:24 +0100
message:
(vila,
for bialix) ``bzr clean-tree`` should not delete nested bzrdirs.
modified:
NEWS NEWS-20050323055033-4e00b5db738777ff
bzrlib/clean_tree.py clean_tree.py-20050827022328-5ba46e22d074695c
bzrlib/tests/blackbox/test_clean_tree.py test_clean_tree.py-20090219235516-em1ybc01twsqacx9-1
=== modified file 'NEWS'
--- a/NEWS 2010-04-30 08:13:34 +0000
+++ b/NEWS 2010-05-04 13:46:14 +0000
@@ -13,6 +13,10 @@
Bug Fixes
*********
+* ``bzr clean-tree`` should not delete nested bzrdirs. Required for proper
+ support of bzr-externals and scmproj plugins.
+ (Alexander Belchenko, bug #572098)
+
* ``bzr switch`` does not die if a ConfigurableFileMerger is used.
(Aaron Bentley, #559436)
=== modified file 'bzrlib/clean_tree.py'
--- a/bzrlib/clean_tree.py 2009-03-23 14:59:43 +0000
+++ b/bzrlib/clean_tree.py 2010-05-04 13:46:14 +0000
@@ -20,6 +20,7 @@
import shutil
import sys
+from bzrlib import bzrdir, errors
from bzrlib.osutils import has_symlinks, isdir
from bzrlib.trace import note
from bzrlib.workingtree import WorkingTree
@@ -53,11 +54,14 @@
try:
deletables = list(iter_deletables(tree, unknown=unknown,
ignored=ignored, detritus=detritus))
+ deletables = _filter_out_nested_bzrdirs(deletables)
if len(deletables) == 0:
note('Nothing to delete.')
return 0
if not no_prompt:
for path, subp in deletables:
+ # FIXME using print is very bad idea
+ # clean_tree should accept to_file argument to write the output
print subp
val = raw_input('Are you sure you wish to delete these [y/N]?')
if val.lower() not in ('y', 'yes'):
@@ -68,6 +72,27 @@
tree.unlock()
+def _filter_out_nested_bzrdirs(deletables):
+ result = []
+ for path, subp in deletables:
+ # bzr won't recurse into unknowns/ignored directories by default
+ # so we don't pay a penalty for checking subdirs of path for nested
+ # bzrdir.
+ # That said we won't detect the branch in the subdir of non-branch
+ # directory and therefore delete it. (worth to FIXME?)
+ if isdir(path):
+ try:
+ bzrdir.BzrDir.open(path)
+ except errors.NotBranchError:
+ result.append((path,subp))
+ else:
+ # TODO may be we need to notify user about skipped directories?
+ pass
+ else:
+ result.append((path,subp))
+ return result
+
+
def delete_items(deletables, dry_run=False):
"""Delete files in the deletables iterable"""
has_deleted = False
=== modified file 'bzrlib/tests/blackbox/test_clean_tree.py'
--- a/bzrlib/tests/blackbox/test_clean_tree.py 2009-03-23 14:59:43 +0000
+++ b/bzrlib/tests/blackbox/test_clean_tree.py 2010-05-04 13:46:14 +0000
@@ -21,6 +21,7 @@
import os
+from bzrlib import ignores
from bzrlib.tests import TestCaseWithTransport
@@ -62,3 +63,18 @@
self.failIfExists('name')
self.failIfExists('name~')
self.failIfExists('name.pyc')
+
+ def test_clean_tree_nested_bzrdir(self):
+ # clean-tree should not blindly delete nested bzrdirs (branches)
+ # bug https://bugs.launchpad.net/bzr/+bug/572098
+ # so it will play well with scmproj/bzr-externals plugins.
+ wt1 = self.make_branch_and_tree('.')
+ wt2 = self.make_branch_and_tree('foo')
+ wt3 = self.make_branch_and_tree('bar')
+ ignores.tree_ignores_add_patterns(wt1, ['./foo'])
+ self.run_bzr(['clean-tree', '--unknown', '--force'])
+ self.failUnlessExists('foo')
+ self.failUnlessExists('bar')
+ self.run_bzr(['clean-tree', '--ignored', '--force'])
+ self.failUnlessExists('foo')
+ self.failUnlessExists('bar')
More information about the bazaar-commits
mailing list