| /* |
| * Copyright (C) 2012 Google Inc. All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions |
| * are met: |
| * |
| * 1. Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * 2. Redistributions in binary form must reproduce the above copyright |
| * notice, this list of conditions and the following disclaimer in the |
| * documentation and/or other materials provided with the distribution. |
| * |
| * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY |
| * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
| * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
| * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY |
| * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
| * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
| * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
| * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF |
| * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| #include "config.h" |
| #include "MockWebSpeechRecognizer.h" |
| |
| #if ENABLE(SCRIPTED_SPEECH) |
| |
| #include "WebSpeechRecognitionResult.h" |
| #include "WebSpeechRecognizerClient.h" |
| |
| using namespace WebKit; |
| |
| namespace { |
| |
| // Task class for calling a client function that does not take any parameters. |
| typedef void (WebSpeechRecognizerClient::*ClientFunctionPointer)(const WebSpeechRecognitionHandle&); |
| class ClientCallTask : public MockWebSpeechRecognizer::Task { |
| public: |
| ClientCallTask(MockWebSpeechRecognizer* mock, ClientFunctionPointer function) |
| : MockWebSpeechRecognizer::Task(mock) |
| , m_function(function) |
| { |
| } |
| |
| virtual void run() OVERRIDE { (m_recognizer->client()->*m_function)(m_recognizer->handle()); } |
| |
| private: |
| ClientFunctionPointer m_function; |
| }; |
| |
| // Task for delivering a result event. |
| class ResultTask : public MockWebSpeechRecognizer::Task { |
| public: |
| ResultTask(MockWebSpeechRecognizer* mock, const WebString transcript, float confidence) |
| : MockWebSpeechRecognizer::Task(mock) |
| , m_transcript(transcript) |
| , m_confidence(confidence) |
| { |
| } |
| |
| virtual void run() OVERRIDE |
| { |
| WebVector<WebString> transcripts(static_cast<size_t>(1)); |
| WebVector<float> confidences(static_cast<size_t>(1)); |
| transcripts[0] = m_transcript; |
| confidences[0] = m_confidence; |
| WebSpeechRecognitionResult res; |
| res.assign(transcripts, confidences, true); |
| |
| m_recognizer->client()->didReceiveResult(m_recognizer->handle(), res, 0, WebVector<WebSpeechRecognitionResult>()); |
| } |
| |
| private: |
| WebString m_transcript; |
| float m_confidence; |
| }; |
| |
| // Task for delivering a nomatch event. |
| class NoMatchTask : public MockWebSpeechRecognizer::Task { |
| public: |
| NoMatchTask(MockWebSpeechRecognizer* mock) : MockWebSpeechRecognizer::Task(mock) { } |
| virtual void run() OVERRIDE { m_recognizer->client()->didReceiveNoMatch(m_recognizer->handle(), WebSpeechRecognitionResult()); } |
| }; |
| |
| // Task for delivering an error event. |
| class ErrorTask : public MockWebSpeechRecognizer::Task { |
| public: |
| ErrorTask(MockWebSpeechRecognizer* mock, int code, const WebString& message) |
| : MockWebSpeechRecognizer::Task(mock) |
| , m_code(code) |
| , m_message(message) |
| { |
| } |
| |
| virtual void run() OVERRIDE { m_recognizer->client()->didReceiveError(m_recognizer->handle(), m_message, static_cast<WebSpeechRecognizerClient::ErrorCode>(m_code)); } |
| |
| private: |
| int m_code; |
| WebString m_message; |
| }; |
| |
| } // namespace |
| |
| PassOwnPtr<MockWebSpeechRecognizer> MockWebSpeechRecognizer::create() |
| { |
| return adoptPtr(new MockWebSpeechRecognizer()); |
| } |
| |
| void MockWebSpeechRecognizer::start(const WebSpeechRecognitionHandle& handle, const WebSpeechRecognitionParams& params, WebSpeechRecognizerClient* client) |
| { |
| m_wasAborted = false; |
| m_handle = handle; |
| m_client = client; |
| |
| m_taskQueue.append(adoptPtr(new ClientCallTask(this, &WebSpeechRecognizerClient::didStart))); |
| m_taskQueue.append(adoptPtr(new ClientCallTask(this, &WebSpeechRecognizerClient::didStartAudio))); |
| m_taskQueue.append(adoptPtr(new ClientCallTask(this, &WebSpeechRecognizerClient::didStartSound))); |
| |
| if (!m_mockTranscripts.isEmpty()) { |
| ASSERT(m_mockTranscripts.size() == m_mockConfidences.size()); |
| |
| for (size_t i = 0; i < m_mockTranscripts.size(); ++i) |
| m_taskQueue.append(adoptPtr(new ResultTask(this, m_mockTranscripts[i], m_mockConfidences[i]))); |
| |
| m_mockTranscripts.clear(); |
| m_mockConfidences.clear(); |
| } else |
| m_taskQueue.append(adoptPtr(new NoMatchTask(this))); |
| |
| m_taskQueue.append(adoptPtr(new ClientCallTask(this, &WebSpeechRecognizerClient::didEndSound))); |
| m_taskQueue.append(adoptPtr(new ClientCallTask(this, &WebSpeechRecognizerClient::didEndAudio))); |
| m_taskQueue.append(adoptPtr(new ClientCallTask(this, &WebSpeechRecognizerClient::didEnd))); |
| |
| startTaskQueue(); |
| } |
| |
| void MockWebSpeechRecognizer::stop(const WebSpeechRecognitionHandle& handle, WebSpeechRecognizerClient* client) |
| { |
| m_handle = handle; |
| m_client = client; |
| |
| // FIXME: Implement. |
| ASSERT_NOT_REACHED(); |
| } |
| |
| void MockWebSpeechRecognizer::abort(const WebSpeechRecognitionHandle& handle, WebSpeechRecognizerClient* client) |
| { |
| m_handle = handle; |
| m_client = client; |
| |
| clearTaskQueue(); |
| m_wasAborted = true; |
| m_taskQueue.append(adoptPtr(new ClientCallTask(this, &WebSpeechRecognizerClient::didEnd))); |
| startTaskQueue(); |
| } |
| |
| void MockWebSpeechRecognizer::addMockResult(const WebString& transcript, float confidence) |
| { |
| m_mockTranscripts.append(transcript); |
| m_mockConfidences.append(confidence); |
| } |
| |
| void MockWebSpeechRecognizer::setError(int code, const WebString& message) |
| { |
| clearTaskQueue(); |
| m_taskQueue.append(adoptPtr(new ErrorTask(this, code, message))); |
| m_taskQueue.append(adoptPtr(new ClientCallTask(this, &WebSpeechRecognizerClient::didEnd))); |
| startTaskQueue(); |
| } |
| |
| MockWebSpeechRecognizer::MockWebSpeechRecognizer() |
| : m_wasAborted(false) |
| , m_taskQueueRunning(false) |
| { |
| } |
| |
| MockWebSpeechRecognizer::~MockWebSpeechRecognizer() |
| { |
| } |
| |
| void MockWebSpeechRecognizer::startTaskQueue() |
| { |
| if (m_taskQueueRunning) |
| return; |
| postTask(new StepTask(this)); |
| m_taskQueueRunning = true; |
| } |
| |
| void MockWebSpeechRecognizer::clearTaskQueue() |
| { |
| m_taskQueue.clear(); |
| m_taskQueueRunning = false; |
| } |
| |
| void MockWebSpeechRecognizer::StepTask::runIfValid() |
| { |
| if (m_object->m_taskQueue.isEmpty()) { |
| m_object->m_taskQueueRunning = false; |
| return; |
| } |
| |
| OwnPtr<Task> task = m_object->m_taskQueue[0].release(); |
| m_object->m_taskQueue.remove(0); |
| task->run(); |
| |
| if (m_object->m_taskQueue.isEmpty()) { |
| m_object->m_taskQueueRunning = false; |
| return; |
| } |
| |
| postTask(new StepTask(m_object)); |
| } |
| |
| #endif // ENABLE(SCRIPTED_SPEECH) |