diff options
Diffstat (limited to 'src/mlia/utils')
-rw-r--r-- | src/mlia/utils/logging.py | 37 | ||||
-rw-r--r-- | src/mlia/utils/misc.py | 24 |
2 files changed, 55 insertions, 6 deletions
diff --git a/src/mlia/utils/logging.py b/src/mlia/utils/logging.py index cf7ad27..0659dcf 100644 --- a/src/mlia/utils/logging.py +++ b/src/mlia/utils/logging.py @@ -1,4 +1,4 @@ -# SPDX-FileCopyrightText: Copyright 2022, Arm Limited and/or its affiliates. +# SPDX-FileCopyrightText: Copyright 2022-2023, Arm Limited and/or its affiliates. # SPDX-License-Identifier: Apache-2.0 """Logging utility functions.""" from __future__ import annotations @@ -54,10 +54,10 @@ def redirect_output( @contextmanager -def redirect_raw( - logger: logging.Logger, output: TextIO, log_level: int +def process_raw_output( + consumer: Callable[[str], None], output: TextIO ) -> Generator[None, None, None]: - """Redirect output using file descriptors.""" + """Process output on file descriptor level.""" with tempfile.TemporaryFile(mode="r+") as tmp: old_output_fd: int | None = None try: @@ -73,7 +73,21 @@ def redirect_raw( tmp.seek(0) for line in tmp.readlines(): - logger.log(log_level, line.rstrip()) + consumer(line) + + +@contextmanager +def redirect_raw( + logger: logging.Logger, output: TextIO, log_level: int +) -> Generator[None, None, None]: + """Redirect output using file descriptors.""" + + def consumer(line: str) -> None: + """Redirect output to the logger.""" + logger.log(log_level, line.rstrip()) + + with process_raw_output(consumer, output): + yield @contextmanager @@ -94,6 +108,19 @@ def redirect_raw_output( yield +@contextmanager +def capture_raw_output(output: TextIO) -> Generator[list[str], None, None]: + """Capture output as list of strings.""" + result: list[str] = [] + + def consumer(line: str) -> None: + """Save output for later processing.""" + result.append(line) + + with process_raw_output(consumer, output): + yield result + + class LogFilter(logging.Filter): """Configurable log filter.""" diff --git a/src/mlia/utils/misc.py b/src/mlia/utils/misc.py index de95448..dd2f007 100644 --- a/src/mlia/utils/misc.py +++ b/src/mlia/utils/misc.py @@ -1,9 +1,31 @@ -# SPDX-FileCopyrightText: Copyright 2022, Arm Limited and/or its affiliates. +# SPDX-FileCopyrightText: Copyright 2022-2023, Arm Limited and/or its affiliates. # SPDX-License-Identifier: Apache-2.0 """Various util functions.""" +from importlib import metadata +from pathlib import Path + +from mlia.utils.filesystem import sha256 + + +class MetadataError(Exception): + """Metadata error.""" def yes(prompt: str) -> bool: """Return true if user confirms the action.""" response = input(f"{prompt} [y/n]: ") return response in ["y", "Y"] + + +def get_pkg_version(pkg_name: str) -> str: + """Return the version of python package.""" + try: + pkg_version = metadata.version(pkg_name) + except FileNotFoundError as exc: + raise MetadataError(exc) from exc + return pkg_version + + +def get_file_checksum(input_path: Path) -> str: + """Retrun the checksum of the input model.""" + return sha256(input_path) |