|  | @@ -56,33 +56,50 @@ class ExtractMixIn:
 | 
	
		
			
				|  |  |          else:
 | 
	
		
			
				|  |  |              pi = None
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        for item in archive.iter_items(filter):
 | 
	
		
			
				|  |  | -            archive.preload_item_chunks(item, optimize_hardlinks=True)
 | 
	
		
			
				|  |  | +        for item in archive.iter_items():
 | 
	
		
			
				|  |  |              orig_path = item.path
 | 
	
		
			
				|  |  |              if strip_components:
 | 
	
		
			
				|  |  | -                item.path = os.sep.join(orig_path.split(os.sep)[strip_components:])
 | 
	
		
			
				|  |  | -            if not args.dry_run:
 | 
	
		
			
				|  |  | -                while dirs and not item.path.startswith(dirs[-1].path):
 | 
	
		
			
				|  |  | -                    dir_item = dirs.pop(-1)
 | 
	
		
			
				|  |  | -                    try:
 | 
	
		
			
				|  |  | -                        archive.extract_item(dir_item, stdout=stdout)
 | 
	
		
			
				|  |  | -                    except BackupError as e:
 | 
	
		
			
				|  |  | -                        self.print_warning_instance(BackupWarning(remove_surrogates(dir_item.path), e))
 | 
	
		
			
				|  |  | +                stripped_path = os.sep.join(orig_path.split(os.sep)[strip_components:])
 | 
	
		
			
				|  |  | +                if not stripped_path:
 | 
	
		
			
				|  |  | +                    continue
 | 
	
		
			
				|  |  | +                item.path = stripped_path
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            is_matched = matcher.match(orig_path)
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |              if output_list:
 | 
	
		
			
				|  |  | -                logging.getLogger("borg.output.list").info(remove_surrogates(item.path))
 | 
	
		
			
				|  |  | -            try:
 | 
	
		
			
				|  |  | -                if dry_run:
 | 
	
		
			
				|  |  | -                    archive.extract_item(item, dry_run=True, hlm=hlm, pi=pi)
 | 
	
		
			
				|  |  | -                else:
 | 
	
		
			
				|  |  | -                    if stat.S_ISDIR(item.mode):
 | 
	
		
			
				|  |  | -                        dirs.append(item)
 | 
	
		
			
				|  |  | -                        archive.extract_item(item, stdout=stdout, restore_attrs=False)
 | 
	
		
			
				|  |  | +                log_prefix = "+" if is_matched else "-"
 | 
	
		
			
				|  |  | +                logging.getLogger("borg.output.list").info(f"{log_prefix} {remove_surrogates(item.path)}")
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            if is_matched:
 | 
	
		
			
				|  |  | +                archive.preload_item_chunks(item, optimize_hardlinks=True)
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                if not dry_run:
 | 
	
		
			
				|  |  | +                    while dirs and not item.path.startswith(dirs[-1].path):
 | 
	
		
			
				|  |  | +                        dir_item = dirs.pop(-1)
 | 
	
		
			
				|  |  | +                        try:
 | 
	
		
			
				|  |  | +                            archive.extract_item(dir_item, stdout=stdout)
 | 
	
		
			
				|  |  | +                        except BackupError as e:
 | 
	
		
			
				|  |  | +                            self.print_warning_instance(BackupWarning(remove_surrogates(dir_item.path), e))
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                try:
 | 
	
		
			
				|  |  | +                    if dry_run:
 | 
	
		
			
				|  |  | +                        archive.extract_item(item, dry_run=True, hlm=hlm, pi=pi)
 | 
	
		
			
				|  |  |                      else:
 | 
	
		
			
				|  |  | -                        archive.extract_item(
 | 
	
		
			
				|  |  | -                            item, stdout=stdout, sparse=sparse, hlm=hlm, pi=pi, continue_extraction=continue_extraction
 | 
	
		
			
				|  |  | -                        )
 | 
	
		
			
				|  |  | -            except BackupError as e:
 | 
	
		
			
				|  |  | -                self.print_warning_instance(BackupWarning(remove_surrogates(orig_path), e))
 | 
	
		
			
				|  |  | +                        if stat.S_ISDIR(item.mode):
 | 
	
		
			
				|  |  | +                            dirs.append(item)
 | 
	
		
			
				|  |  | +                            archive.extract_item(item, stdout=stdout, restore_attrs=False)
 | 
	
		
			
				|  |  | +                        else:
 | 
	
		
			
				|  |  | +                            archive.extract_item(
 | 
	
		
			
				|  |  | +                                item,
 | 
	
		
			
				|  |  | +                                stdout=stdout,
 | 
	
		
			
				|  |  | +                                sparse=sparse,
 | 
	
		
			
				|  |  | +                                hlm=hlm,
 | 
	
		
			
				|  |  | +                                pi=pi,
 | 
	
		
			
				|  |  | +                                continue_extraction=continue_extraction,
 | 
	
		
			
				|  |  | +                            )
 | 
	
		
			
				|  |  | +                except BackupError as e:
 | 
	
		
			
				|  |  | +                    self.print_warning_instance(BackupWarning(remove_surrogates(orig_path), e))
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |          if pi:
 | 
	
		
			
				|  |  |              pi.finish()
 | 
	
		
			
				|  |  |  
 |