unify more loops, remove spaces
This commit is contained in:
@ -19,7 +19,7 @@ class driver(speechDriver):
|
||||
def shutdown(self):
|
||||
if self._isInitialized:
|
||||
self.cancel()
|
||||
self._isInitialized = False
|
||||
self._isInitialized = False
|
||||
print('Speech Debug Driver: Shutdown')
|
||||
|
||||
def speak(self,text, queueable=True):
|
||||
@ -33,42 +33,42 @@ class driver(speechDriver):
|
||||
def cancel(self):
|
||||
if not self._isInitialized:
|
||||
return
|
||||
print('Speech Debug Driver: Cancel')
|
||||
print('Speech Debug Driver: Cancel')
|
||||
|
||||
def setCallback(self, callback):
|
||||
print('Speech Debug Driver: setCallback')
|
||||
print('Speech Debug Driver: setCallback')
|
||||
|
||||
def clear_buffer(self):
|
||||
if not self._isInitialized:
|
||||
return
|
||||
print('Speech Debug Driver: clear_buffer')
|
||||
print('Speech Debug Driver: clear_buffer')
|
||||
|
||||
def setVoice(self, voice):
|
||||
if not self._isInitialized:
|
||||
return
|
||||
print('Speech Debug Driver: setVoice:' + str(voice))
|
||||
print('Speech Debug Driver: setVoice:' + str(voice))
|
||||
|
||||
def setPitch(self, pitch):
|
||||
if not self._isInitialized:
|
||||
return
|
||||
print('Speech Debug Driver: setPitch:' + str(pitch))
|
||||
print('Speech Debug Driver: setPitch:' + str(pitch))
|
||||
|
||||
def setRate(self, rate):
|
||||
if not self._isInitialized:
|
||||
return
|
||||
print('Speech Debug Driver: setRate:' + str(rate))
|
||||
print('Speech Debug Driver: setRate:' + str(rate))
|
||||
|
||||
def setModule(self, module):
|
||||
if not self._isInitialized:
|
||||
return
|
||||
print('Speech Debug Driver: setModule:' + str(module))
|
||||
return
|
||||
print('Speech Debug Driver: setModule:' + str(module))
|
||||
|
||||
def setLanguage(self, language):
|
||||
if not self._isInitialized:
|
||||
return
|
||||
print('Speech Debug Driver: setLanguage:' + str(language))
|
||||
print('Speech Debug Driver: setLanguage:' + str(language))
|
||||
|
||||
def setVolume(self, volume):
|
||||
if not self._isInitialized:
|
||||
return
|
||||
return
|
||||
print('Speech Debug Driver: setVolume:' + str(volume))
|
||||
|
@ -15,19 +15,19 @@ class driver(speechDriver):
|
||||
def __init__(self):
|
||||
speechDriver.__init__(self)
|
||||
def initialize(self, environment):
|
||||
self.env = environment
|
||||
self.env = environment
|
||||
try:
|
||||
self.server = pexpect.spawn('tclsh ' + self.env['runtime']['settingsManager'].getSetting('speech', 'serverPath'))
|
||||
self._isInitialized = True
|
||||
self._isInitialized = True
|
||||
except Exception as e:
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:initialize:' + str(e),debug.debugLevel.ERROR)
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:initialize:' + str(e),debug.debugLevel.ERROR)
|
||||
|
||||
def shutdown(self):
|
||||
if self.server:
|
||||
try:
|
||||
self.server.terminate()
|
||||
except Exception as e:
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:shutdown:self.server.terminate():' + str(e),debug.debugLevel.ERROR)
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:shutdown:self.server.terminate():' + str(e),debug.debugLevel.ERROR)
|
||||
|
||||
def speak(self,text, queueable=True):
|
||||
if not self._isInitialized:
|
||||
@ -45,7 +45,7 @@ class driver(speechDriver):
|
||||
cleanText = 'tts_say \"' + cleanText +'\"'
|
||||
self.server.sendline(cleanText)
|
||||
except Exception as e:
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:speak:self.server.sendline():' + str(e),debug.debugLevel.ERROR)
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:speak:self.server.sendline():' + str(e),debug.debugLevel.ERROR)
|
||||
|
||||
def cancel(self):
|
||||
if not self._isInitialized:
|
||||
@ -54,7 +54,7 @@ class driver(speechDriver):
|
||||
self.server.sendline('stop')
|
||||
except Exception as e:
|
||||
print(e)
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:cancel:self.server.sendline():' + str(e),debug.debugLevel.ERROR)
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:cancel:self.server.sendline():' + str(e),debug.debugLevel.ERROR)
|
||||
|
||||
def setRate(self, rate):
|
||||
if not self._isInitialized:
|
||||
@ -62,7 +62,7 @@ class driver(speechDriver):
|
||||
try:
|
||||
self.server.sendline('tts_set_speech_rate ' + str(int(rate * 400)))
|
||||
except Exception as e:
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:setRate:self.server.sendline():' + str(e),debug.debugLevel.ERROR)
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:setRate:self.server.sendline():' + str(e),debug.debugLevel.ERROR)
|
||||
|
||||
def setLanguage(self, language):
|
||||
if not self._isInitialized:
|
||||
|
@ -14,13 +14,13 @@ class driver(speechDriver):
|
||||
self._es = None
|
||||
|
||||
def initialize(self, environment):
|
||||
self.env = environment
|
||||
self.env = environment
|
||||
try:
|
||||
from espeak import espeak
|
||||
self._es = espeak
|
||||
self._isInitialized = True
|
||||
except Exception as e:
|
||||
self.env['runtime']['debug'].writeDebugOut(str(e),debug.debugLevel.ERROR)
|
||||
self.env['runtime']['debug'].writeDebugOut(str(e),debug.debugLevel.ERROR)
|
||||
self._initialized = False
|
||||
|
||||
def speak(self,text, interrupt=True):
|
||||
@ -30,10 +30,10 @@ class driver(speechDriver):
|
||||
self.cancel()
|
||||
if self.language != None:
|
||||
if self.language != '':
|
||||
self._es.set_voice(self.language)
|
||||
self._es.set_voice(self.language)
|
||||
elif self.voice != None:
|
||||
if self.voice != '':
|
||||
self._es.set_voice(self.voice)
|
||||
if self.voice != '':
|
||||
self._es.set_voice(self.voice)
|
||||
self._es.synth(text)
|
||||
|
||||
def cancel(self):
|
||||
|
@ -27,11 +27,11 @@ class driver(speechDriver):
|
||||
self.speechThread = Thread(target=self.worker)
|
||||
self.lock = Lock()
|
||||
self.textQueue = speakQueue()
|
||||
def initialize(self, environment):
|
||||
def initialize(self, environment):
|
||||
self.env = environment
|
||||
self.minVolume = self.env['runtime']['settingsManager'].getSettingAsInt('speech', 'fenrirMinVolume')
|
||||
self.maxVolume = self.env['runtime']['settingsManager'].getSettingAsInt('speech', 'fenrirMaxVolume')
|
||||
self.minPitch = self.env['runtime']['settingsManager'].getSettingAsInt('speech', 'fenrirMinPitch')
|
||||
self.maxVolume = self.env['runtime']['settingsManager'].getSettingAsInt('speech', 'fenrirMaxVolume')
|
||||
self.minPitch = self.env['runtime']['settingsManager'].getSettingAsInt('speech', 'fenrirMinPitch')
|
||||
self.maxPitch = self.env['runtime']['settingsManager'].getSettingAsInt('speech', 'fenrirMaxPitch')
|
||||
self.minRate = self.env['runtime']['settingsManager'].getSettingAsInt('speech', 'fenrirMinRate')
|
||||
self.maxRate = self.env['runtime']['settingsManager'].getSettingAsInt('speech', 'fenrirMaxRate')
|
||||
@ -40,23 +40,23 @@ class driver(speechDriver):
|
||||
if self.speechCommand == '':
|
||||
self.speechCommand = 'espeak -a fenrirVolume -s fenrirRate -p fenrirPitch -v fenrirVoice -- "fenrirText"'
|
||||
if False: #for debugging overwrite here
|
||||
#self.speechCommand = 'spd-say --wait -r 100 -i 100 "fenrirText"'
|
||||
self.speechCommand = 'flite -t "fenrirText"'
|
||||
#self.speechCommand = 'spd-say --wait -r 100 -i 100 "fenrirText"'
|
||||
self.speechCommand = 'flite -t "fenrirText"'
|
||||
|
||||
self._isInitialized = True
|
||||
self._isInitialized = True
|
||||
if self._isInitialized:
|
||||
self.speechThread.start()
|
||||
self.speechThread.start()
|
||||
def shutdown(self):
|
||||
if not self._isInitialized:
|
||||
return
|
||||
self.cancel()
|
||||
self.cancel()
|
||||
self.textQueue.put(-1)
|
||||
|
||||
def speak(self,text, queueable=True):
|
||||
if not self._isInitialized:
|
||||
return
|
||||
if not queueable:
|
||||
self.cancel()
|
||||
if not queueable:
|
||||
self.cancel()
|
||||
utterance = {
|
||||
'text': text,
|
||||
'volume': self.volume,
|
||||
@ -65,7 +65,7 @@ class driver(speechDriver):
|
||||
'module': self.module,
|
||||
'language': self.language,
|
||||
'voice': self.voice,
|
||||
}
|
||||
}
|
||||
self.textQueue.put(utterance.copy())
|
||||
|
||||
def cancel(self):
|
||||
@ -77,20 +77,20 @@ class driver(speechDriver):
|
||||
try:
|
||||
self.proc.terminate()
|
||||
except Exception as e:
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:Cancel:self.proc.terminate():' + str(e),debug.debugLevel.WARNING)
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:Cancel:self.proc.terminate():' + str(e),debug.debugLevel.WARNING)
|
||||
try:
|
||||
self.proc.kill()
|
||||
except Exception as e:
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:Cancel:self.proc.kill():' + str(e),debug.debugLevel.WARNING)
|
||||
self.proc = None
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:Cancel:self.proc.kill():' + str(e),debug.debugLevel.WARNING)
|
||||
self.proc = None
|
||||
self.lock.release()
|
||||
def setCallback(self, callback):
|
||||
print('SpeechDummyDriver: setCallback')
|
||||
print('SpeechDummyDriver: setCallback')
|
||||
|
||||
def clear_buffer(self):
|
||||
if not self._isInitialized:
|
||||
return
|
||||
self.textQueue.clear()
|
||||
self.textQueue.clear()
|
||||
|
||||
def setVoice(self, voice):
|
||||
if not self._isInitialized:
|
||||
@ -137,7 +137,7 @@ class driver(speechDriver):
|
||||
if not 'text' in utterance:
|
||||
continue
|
||||
if not isinstance(utterance['text'],str):
|
||||
continue
|
||||
continue
|
||||
if utterance['text'] == '':
|
||||
continue
|
||||
# check for valid data fields
|
||||
@ -178,13 +178,13 @@ class driver(speechDriver):
|
||||
popenSpeechCommand[idx] = word
|
||||
|
||||
try:
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:worker:' + ' '.join(popenSpeechCommand),debug.debugLevel.INFO)
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:worker:' + ' '.join(popenSpeechCommand),debug.debugLevel.INFO)
|
||||
self.lock.acquire(True)
|
||||
self.proc = Popen(popenSpeechCommand, stdin=None, stdout=None, stderr=None, shell=False)
|
||||
self.lock.release()
|
||||
self.proc.wait()
|
||||
except Exception as e:
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:worker:' + str(e),debug.debugLevel.ERROR)
|
||||
self.env['runtime']['debug'].writeDebugOut('speechDriver:worker:' + str(e),debug.debugLevel.ERROR)
|
||||
|
||||
self.lock.acquire(True)
|
||||
self.proc = None
|
||||
|
@ -14,12 +14,12 @@ class driver(speechDriver):
|
||||
speechDriver.__init__(self)
|
||||
self._engine = None
|
||||
def initialize(self, environment):
|
||||
self.env = environment
|
||||
self.env = environment
|
||||
def shutdown(self):
|
||||
if self._isInitialized:
|
||||
self.cancel()
|
||||
self.cancel()
|
||||
self._engine.endLoop()
|
||||
self._initialized = False
|
||||
self._initialized = False
|
||||
def eventLoop(self):
|
||||
self._engine.startLoop()
|
||||
def startEngine(self):
|
||||
@ -28,17 +28,17 @@ class driver(speechDriver):
|
||||
if self.module != '':
|
||||
self._engine = pyttsx3.init(self.module)
|
||||
else:
|
||||
self._engine = pyttsx3.init()
|
||||
self._engine = pyttsx3.init()
|
||||
self.eventLoopThread = Thread(target=self.eventLoop)
|
||||
self._isInitialized = True
|
||||
self.eventLoopThread.start()
|
||||
except Exception as e:
|
||||
self.env['runtime']['debug'].writeDebugOut('SpeechDriver:initialize:' + str(e),debug.debugLevel.ERROR)
|
||||
self.env['runtime']['debug'].writeDebugOut('SpeechDriver:initialize:' + str(e),debug.debugLevel.ERROR)
|
||||
|
||||
def speak(self,text, interrupt=True):
|
||||
if not self._isInitialized:
|
||||
self.startEngine()
|
||||
if not self._isInitialized:
|
||||
if not self._isInitialized:
|
||||
return
|
||||
if not interrupt:
|
||||
self.cancel()
|
||||
@ -51,15 +51,15 @@ class driver(speechDriver):
|
||||
except Exception as e:
|
||||
self.env['runtime']['debug'].writeDebugOut('SpeechDriver:speak:rate:' + str(e),debug.debugLevel.ERROR)
|
||||
try:
|
||||
self._engine.setProperty('pitch', self.pitch)
|
||||
self._engine.setProperty('pitch', self.pitch)
|
||||
except Exception as e:
|
||||
self.env['runtime']['debug'].writeDebugOut('SpeechDriver:speak:pitch:' + str(e),debug.debugLevel.ERROR)
|
||||
self.env['runtime']['debug'].writeDebugOut('SpeechDriver:speak:pitch:' + str(e),debug.debugLevel.ERROR)
|
||||
if self.language != None:
|
||||
if self.language != '':
|
||||
try:
|
||||
self._engine.setProperty('voice', self.language)
|
||||
self._engine.setProperty('voice', self.language)
|
||||
except Exception as e:
|
||||
self.env['runtime']['debug'].writeDebugOut('SpeechDriver:speak:language:' + str(e),debug.debugLevel.ERROR)
|
||||
self.env['runtime']['debug'].writeDebugOut('SpeechDriver:speak:language:' + str(e),debug.debugLevel.ERROR)
|
||||
|
||||
elif self.voice != None:
|
||||
if self.voice != '':
|
||||
|
Reference in New Issue
Block a user