Files
DemonEditor/app/commons.py

114 lines
2.8 KiB
Python
Raw Normal View History

2017-11-25 15:55:24 +03:00
import logging
2021-10-18 19:36:19 +03:00
from collections import defaultdict
2017-10-26 01:23:05 +03:00
from functools import wraps
from threading import Thread, Timer
2017-10-26 01:23:05 +03:00
2017-11-14 19:20:16 +03:00
from gi.repository import GLib
2017-12-21 12:38:45 +03:00
_LOG_FILE = "demon-editor.log"
2022-09-22 20:09:03 +03:00
LOG_DATE_FORMAT = "%d-%m-%y %H:%M:%S"
2021-10-21 18:53:57 +03:00
LOGGER_NAME = "main_logger"
2022-09-22 20:09:03 +03:00
LOG_FORMAT = "%(asctime)s %(message)s"
2019-05-12 16:26:19 +03:00
def init_logger():
2021-10-21 18:53:57 +03:00
logging.Logger(LOGGER_NAME)
2019-05-12 16:26:19 +03:00
logging.basicConfig(level=logging.INFO,
2022-09-22 20:09:03 +03:00
format=LOG_FORMAT,
datefmt=LOG_DATE_FORMAT,
2020-05-19 11:39:12 +03:00
handlers=[logging.FileHandler(_LOG_FILE), logging.StreamHandler()])
2019-05-12 16:26:19 +03:00
log("Logging is enabled.", level=logging.INFO)
2017-11-25 15:55:24 +03:00
2020-07-11 12:58:03 +03:00
def log(message, level=logging.ERROR, debug=False, fmt_message="{}"):
""" The main logging function. """
2021-10-21 18:53:57 +03:00
logger = logging.getLogger(LOGGER_NAME)
2020-07-11 12:58:03 +03:00
if debug:
from traceback import format_exc
logger.log(level, fmt_message.format(format_exc()))
else:
logger.log(level, message)
2017-11-25 15:55:24 +03:00
2017-11-14 19:20:16 +03:00
def run_idle(func):
""" Runs a function with a lower priority """
@wraps(func)
def wrapper(*args, **kwargs):
GLib.idle_add(func, *args, **kwargs)
return wrapper
2017-10-26 01:23:05 +03:00
def run_task(func):
""" Runs function in separate thread """
@wraps(func)
def wrapper(*args, **kwargs):
2017-11-14 19:20:16 +03:00
task = Thread(target=func, args=args, kwargs=kwargs, daemon=True)
2017-10-26 01:23:05 +03:00
task.start()
2017-11-25 15:55:24 +03:00
return wrapper
def run_with_delay(timeout=5):
""" Starts the function with a delay.
If the previous timer still works, it will canceled!
"""
def run_with(func):
timer = None
@wraps(func)
def wrapper(*args, **kwargs):
nonlocal timer
if timer and timer.is_alive():
timer.cancel()
def run():
GLib.idle_add(func, *args, **kwargs, priority=GLib.PRIORITY_LOW)
timer = Timer(interval=timeout, function=run)
timer.start()
return wrapper
return run_with
2022-05-09 23:57:50 +03:00
def get_size_from_bytes(size):
""" Simple convert function from bytes to other units like K, M or G. """
try:
b = float(size)
except ValueError:
return size
else:
kb, mb, gb = 1024.0, 1048576.0, 1073741824.0
if b < kb:
return str(b)
elif kb <= b < mb:
return f"{b / kb:.1f} K"
elif mb <= b < gb:
return f"{b / mb:.1f} M"
elif gb <= b:
return f"{b / gb:.1f} G"
2021-10-18 19:36:19 +03:00
class DefaultDict(defaultdict):
""" Extended to support functions with params as default factory. """
def __missing__(self, key):
if self.default_factory:
value = self[key] = self.default_factory(key)
return value
return super().__missing__(key)
def get(self, key, default=None):
return self[key]
2017-10-26 01:23:05 +03:00
if __name__ == "__main__":
pass