diff options
author | Ben Sima <ben@bsima.me> | 2024-11-15 14:55:37 -0500 |
---|---|---|
committer | Ben Sima <ben@bsima.me> | 2024-12-21 10:06:49 -0500 |
commit | 6513755670892983db88a6633b8c1ea6019c03d1 (patch) | |
tree | 44e9eccdb7a3a74ab7e96a8fee7572dd6a78dc73 /Omni/Log.py | |
parent | ae7b7e0186b5f2e0dcd4d5fac0a71fa264caedc2 (diff) |
Re-namespace some stuff to Omni
I was getting confused about what is a product and what is internal
infrastructure; I think it is good to keep those things separate. So I moved a
bunch of stuff to an Omni namespace, actually most stuff went there. Only things
that are explicitly external products are still in the Biz namespace.
Diffstat (limited to 'Omni/Log.py')
-rw-r--r-- | Omni/Log.py | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/Omni/Log.py b/Omni/Log.py new file mode 100644 index 0000000..2fbd007 --- /dev/null +++ b/Omni/Log.py @@ -0,0 +1,35 @@ +"""Setup logging like Omni/Log.hs.""" + +# noqa: builtin-attribute-shadowing +import logging +import typing + + +class LowerFormatter(logging.Formatter): + """A logging formatter that formats logs how I like.""" + + def format(self: "LowerFormatter", record: typing.Any) -> typing.Any: + """Use the format I like for logging.""" + record.levelname = record.levelname.lower() + return super(logging.Formatter, self).format(record) # type: ignore[misc] + + +def setup() -> None: + """Run this in your __main__ function.""" + logging.basicConfig( + level=logging.DEBUG, + format="%(levelname)s: %(name)s: %(message)s", + ) + logging.addLevelName(logging.DEBUG, "dbug") + logging.addLevelName(logging.ERROR, "fail") + logging.addLevelName(logging.INFO, "info") + logger = logging.getLogger(__name__) + formatter = LowerFormatter() + handler = logging.StreamHandler() + handler.setFormatter(formatter) + logger.addHandler(handler) + + +if __name__ == "__main__": + setup() + logging.debug("i am doing testing") |