-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathstart.py
executable file
·66 lines (53 loc) · 2.22 KB
/
start.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
#!/usr/bin/env python3
import Pulseaudio_Loopback_Tool
from datetime import datetime
import gui_logic
import traceback
import logging
import argparse
import sys
import os
FORMAT = "[{asctime}][{filename}][{lineno:3}][{funcName}][{levelname}] {message}"
LOGGING_LEVEL = logging.DEBUG
def log_exception_handler(error_type, value, tb):
# TODO: Unify logging errors.
the_logger = logging.getLogger("Main")
the_logger.critical("Uncaught exception:\n"
"Type: {}\n"
"Value: {}\n"
"Traceback:\n {}".format(str(error_type), str(value), "".join(traceback.format_tb(tb))))
def setup_logging():
setup_logger = logging.getLogger("Main")
log_format = logging.Formatter(FORMAT, style="{")
os.makedirs("logs", exist_ok=True)
time_string = datetime.now().isoformat()
# log_file_handler = logging.FileHandler("logs/PALT {}.log".format(time_string), mode="w+")
log_latest_handler = logging.FileHandler("logs/PALT Latest.log", mode="w+")
# log_file_handler.setFormatter(log_format)
log_latest_handler.setFormatter(log_format)
log_console_handler = logging.StreamHandler(sys.stdout)
log_console_handler.setFormatter(log_format)
# setup_logger.addHandler(log_file_handler)
setup_logger.addHandler(log_latest_handler)
setup_logger.addHandler(log_console_handler)
setup_logger.setLevel(LOGGING_LEVEL)
sys.excepthook = log_exception_handler
try:
text = 'This program gives a GUI to help users create loopbacks, create virtual sinks, remap sources, and delete ' \
'relevent modules.'
parser = argparse.ArgumentParser(description=text)
parser.add_argument("-o", "--old", help="Use old version", action="store_true")
args = parser.parse_args()
setup_logging()
logger = logging.getLogger("Main")
if args.old:
logger.info("Starting up deprecated version.")
Pulseaudio_Loopback_Tool.setup_window()
logger.info("Window appears to have been closed.")
else:
gui_logic.run_gui()
logger.info("Window appears to have been closed.")
except KeyboardInterrupt:
setup_logging()
logger = logging.getLogger("Main")
logger.info("Found KeyboardInterrupt, doing things.")