From 4bb25a19aede052a518ad588b593e9ec96ead21b Mon Sep 17 00:00:00 2001 From: embeddedc <> Date: Mon, 25 Nov 2024 08:08:43 +0100 Subject: [PATCH] Some cleanup: Allow all IOBase derived file streams --- src/asammdf/mdf.py | 16 ++++------------ 1 file changed, 4 insertions(+), 12 deletions(-) diff --git a/src/asammdf/mdf.py b/src/asammdf/mdf.py index febd4e28c..bda993b6e 100644 --- a/src/asammdf/mdf.py +++ b/src/asammdf/mdf.py @@ -11,7 +11,7 @@ from enum import Enum from functools import reduce import gzip -from io import BufferedIOBase, BytesIO +from io import IOBase import logging import os from pathlib import Path @@ -233,10 +233,9 @@ def __init__( if name: if is_file_like(name): - if isinstance(name, (BytesIO, BufferedIOBase)): + if isinstance(name, IOBase): original_name = None file_stream = name - do_close = False elif isinstance(name, bz2.BZ2File): original_name = Path(name._fp.name) @@ -245,8 +244,6 @@ def __init__( file_stream = open(tmp_name, "rb") name = tmp_name - do_close = True - elif isinstance(name, gzip.GzipFile): original_name = Path(name.name) tmp_name = get_temporary_filename(original_name, dir=temporary_folder) @@ -254,8 +251,6 @@ def __init__( file_stream = open(tmp_name, "rb") name = tmp_name - do_close = True - elif FSSPEF_AVAILABLE and isinstance(name, fsspec.spec.AbstractBufferedFile): original_name = "AzureFile" file_stream = name @@ -282,7 +277,6 @@ def __init__( move(output, name) file_stream = open(name, "rb") - do_close = True else: name = original_name = Path(name) @@ -305,14 +299,12 @@ def __init__( move(output, name) file_stream = open(name, "rb") - do_close = True file_stream.seek(0) magic_header = file_stream.read(8) if magic_header.strip() not in (b"MDF", b"UnFinMF"): - if do_close: - file_stream.close() + file_stream.close() raise MdfException(f'"{name}" is not a valid ASAM MDF file: magic header is {magic_header}') file_stream.seek(8) @@ -320,7 +312,7 @@ def __init__( if not version: _, version = get_measurement_timestamp_and_version(file_stream) - if do_close: + if not isinstance(name, IOBase): file_stream.close() kwargs["original_name"] = original_name