From 1a4a934d5eee53d16c86014e99c2f98914b13ebf Mon Sep 17 00:00:00 2001 From: Dominik Riebeling Date: Wed, 22 Feb 2012 22:31:42 +0100 Subject: Don't poll SAPI script output. Wait for the process to signal new data available instead of polling its output. Fixes synchronisation issues with sapi_voice.vbs that were causing FS#12595. Change-Id: I86e844e837ed20f32005fdccf7ec9e8c1efbe983 --- rbutil/rbutilqt/base/ttssapi.cpp | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) (limited to 'rbutil/rbutilqt') diff --git a/rbutil/rbutilqt/base/ttssapi.cpp b/rbutil/rbutilqt/base/ttssapi.cpp index e2587b715f..00c63550d3 100644 --- a/rbutil/rbutilqt/base/ttssapi.cpp +++ b/rbutil/rbutilqt/base/ttssapi.cpp @@ -227,11 +227,8 @@ TTSStatus TTSSapi::voice(QString text,QString wavfile, QString *errStr) *voicestream << query; *voicestream << "SYNC\tbla\r\n"; voicestream->flush(); - char temp[20]; - - //we use this, because waitForReadyRead doesnt work from a different thread - while( voicescript->readLine(temp,20) == 0) - QCoreApplication::processEvents(); + // do NOT poll the output with readLine(), this causes sync issues! + voicescript->waitForReadyRead(); if(!QFileInfo(wavfile).isFile()) { qDebug() << "[TTSSapi] output file does not exist:" << wavfile; -- cgit v1.2.3