Make the recursive reverse depenedency list building more efficient

Signed-off-by: Adam D. Barratt <adam@adam-barratt.org.uk>
debian
Adam D. Barratt 14 years ago
parent de312e4138
commit df6f50bbd5

@ -2046,12 +2046,24 @@ class Britney:
# save the old binary for undo # save the old binary for undo
undo['binaries'][p] = binaries[parch][0][binary] undo['binaries'][p] = binaries[parch][0][binary]
# all the reverse dependencies are affected by the change # all the reverse dependencies are affected by the change
for j in binaries[parch][0][binary][RDEPENDS]: # recursively loop through the reverse dependencies
key = (j, parch) rev_deps = set(binaries[parch][0][binary][RDEPENDS])
if key not in affected: affected.append(key) seen = set()
for p in self.get_full_tree(j, parch, 'testing'): while len(rev_deps) > 0:
key = (p, parch) # mark all of the current iteration of packages as affected
if key not in affected: affected.append(key) affected.extend( [ (x, parch) for x in rev_deps ] )
# and as processed
seen |= rev_deps
# generate the next iteration, which is the reverse-dependencies of
# the current iteration
new_rev_deps = [ binaries[parch][0][x][RDEPENDS] for x in rev_deps \
if x in binaries[parch][0] ]
# flatten the list-of-lists, filtering out already handled packages
# in the process
rev_deps = set([ package for sublist in new_rev_deps \
for package in sublist if package not in seen ])
# remove duplicates from the list of affected packages
affected = list(set(affected))
# remove the provided virtual packages # remove the provided virtual packages
for j in binaries[parch][0][binary][PROVIDES]: for j in binaries[parch][0][binary][PROVIDES]:
key = j + "/" + parch key = j + "/" + parch

Loading…
Cancel
Save