# Copyright 2017 Mycroft AI Inc. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # import subprocess from .tts import TTS, TTSValidator class ESpeak(TTS): """TTS module for generating speech using ESpeak.""" def __init__(self, lang, config): super(ESpeak, self).__init__(lang, config, ESpeakValidator(self)) def get_tts(self, sentence, wav_file): """Generate WAV from sentence, phonemes aren't supported. Args: sentence (str): sentence to generate audio for wav_file (str): output file Returns: tuple ((str) file location, None) """ # Create Argument String for Espeak arguments = ['espeak', '-v', self.lang + '+' + self.voice] amplitude = self.config.get('amplitude') if amplitude: arguments.append('-a '+amplitude) gap = self.config.get('gap') if gap: arguments.append('-g '+gap) capital = self.config.get('capital') if capital: arguments.append('-k '+capital) pitch = self.config.get('pitch') if pitch: arguments.append('-p '+pitch) speed = self.config.get('speed') if speed: arguments.append('-s '+speed) arguments.extend(['-w', wav_file, sentence]) subprocess.call(arguments) return wav_file, None class ESpeakValidator(TTSValidator): def __init__(self, tts): super(ESpeakValidator, self).__init__(tts) def validate_lang(self): # TODO pass def validate_connection(self): try: subprocess.call(['espeak', '--version']) except Exception: raise Exception('ESpeak is not installed. Please install it on ' 'your system and restart Mycroft.') def get_tts_class(self): return ESpeak