2022-09-08 23:58:11 +12:00
|
|
|
import logging
|
2022-06-24 07:26:08 +12:00
|
|
|
import os
|
2022-09-08 23:58:11 +12:00
|
|
|
import platform
|
2022-06-24 07:26:08 +12:00
|
|
|
import sys
|
2022-09-08 23:58:11 +12:00
|
|
|
import time
|
2022-09-08 10:27:37 +12:00
|
|
|
from argparse import Namespace
|
2022-06-24 07:26:08 +12:00
|
|
|
|
2022-09-08 23:58:11 +12:00
|
|
|
import legendary
|
2022-10-26 11:33:49 +13:00
|
|
|
from PyQt5.QtCore import QSettings, QTranslator, QT_VERSION_STR, PYQT_VERSION_STR
|
2022-06-24 07:26:08 +12:00
|
|
|
from PyQt5.QtGui import QIcon
|
|
|
|
from PyQt5.QtWidgets import QApplication
|
|
|
|
|
|
|
|
import rare.resources.resources
|
2022-09-08 11:13:10 +12:00
|
|
|
from rare.utils import paths
|
2022-07-27 02:58:17 +12:00
|
|
|
from rare.utils.misc import set_color_pallete, set_style_sheet
|
2022-06-24 07:26:08 +12:00
|
|
|
|
|
|
|
|
|
|
|
class RareApp(QApplication):
|
2022-09-08 23:58:11 +12:00
|
|
|
logger = logging.getLogger("RareApp")
|
2022-06-24 07:26:08 +12:00
|
|
|
|
2022-09-08 23:58:11 +12:00
|
|
|
def __init__(self, args: Namespace, log_file: str):
|
2022-06-24 07:26:08 +12:00
|
|
|
super(RareApp, self).__init__(sys.argv)
|
|
|
|
self.setQuitOnLastWindowClosed(False)
|
|
|
|
|
|
|
|
self.setApplicationName("Rare")
|
|
|
|
self.setOrganizationName("Rare")
|
2022-09-08 23:58:11 +12:00
|
|
|
|
|
|
|
# Create directories after QStandardPaths has been initialized
|
2022-09-08 11:13:10 +12:00
|
|
|
paths.create_dirs()
|
2022-09-08 23:58:11 +12:00
|
|
|
|
|
|
|
# Clean any existing logging handlers from library imports
|
|
|
|
for handler in logging.root.handlers[:]:
|
|
|
|
logging.root.removeHandler(handler)
|
|
|
|
|
|
|
|
start_time = time.strftime("%y-%m-%d--%H-%M") # year-month-day-hour-minute
|
|
|
|
file_handler = logging.FileHandler(
|
|
|
|
filename=os.path.join(paths.log_dir(), log_file.format(start_time)),
|
|
|
|
encoding="utf-8",
|
|
|
|
)
|
|
|
|
file_handler.setFormatter(fmt=logging.Formatter("[%(name)s] %(levelname)s: %(message)s"))
|
|
|
|
|
|
|
|
# Set up common logging channel to stderr
|
|
|
|
if args.debug:
|
|
|
|
logging.basicConfig(
|
|
|
|
format="[%(name)s] %(levelname)s: %(message)s",
|
|
|
|
level=logging.DEBUG,
|
|
|
|
stream=sys.stderr,
|
|
|
|
)
|
|
|
|
file_handler.setLevel(logging.DEBUG)
|
|
|
|
logging.root.addHandler(file_handler)
|
|
|
|
logging.getLogger().setLevel(level=logging.DEBUG)
|
|
|
|
# keep requests, asyncio and pillow quiet
|
|
|
|
logging.getLogger("requests").setLevel(logging.WARNING)
|
|
|
|
logging.getLogger("urllib3").setLevel(logging.WARNING)
|
|
|
|
logging.getLogger("asyncio").setLevel(logging.WARNING)
|
|
|
|
self.logger.info(
|
|
|
|
f"Launching Rare version {rare.__version__} Codename: {rare.code_name}\n"
|
|
|
|
f" - Using Legendary {legendary.__version__} Codename: {legendary.__codename__} as backend\n"
|
|
|
|
f" - Operating System: {platform.system()}, Python version: {platform.python_version()}\n"
|
|
|
|
f" - Running {sys.executable} {' '.join(sys.argv)}\n"
|
|
|
|
f" - Qt version: {QT_VERSION_STR}, PyQt version: {PYQT_VERSION_STR}"
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
logging.basicConfig(
|
|
|
|
format="[%(name)s] %(levelname)s: %(message)s",
|
|
|
|
level=logging.INFO,
|
|
|
|
stream=sys.stderr,
|
|
|
|
)
|
|
|
|
file_handler.setLevel(logging.DEBUG)
|
|
|
|
logging.root.addHandler(file_handler)
|
|
|
|
self.logger.info(f"Launching Rare version {rare.__version__}")
|
|
|
|
self.logger.info(f"Operating System: {platform.system()}")
|
|
|
|
|
2022-06-24 07:26:08 +12:00
|
|
|
self.settings = QSettings()
|
|
|
|
|
|
|
|
# Translator
|
|
|
|
self.translator = QTranslator()
|
|
|
|
self.qt_translator = QTranslator()
|
|
|
|
|
|
|
|
# Style
|
|
|
|
# lk: this is a bit silly but serves well until we have a class
|
|
|
|
# lk: store the default qt style name from the system on startup as a property for later reference
|
|
|
|
self.setProperty("rareDefaultQtStyle", self.style().objectName())
|
|
|
|
if (
|
|
|
|
self.settings.value("color_scheme", None) is None
|
|
|
|
and self.settings.value("style_sheet", None) is None
|
|
|
|
):
|
|
|
|
self.settings.setValue("color_scheme", "")
|
|
|
|
self.settings.setValue("style_sheet", "RareStyle")
|
|
|
|
|
|
|
|
if color_scheme := self.settings.value("color_scheme", False):
|
|
|
|
self.settings.setValue("style_sheet", "")
|
|
|
|
set_color_pallete(color_scheme)
|
|
|
|
elif style_sheet := self.settings.value("style_sheet", False):
|
|
|
|
self.settings.setValue("color_scheme", "")
|
|
|
|
set_style_sheet(style_sheet)
|
|
|
|
self.setWindowIcon(QIcon(":/images/Rare.png"))
|
|
|
|
|
|
|
|
def load_translator(self, lang: str):
|
2022-09-08 11:13:10 +12:00
|
|
|
if os.path.isfile(f := os.path.join(paths.resources_path, "languages", f"{lang}.qm")):
|
2022-06-24 07:26:08 +12:00
|
|
|
self.translator.load(f)
|
|
|
|
self.logger.info(f"Your language is supported: {lang}")
|
|
|
|
elif not lang == "en":
|
|
|
|
self.logger.info("Your language is not supported")
|
|
|
|
self.installTranslator(self.translator)
|
|
|
|
|
|
|
|
# translator for qt stuff
|
2022-09-08 11:13:10 +12:00
|
|
|
if os.path.isfile(f := os.path.join(paths.resources_path, f"qt_{lang}.qm")):
|
2022-06-24 07:26:08 +12:00
|
|
|
self.qt_translator = QTranslator()
|
|
|
|
self.qt_translator.load(f)
|
|
|
|
self.installTranslator(self.qt_translator)
|