55 lines
1.3 KiB
Python
55 lines
1.3 KiB
Python
#encoding = utf8
|
|
import logging
|
|
|
|
from asr import AsrObserver
|
|
from utils import AsyncTaskQueue
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
class NLPBase(AsrObserver):
|
|
def __init__(self, context, split, callback=None):
|
|
self._ask_queue = AsyncTaskQueue()
|
|
self._context = context
|
|
self._split_handle = split
|
|
self._callback = callback
|
|
|
|
@property
|
|
def callback(self):
|
|
return self._callback
|
|
|
|
@callback.setter
|
|
def callback(self, value):
|
|
self._callback = value
|
|
|
|
def _on_callback(self, txt: str):
|
|
if self._callback is not None:
|
|
self._callback.on_message(txt)
|
|
|
|
async def _request(self, question):
|
|
pass
|
|
|
|
async def _on_close(self):
|
|
pass
|
|
|
|
def process(self, message: str):
|
|
pass
|
|
|
|
def completed(self, message: str):
|
|
logger.info(f'complete:{message}')
|
|
# self._context.pause_talk()
|
|
self.ask(message)
|
|
|
|
def ask(self, question):
|
|
logger.info(f'ask:{question}')
|
|
self._ask_queue.add_task(self._request, question)
|
|
logger.info(f'ask:{question} completed')
|
|
|
|
def stop(self):
|
|
logger.info('NLPBase stop')
|
|
self._ask_queue.add_task(self._on_close)
|
|
self._ask_queue.stop()
|
|
|
|
def pause_talk(self):
|
|
self._ask_queue.clear()
|
|
|