summaryrefslogtreecommitdiff
path: root/rdiff-backup/rdiff_backup/selection.py
diff options
context:
space:
mode:
authorben <ben@2b77aa54-bcbc-44c9-a7ec-4f6cf2b41109>2002-05-21 23:25:47 +0000
committerben <ben@2b77aa54-bcbc-44c9-a7ec-4f6cf2b41109>2002-05-21 23:25:47 +0000
commit48c85c6792ed001c8063fec21dfd2794c32dcd28 (patch)
tree91d28a549e15e48681266b2e8a6c2cc88db10516 /rdiff-backup/rdiff_backup/selection.py
parent55669110eec45e22249537d3195799cf5945ad23 (diff)
downloadrdiff-backup-48c85c6792ed001c8063fec21dfd2794c32dcd28.tar.gz
Fixed source finalizer resume bug (although more remains to be done)
git-svn-id: http://svn.savannah.nongnu.org/svn/rdiff-backup/trunk@95 2b77aa54-bcbc-44c9-a7ec-4f6cf2b41109
Diffstat (limited to 'rdiff-backup/rdiff_backup/selection.py')
-rw-r--r--rdiff-backup/rdiff_backup/selection.py20
1 files changed, 14 insertions, 6 deletions
diff --git a/rdiff-backup/rdiff_backup/selection.py b/rdiff-backup/rdiff_backup/selection.py
index 94da6f1..70f5e7e 100644
--- a/rdiff-backup/rdiff_backup/selection.py
+++ b/rdiff-backup/rdiff_backup/selection.py
@@ -74,12 +74,15 @@ class Select:
self.prefix = self.dsrpath.path
self.quoting_on = Globals.quoting_enabled and quoted_filenames
- def set_iter(self, starting_index = None, sel_func = None):
+ def set_iter(self, starting_index = None, iterate_parents = None,
+ sel_func = None):
"""Initialize more variables, get ready to iterate
- Will iterate indicies greater than starting_index. Selection
- function sel_func is called on each dsrp and is usually
- self.Select. Returns self just for convenience.
+ Will iterate indicies greater than starting_index. If
+ iterate_parents is true, will also include parents of
+ starting_index in iteration. Selection function sel_func is
+ called on each dsrp and is usually self.Select. Returns self
+ just for convenience.
"""
if not sel_func: sel_func = self.Select
@@ -88,7 +91,10 @@ class Select:
self.starting_index = starting_index
self.iter = self.iterate_starting_from(self.dsrpath,
self.iterate_starting_from, sel_func)
- else: self.iter = self.Iterate(self.dsrpath, self.Iterate, sel_func)
+ else:
+ assert not iterate_parents
+ self.iter = self.Iterate(self.dsrpath, self.Iterate, sel_func)
+ self.iterate_parents = iterate_parents
self.next = self.iter.next
self.__iter__ = lambda: self
return self
@@ -140,8 +146,10 @@ class Select:
if dsrpath.index > self.starting_index: # past starting_index
for dsrp in self.Iterate(dsrpath, self.Iterate, sel_func):
yield dsrp
- elif dsrpath.index == self.starting_index[:len(dsrpath.index)]:
+ elif (dsrpath.index == self.starting_index[:len(dsrpath.index)]
+ and dsrpath.isdir()):
# May encounter starting index on this branch
+ if self.iterate_parents: yield dsrpath
for dsrp in self.iterate_in_dir(dsrpath,
self.iterate_starting_from,
sel_func): yield dsrp