You're reading an old version of this documentation. If you want up-to-date information, please have a look at v0.1.3.

Source code for src.cosmicqc.cli

"""
Setup coSMicQC CLI through python-fire
"""

import inspect
import sys
import types
from typing import Optional

import fire
from fire import helptext, inspectutils, value_types
from fire.core import Display, FireError, _DictAsString, _OneLineResult
from fire.trace import FireTrace

from . import analyze


# used to avoid bugs with python-fire and pandas string-based repr compatibility.
# referenced from https://github.com/google/python-fire/pull/446
# to be removed after python-fire merges changes (uncertain of timeline)
[docs] def HasCustomRepr(component: object) -> bool: """Reproduces above HasCustomStr function to determine if component has a custom __repr__ method. ... Args: component: The object to check for a custom __repr__ method. Returns: Whether `component` has a custom __repr__ method. """ if hasattr(component, "__repr__"): class_attrs = inspectutils.GetClassAttrsDict(type(component)) or {} repr_attr = class_attrs.get("__repr__") if repr_attr and repr_attr.defining_class is not object: return True return False
# used to avoid bugs with python-fire and pandas string-based repr compatibility. # referenced with modifications from https://github.com/google/python-fire/pull/446 # to be removed after python-fire merges changes (uncertain of timeline) # ignore rule below added to help avoid triggering ruff linting checks on temporary fix.
[docs] def _PrintResult( # noqa: C901 component_trace: FireTrace, verbose: bool = False, serialize: Optional[bool] = None ) -> None: """Prints the result of the Fire call to stdout in a human readable way.""" result = component_trace.GetResult() # Allow users to modify the return value of the component and provide # custom formatting. if serialize: if not callable(serialize): raise FireError( "The argument `serialize` must be empty or callable:", serialize ) result = serialize(result) if value_types.HasCustomStr(result): # If the object has a custom __str__ method, rather than one inherited from # object, then we use that to serialize the object. print(str(result)) return elif HasCustomRepr(result): # Same as above, but for __repr__. # For pandas.DataFrame, __str__ is inherited from object, but __repr__ has # a custom implementation (see pandas.core.frame.DataFrame.__repr__) print(str(result)) return if isinstance(result, (list, set, frozenset, types.GeneratorType)): for i in result: print(_OneLineResult(i)) elif inspect.isgeneratorfunction(result): raise NotImplementedError elif isinstance(result, dict) and value_types.IsSimpleGroup(result): print(_DictAsString(result, verbose)) elif isinstance(result, tuple): print(_OneLineResult(result)) elif isinstance(result, value_types.VALUE_TYPES): if result is not None: print(result) else: help_text = helptext.HelpText(result, trace=component_trace, verbose=verbose) output = [help_text] # used for displaying output through python-fire Display(output, out=sys.stdout)
# replace the _PrintResult function with a fix for pandas dataframes fire.core._PrintResult = _PrintResult
[docs] def cli_analyze() -> None: """ Run the analyze module functions through python-fire CLI This function serves as the CLI entry point for functions within the analyze module. """ fire.Fire(analyze)
if __name__ == "__main__": """ Setup the CLI with python-fire for the coSMicQC package. This enables running the functions identify_outliers, find_outliers, and label_outliers from the command line interface through analyze """ cli_analyze()