extract: fix KeyError for "partial" extraction, fixes #4607

note that "partial" even applied to giving an always matching condition.

"full" is only assumed if no conditions are given.
This commit is contained in:
Thomas Waldmann 2019-06-10 18:23:28 +02:00
parent 0ecd4e19c0
commit 71c7efd17c
1 changed files with 1 additions and 1 deletions

View File

@ -258,6 +258,7 @@ class DownloadPipeline:
Warning: if *preload* is True then all data chunks of every yielded item have to be retrieved,
otherwise preloaded chunks will accumulate in RemoteRepository and create a memory leak.
"""
masters_preloaded = set()
unpacker = msgpack.Unpacker(use_list=False)
for data in self.fetch_many(ids):
unpacker.feed(data)
@ -279,7 +280,6 @@ class DownloadPipeline:
# selected (== not extracted), we will still need to preload its chunks if a
# corresponding hardlink slave is selected (== is extracted).
# due to a side effect of the filter() call, we now have hardlink_masters dict populated.
masters_preloaded = set()
for item in items:
if 'chunks' in item: # regular file, maybe a hardlink master
preload(item.chunks)