|  | @@ -14,7 +14,6 @@ import sys
 | 
	
		
			
				|  |  |  import time
 | 
	
		
			
				|  |  |  from io import BytesIO
 | 
	
		
			
				|  |  |  from attic import xattr
 | 
	
		
			
				|  |  | -from attic.cache import Cache
 | 
	
		
			
				|  |  |  from attic.platform import acl_get, acl_set
 | 
	
		
			
				|  |  |  from attic.chunker import Chunker
 | 
	
		
			
				|  |  |  from attic.hashindex import ChunkIndex
 | 
	
	
		
			
				|  | @@ -224,22 +223,19 @@ class Archive:
 | 
	
		
			
				|  |  |          self.repository.commit()
 | 
	
		
			
				|  |  |          self.cache.commit()
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -    def calc_stats(self):
 | 
	
		
			
				|  |  | +    def calc_stats(self, cache):
 | 
	
		
			
				|  |  |          def add(id):
 | 
	
		
			
				|  |  | -            count, size, csize = cache.chunks[id]
 | 
	
		
			
				|  |  | +            count, size, csize = self.cache.chunks[id]
 | 
	
		
			
				|  |  |              stats.update(size, csize, count == 1)
 | 
	
		
			
				|  |  | -            cache.chunks[id] = count - 1, size, csize  # dirties cache.chunks!
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | +            self.cache.chunks[id] = count - 1, size, csize
 | 
	
		
			
				|  |  |          def add_file_chunks(chunks):
 | 
	
		
			
				|  |  |              for id, _, _ in chunks:
 | 
	
		
			
				|  |  |                  add(id)
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  |          # This function is a bit evil since it abuses the cache to calculate
 | 
	
		
			
				|  |  | -        # the stats. The cache transaction must be rolled back afterwards.
 | 
	
		
			
				|  |  | -        cache = Cache(self.repository, self.key, self.manifest)
 | 
	
		
			
				|  |  | +        # the stats. The cache transaction must be rolled back afterwards
 | 
	
		
			
				|  |  | +        unpacker = msgpack.Unpacker(use_list=False)
 | 
	
		
			
				|  |  |          cache.begin_txn()
 | 
	
		
			
				|  |  |          stats = Statistics()
 | 
	
		
			
				|  |  | -        unpacker = msgpack.Unpacker(use_list=False)
 | 
	
		
			
				|  |  |          add(self.id)
 | 
	
		
			
				|  |  |          for id, chunk in zip(self.metadata[b'items'], self.repository.get_many(self.metadata[b'items'])):
 | 
	
		
			
				|  |  |              add(id)
 |