/*
 * Copyright (C) 2020 Apple 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 INC. 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 INC. 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.
 */


#pragma once

#include "SpeechRecognitionProvider.h"

namespace WebCore {

class DummySpeechRecognitionProvider final : public SpeechRecognitionProvider {
public:
    class DummySpeechRecognitionConnection final : public SpeechRecognitionConnection {
    public:
        static Ref<DummySpeechRecognitionConnection> create()
        {
            return adoptRef(*new DummySpeechRecognitionConnection());
        }
        void registerClient(SpeechRecognitionConnectionClient&) final { }
        void unregisterClient(SpeechRecognitionConnectionClient&) final { }
        void start(SpeechRecognitionConnectionClientIdentifier, const String&, bool, bool, uint64_t, ClientOrigin&&, FrameIdentifier) final { }
        void stop(SpeechRecognitionConnectionClientIdentifier) final { }
        void abort(SpeechRecognitionConnectionClientIdentifier) final { }
        void didReceiveUpdate(SpeechRecognitionUpdate&&) final { }
    };
    DummySpeechRecognitionProvider() = default;
    SpeechRecognitionConnection& speechRecognitionConnection()
    {
        if (!m_connection)
            m_connection = DummySpeechRecognitionConnection::create();
        return *m_connection;
    }
private:
    RefPtr<DummySpeechRecognitionConnection> m_connection;
};

} // namespace WebCore
