2022-01-23 16:56:27 -06:00
|
|
|
# Python imports
|
|
|
|
import builtins
|
2024-12-22 00:50:32 -06:00
|
|
|
import traceback
|
2023-01-29 00:06:52 -06:00
|
|
|
import threading
|
2023-10-18 19:00:33 -05:00
|
|
|
import sys
|
2022-01-23 16:56:27 -06:00
|
|
|
|
|
|
|
# Lib imports
|
|
|
|
|
|
|
|
# Application imports
|
2024-02-10 19:45:23 -06:00
|
|
|
# from libs.db import DB
|
2024-01-11 19:35:04 -06:00
|
|
|
from libs.event_system import EventSystem
|
|
|
|
from libs.endpoint_registry import EndpointRegistry
|
|
|
|
from libs.keybindings import Keybindings
|
|
|
|
from libs.logger import Logger
|
2024-02-25 16:19:14 -06:00
|
|
|
from libs.settings.manager import SettingsManager
|
2022-02-25 17:53:58 -06:00
|
|
|
|
|
|
|
|
2023-10-07 17:12:02 -05:00
|
|
|
|
2022-09-05 18:01:39 -05:00
|
|
|
# NOTE: Threads WILL NOT die with parent's destruction.
|
|
|
|
def threaded_wrapper(fn):
|
|
|
|
def wrapper(*args, **kwargs):
|
2023-11-19 15:37:11 -06:00
|
|
|
thread = threading.Thread(target = fn, args = args, kwargs = kwargs, daemon = False)
|
|
|
|
thread.start()
|
|
|
|
return thread
|
2022-09-05 18:01:39 -05:00
|
|
|
return wrapper
|
2022-01-23 16:56:27 -06:00
|
|
|
|
2022-09-05 18:01:39 -05:00
|
|
|
# NOTE: Threads WILL die with parent's destruction.
|
|
|
|
def daemon_threaded_wrapper(fn):
|
|
|
|
def wrapper(*args, **kwargs):
|
2023-11-19 15:37:11 -06:00
|
|
|
thread = threading.Thread(target = fn, args = args, kwargs = kwargs, daemon = True)
|
|
|
|
thread.start()
|
|
|
|
return thread
|
2022-09-05 18:01:39 -05:00
|
|
|
return wrapper
|
2022-01-23 16:56:27 -06:00
|
|
|
|
2024-12-22 00:50:32 -06:00
|
|
|
def call_chain_wrapper(fn):
|
|
|
|
def wrapper(*args, **kwargs):
|
|
|
|
print()
|
|
|
|
print()
|
|
|
|
for line in traceback.format_stack():
|
|
|
|
print( line.strip() )
|
|
|
|
print()
|
|
|
|
print()
|
|
|
|
|
|
|
|
return fn(*args, **kwargs)
|
|
|
|
return wrapper
|
2022-01-23 16:56:27 -06:00
|
|
|
|
2021-10-10 23:33:58 -05:00
|
|
|
|
2022-01-23 16:56:27 -06:00
|
|
|
# NOTE: Just reminding myself we can add to builtins two different ways...
|
|
|
|
# __builtins__.update({"event_system": Builtins()})
|
2024-02-29 18:50:34 -06:00
|
|
|
builtins.APP_NAME = "<change_me>"
|
2023-09-23 00:12:36 -05:00
|
|
|
|
2022-10-13 20:58:44 -05:00
|
|
|
builtins.keybindings = Keybindings()
|
2022-02-25 17:53:58 -06:00
|
|
|
builtins.event_system = EventSystem()
|
2022-09-05 18:01:39 -05:00
|
|
|
builtins.endpoint_registry = EndpointRegistry()
|
2023-07-30 00:36:52 -05:00
|
|
|
builtins.settings_manager = SettingsManager()
|
2024-02-10 19:45:23 -06:00
|
|
|
# builtins.db = DB()
|
2023-09-17 20:08:09 -05:00
|
|
|
|
|
|
|
settings_manager.load_settings()
|
|
|
|
|
2023-07-30 00:36:52 -05:00
|
|
|
builtins.settings = settings_manager.settings
|
2024-11-08 22:46:07 -06:00
|
|
|
builtins.logger = Logger(
|
|
|
|
settings_manager.get_home_config_path(), \
|
|
|
|
_ch_log_lvl = settings.debugging.ch_log_lvl, \
|
|
|
|
_fh_log_lvl = settings.debugging.fh_log_lvl
|
|
|
|
).get_logger()
|
2022-10-13 20:58:44 -05:00
|
|
|
|
2022-09-05 18:01:39 -05:00
|
|
|
builtins.threaded = threaded_wrapper
|
|
|
|
builtins.daemon_threaded = daemon_threaded_wrapper
|
2024-12-22 00:50:32 -06:00
|
|
|
builtins.call_chain = call_chain_wrapper
|
2023-10-18 19:00:33 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def custom_except_hook(exc_type, exc_value, exc_traceback):
|
|
|
|
if issubclass(exc_type, KeyboardInterrupt):
|
|
|
|
sys.__excepthook__(exc_type, exc_value, exc_traceback)
|
|
|
|
return
|
|
|
|
|
2024-11-08 22:46:07 -06:00
|
|
|
logger.error("Uncaught exception", exc_info = (exc_type, exc_value, exc_traceback))
|
2023-10-18 19:00:33 -05:00
|
|
|
|
2023-11-19 15:37:11 -06:00
|
|
|
sys.excepthook = custom_except_hook
|