blob: 526a1282f5387dbcd483c53978530d7c1c72b90e [file] [log] [blame]
Ivo Creusen3ce44a32019-10-31 14:38:11 +01001/*
2 * Copyright (c) 2019 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11#ifndef API_NETEQ_NETEQ_FACTORY_H_
12#define API_NETEQ_NETEQ_FACTORY_H_
13
14#include <memory>
15
Ivo Creusen68c65722019-11-26 12:29:05 +010016#include "api/audio_codecs/audio_decoder_factory.h"
Ivo Creusen3ce44a32019-10-31 14:38:11 +010017#include "api/neteq/neteq.h"
18#include "system_wrappers/include/clock.h"
19
20namespace webrtc {
21
22// Creates NetEq instances using the settings provided in the config struct.
23class NetEqFactory {
24 public:
25 virtual ~NetEqFactory() = default;
26
Artem Titov0e61fdd2021-07-25 21:50:14 +020027 // Creates a new NetEq object, with parameters set in `config`. The `config`
Ivo Creusen3ce44a32019-10-31 14:38:11 +010028 // object will only have to be valid for the duration of the call to this
29 // method.
Ivo Creusen68c65722019-11-26 12:29:05 +010030 virtual std::unique_ptr<NetEq> CreateNetEq(
31 const NetEq::Config& config,
32 const rtc::scoped_refptr<AudioDecoderFactory>& decoder_factory,
33 Clock* clock) const = 0;
Ivo Creusen3ce44a32019-10-31 14:38:11 +010034};
35
36} // namespace webrtc
37#endif // API_NETEQ_NETEQ_FACTORY_H_