from .music_file import MusicFile
from .mixer import Mixer
-from . import Config, gain, error_print, warn_print
+from .helpers import Config, gain, error_print, warn_print
from .action import Action
class Mapping(RelativeLayout):
self.key_config, self.open_files = self.parse_config()
except Exception as e:
error_print("Error while loading configuration: {}".format(e),
- with_trace=True)
- sys.exit()
+ with_trace=True, exit=True)
else:
self.success()
threading.Thread(name="MSKeyAction", target=key.run,
args=['-'.join(modifiers)]).start()
elif 'ctrl' in modifiers and (keycode[0] == 113 or keycode[0] == '99'):
- self.stop_all_running()
- for thread in threading.enumerate():
- if thread.getName()[0:2] != "MS":
- continue
- thread.join()
-
+ self.leave_application()
sys.exit()
elif 'ctrl' in modifiers and keycode[0] == 114:
threading.Thread(name="MSReload", target=self.reload).start()
return True
+ def leave_application(self):
+ self.keyboard.unbind(on_key_down=self.on_keyboard_down)
+ self.stop_all_running()
+ for music in self.open_files.values():
+ music.stop()
+ for thread in threading.enumerate():
+ if thread.getName()[0:2] == "MS":
+ thread.join()
+ elif thread.__class__ == threading.Timer:
+ thread.cancel()
+ thread.join()
+
# Helpers
def allowed_modifiers(self, modifiers):
allowed = []
try:
config = yaml.safe_load(stream)
except Exception as e:
- error_print("Error while loading config file: {}".format(e))
- sys.exit()
+ error_print("Error while loading config file: {}".format(e),
+ exit=True)
stream.close()
if not isinstance(config, dict):
- raise Exception("Top level config is supposed to be a hash")
+ error_print("Top level config is supposed to be a hash",
+ exit=True)
if 'aliases' in config and isinstance(config['aliases'], dict):
aliases = config['aliases']