fishyboteso/fishy/engine/common/IEngine.py

71 lines
1.6 KiB
Python
Raw Normal View History

import logging
import traceback
2020-06-01 12:58:18 +00:00
import typing
from threading import Thread
from typing import Callable
from playsound import playsound
2020-10-17 19:06:07 +00:00
from fishy.gui.funcs import GUIFuncsMock
from fishy.helper import helper
2020-06-01 12:58:18 +00:00
if typing.TYPE_CHECKING:
from fishy.gui import GUI
class IEngine:
2020-06-01 12:58:18 +00:00
2020-10-17 19:06:07 +00:00
def __init__(self, gui_ref: 'Callable[[], GUI]'):
2020-06-01 12:58:18 +00:00
self.get_gui = gui_ref
# 0 - off, 1 - running, 2 - quitting
self.state = 0
self.window = None
2020-06-01 12:58:18 +00:00
self.thread = None
@property
def gui(self):
if self.get_gui is None:
return GUIFuncsMock()
2020-06-01 12:58:18 +00:00
return self.get_gui().funcs
@property
def start(self):
return self.state == 1
2020-06-01 12:58:18 +00:00
def toggle_start(self):
if self.state == 0:
self.turn_on()
else:
self.turn_on()
def turn_on(self):
self.state = 1
self.thread = Thread(target=self._crash_safe)
self.thread.start()
def turn_off(self):
"""
this method only signals the thread to close using start flag,
its the responsibility of the thread to shut turn itself off
"""
if self.state == 1:
logging.info("turning off...")
self.state = 2
else:
logging.error("engine already signaled to turn off")
# todo: implement force turn off on repeated calls
# noinspection PyBroadException
def _crash_safe(self):
self.gui.bot_started(True)
try:
self.run()
except Exception:
traceback.print_exc()
self.state = 0
self.gui.bot_started(False)
2020-06-01 12:58:18 +00:00
def run(self):
raise NotImplementedError