Source code for rics._just_the_way_i_like_it
import logging
import os
import sys
import traceback
import warnings
from multiprocessing import process
from typing import Any, Union
from .logs import basic_config
_SKIP_WARNING: bool = False
[docs]def configure_stuff(
level: Union[int, str] = logging.INFO,
rics_level: Union[int, str] = logging.INFO,
id_translation_level: Union[int, str] = logging.INFO,
matplotlib_level: Union[int, str] = logging.WARNING,
**kwargs: Any,
) -> None:
"""Configure a bunch of stuff to match my personal preferences. May do strange stuff 👻.
.. warning::
This function can and will change without warning, and will not be documented in the changelog. Don't use for
anything important.
Args:
level: Log level for the root logger. Default is ``logging.INFO``.
rics_level: Log level for the :mod:`rics` package. Default is ``logging.INFO``.
id_translation_level: Log level for the :mod:`id_translation` package. Default is ``logging.INFO``.
matplotlib_level: Log level for the :mod:`matplotlib` package. Default is ``logging.WARNING``.
**kwargs: Keyword arguments for :py:func:`logging.basicConfig`.
"""
basic_config(
level=level,
rics_level=rics_level,
id_translation_level=id_translation_level,
matplotlib_level=matplotlib_level,
**kwargs,
)
_configure_pandas()
try:
from .plotting import configure
configure()
except ModuleNotFoundError as e:
warnings.warn(f"Plotting configuration not done: {e}", stacklevel=2)
print("👻 Configured some stuff just the way I like it!")
_maybe_emit_warning()
def _configure_pandas() -> None:
try:
import pandas as pd
except ModuleNotFoundError as e:
warnings.warn(f"Pandas configuration not done: {e}", stacklevel=3)
return
pd.options.display.max_columns = 50
pd.options.display.max_colwidth = 150
pd.options.display.max_rows = 250
pd.options.display.width = 0
pd.options.display.float_format = "{:.6g}".format
pd.options.mode.chained_assignment = "raise"
try:
pd.plotting.register_matplotlib_converters()
except ImportError: # pragma: no cover
pass
def _maybe_emit_warning() -> None: # pragma: no cover
global _SKIP_WARNING
if _SKIP_WARNING:
return
_SKIP_WARNING = True
if getattr(process.current_process(), "_inheriting", False):
return # From multiprocessing.spawn._check_not_importing_main
if os.environ.get("JTWILI", "false").lower() == "true":
return
try:
get_ipython() # type: ignore[name-defined]
return # Typically in a console or notebook
except NameError:
pass
caller = traceback.format_stack()[-3]
message = f"If you're seeing this in bad places, remove the call to rics.configure_stuff() in:\n{caller}"
logger = logging.getLogger("rics")
if logger.isEnabledFor(logging.WARNING):
logger.warning(message)
else:
print(message, end="", file=sys.stderr)