zip-download files older than 1980-01-01
This commit is contained in:
		
							parent
							
								
									344ce63455
								
							
						
					
					
						commit
						fa12c81a03
					
				| @ -5,7 +5,7 @@ import tarfile | ||||
| import threading | ||||
| 
 | ||||
| from .sutil import errdesc | ||||
| from .util import Queue, fsenc | ||||
| from .util import Queue, fsenc, min_ex | ||||
| from .bos import bos | ||||
| 
 | ||||
| 
 | ||||
| @ -88,8 +88,9 @@ class StreamTar(object): | ||||
| 
 | ||||
|             try: | ||||
|                 self.ser(f) | ||||
|             except Exception as ex: | ||||
|                 errors.append([f["vp"], repr(ex)]) | ||||
|             except Exception: | ||||
|                 ex = min_ex(5, True).replace("\n", "\n-- ") | ||||
|                 errors.append([f["vp"], ex]) | ||||
| 
 | ||||
|         if errors: | ||||
|             self.errf, txt = errdesc(errors) | ||||
|  | ||||
| @ -1,13 +1,12 @@ | ||||
| # coding: utf-8 | ||||
| from __future__ import print_function, unicode_literals | ||||
| 
 | ||||
| import os | ||||
| import time | ||||
| import zlib | ||||
| from datetime import datetime | ||||
| 
 | ||||
| from .sutil import errdesc | ||||
| from .util import yieldfile, sanitize_fn, spack, sunpack | ||||
| from .util import yieldfile, sanitize_fn, spack, sunpack, min_ex | ||||
| from .bos import bos | ||||
| 
 | ||||
| 
 | ||||
| @ -36,7 +35,10 @@ def unixtime2dos(ts): | ||||
| 
 | ||||
|     bd = ((dy - 1980) << 9) + (dm << 5) + dd | ||||
|     bt = (th << 11) + (tm << 5) + ts // 2 | ||||
|     try: | ||||
|         return spack(b"<HH", bt, bd) | ||||
|     except: | ||||
|         return b"\x00\x00\x21\x00" | ||||
| 
 | ||||
| 
 | ||||
| def gen_fdesc(sz, crc32, z64): | ||||
| @ -244,8 +246,9 @@ class StreamZip(object): | ||||
|             try: | ||||
|                 for x in self.ser(f): | ||||
|                     yield x | ||||
|             except Exception as ex: | ||||
|                 errors.append([f["vp"], repr(ex)]) | ||||
|             except Exception: | ||||
|                 ex = min_ex(5, True).replace("\n", "\n-- ") | ||||
|                 errors.append([f["vp"], ex]) | ||||
| 
 | ||||
|         if errors: | ||||
|             errf, txt = errdesc(errors) | ||||
|  | ||||
| @ -485,13 +485,13 @@ def vol_san(vols, txt): | ||||
|     return txt | ||||
| 
 | ||||
| 
 | ||||
| def min_ex(): | ||||
| def min_ex(max_lines=8, reverse=False): | ||||
|     et, ev, tb = sys.exc_info() | ||||
|     tb = traceback.extract_tb(tb) | ||||
|     fmt = "{} @ {} <{}>: {}" | ||||
|     ex = [fmt.format(fp.split(os.sep)[-1], ln, fun, txt) for fp, ln, fun, txt in tb] | ||||
|     ex.append("[{}] {}".format(et.__name__, ev)) | ||||
|     return "\n".join(ex[-8:]) | ||||
|     return "\n".join(ex[-max_lines:][:: -1 if reverse else 1]) | ||||
| 
 | ||||
| 
 | ||||
| @contextlib.contextmanager | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 ed
						ed