From abd409ed042c380ed5e31c80f07003a7683d895d Mon Sep 17 00:00:00 2001 From: JarbasAI <33701864+JarbasAl@users.noreply.github.com> Date: Tue, 22 Oct 2024 00:12:48 +0100 Subject: [PATCH] fix:improve stop (#260) also stop ongoing TTS partial fix, TODO in code for later --- ovos_workshop/skills/ovos.py | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/ovos_workshop/skills/ovos.py b/ovos_workshop/skills/ovos.py index ad9c2d86..35717807 100644 --- a/ovos_workshop/skills/ovos.py +++ b/ovos_workshop/skills/ovos.py @@ -1237,6 +1237,12 @@ def _handle_session_stop(self, message: Message): except Exception as e: data["error"] = str(e) self.log.exception(f'Failed to stop skill: {self.skill_id}: {e}') + if data["result"] and sess.session_id == "default": + # TODO - track if speech is coming from this skill! + # this is not currently tracked + self.bus.emit(message.reply("mycroft.audio.speech.stop", + {"skill_id": self.skill_id})) + self.bus.emit(message.reply(f"{self.skill_id}.stop.response", data)) def __handle_stop(self, message): @@ -1247,7 +1253,7 @@ def __handle_stop(self, message): self.bus.emit(message.forward(self.skill_id + ".stop")) sess = SessionManager.get(message) try: - stopped = self.stop_session(sess) or self.stop() + stopped = self.stop_session(sess) or self.stop() or False LOG.debug(f"{self.skill_id} stopped: {stopped}") if stopped: self.bus.emit(message.reply("mycroft.stop.handled",