2 * Copyright © 2009 Keith Packard <keithp@keithp.com>
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; version 2 of the License.
8 * This program is distributed in the hope that it will be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 * General Public License for more details.
13 * You should have received a copy of the GNU General Public License along
14 * with this program; if not, write to the Free Software Foundation, Inc.,
15 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
19 #include <flite/flite.h>
21 #include <alsa/asoundlib.h>
23 cst_voice *register_cmu_us_kal();
24 static cst_voice *voice;
26 static FILE *pipe_write;
27 static GThread *aoview_flite_thread;
29 static snd_pcm_t *alsa_handle;
32 aoview_flite_task(gpointer data)
41 err = snd_pcm_open(&alsa_handle, "default",
42 SND_PCM_STREAM_PLAYBACK, 0);
46 snd_pcm_close(alsa_handle);
52 while (fgets(line, sizeof (line) - 1, input) != NULL) {
55 wave = flite_text_to_wave(line, voice);
56 if (wave->sample_rate != rate ||
57 wave->num_channels != channels)
59 rate = wave->sample_rate;
60 channels = wave->num_channels;
61 snd_pcm_set_params(alsa_handle,
63 SND_PCM_ACCESS_RW_INTERLEAVED,
69 snd_pcm_prepare(alsa_handle);
70 err = snd_pcm_writei(alsa_handle,
74 fprintf(stderr, "alsa write error %s\n",
76 snd_pcm_drain(alsa_handle);
79 snd_pcm_close(alsa_handle);
85 aoview_flite_stop(void)
92 if (aoview_flite_thread) {
93 g_thread_join(aoview_flite_thread);
94 aoview_flite_thread = NULL;
99 aoview_flite_start(void)
108 voice = register_cmu_us_kal();
110 perror("register voice");
116 pipe_read = fdopen(p[0], "r");
117 pipe_write = fdopen(p[1], "w");
118 g_thread_create(aoview_flite_task, pipe_read, TRUE, &error);