summaryrefslogtreecommitdiff
path: root/Omni/Log.py
diff options
context:
space:
mode:
authorBen Sima <ben@bsima.me>2024-11-15 14:55:37 -0500
committerBen Sima <ben@bsima.me>2024-12-21 10:06:49 -0500
commit6513755670892983db88a6633b8c1ea6019c03d1 (patch)
tree44e9eccdb7a3a74ab7e96a8fee7572dd6a78dc73 /Omni/Log.py
parentae7b7e0186b5f2e0dcd4d5fac0a71fa264caedc2 (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.py35
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")