mirror of
https://github.com/karpathy/nanochat.git
synced 2025-12-06 12:22:18 +00:00
Create logging wrapper for function name, args, and kwargs
This commit is contained in:
parent
e85c309235
commit
8a40915246
26
nanochat/logger.py
Normal file
26
nanochat/logger.py
Normal file
|
|
@ -0,0 +1,26 @@
|
||||||
|
from functools import wraps
|
||||||
|
|
||||||
|
from loguru import logger
|
||||||
|
|
||||||
|
|
||||||
|
def log(func):
|
||||||
|
"""A decorator to log function calls, arguments, and return values."""
|
||||||
|
|
||||||
|
@wraps(func)
|
||||||
|
def wrapper(*args, **kwargs):
|
||||||
|
# Log function start and arguments
|
||||||
|
logger.info(f"Function '{func.__name__}' | args: {args} | kwargs: {kwargs}")
|
||||||
|
try:
|
||||||
|
# Call the original function
|
||||||
|
result = func(*args, **kwargs)
|
||||||
|
# Log function end and return value
|
||||||
|
logger.info(f"Function '{func.__name__}' finished, returned: {result}")
|
||||||
|
return result
|
||||||
|
except Exception as e:
|
||||||
|
# Log any exceptions
|
||||||
|
logger.error(
|
||||||
|
f"Function '{func.__name__}' raised an exception: {e}", exc_info=True
|
||||||
|
)
|
||||||
|
raise
|
||||||
|
|
||||||
|
return wrapper
|
||||||
Loading…
Reference in New Issue
Block a user