OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 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 | 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 | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
11 #ifndef WEBRTC_MODULES_AUDIO_CODING_CODECS_AUDIO_DECODER_FACTORY_H_ | 11 #ifndef WEBRTC_MODULES_AUDIO_CODING_CODECS_AUDIO_DECODER_FACTORY_H_ |
12 #define WEBRTC_MODULES_AUDIO_CODING_CODECS_AUDIO_DECODER_FACTORY_H_ | 12 #define WEBRTC_MODULES_AUDIO_CODING_CODECS_AUDIO_DECODER_FACTORY_H_ |
13 | 13 |
14 #include <memory> | 14 #include <memory> |
15 #include <vector> | 15 #include <vector> |
16 | 16 |
17 #include "webrtc/base/atomicops.h" | |
18 #include "webrtc/base/refcount.h" | |
17 #include "webrtc/modules/audio_coding/codecs/audio_decoder.h" | 19 #include "webrtc/modules/audio_coding/codecs/audio_decoder.h" |
18 #include "webrtc/modules/audio_coding/codecs/audio_format.h" | 20 #include "webrtc/modules/audio_coding/codecs/audio_format.h" |
19 | 21 |
20 namespace webrtc { | 22 namespace webrtc { |
21 | 23 |
22 // A factory that creates AudioDecoders. | 24 // A factory that creates AudioDecoders. |
23 // NOTE: This class is still under development and may change without notice. | 25 // NOTE: This class is still under development and may change without notice. |
24 class AudioDecoderFactory { | 26 class AudioDecoderFactory : public rtc::RefCountInterface { |
25 public: | 27 public: |
26 virtual ~AudioDecoderFactory() = default; | 28 virtual ~AudioDecoderFactory() = default; |
27 | 29 |
28 virtual std::vector<SdpAudioFormat> GetSupportedFormats() = 0; | 30 virtual std::vector<SdpAudioFormat> GetSupportedFormats() = 0; |
29 | 31 |
30 virtual std::unique_ptr<AudioDecoder> MakeAudioDecoder( | 32 virtual std::unique_ptr<AudioDecoder> MakeAudioDecoder( |
31 const SdpAudioFormat& format) = 0; | 33 const SdpAudioFormat& format) = 0; |
34 | |
35 int AddRef() const override { | |
ossu
2016/05/18 11:59:56
Put these in .cc-file?
Pro: cleaner
Con: slower (a
kwiberg-webrtc
2016/05/18 14:03:15
Slower how? It's a virtual call either way.
ossu
2016/05/18 14:42:20
Yeah, I guess as long as we inherit from rtc::RefC
kwiberg-webrtc
2016/05/18 15:48:27
Making them final would essentially make them not
| |
36 return rtc::AtomicOps::Increment(&ref_count_); | |
37 } | |
38 | |
39 int Release() const override { | |
40 int count = rtc::AtomicOps::Decrement(&ref_count_); | |
41 if (!count) { | |
42 delete this; | |
43 } | |
44 return count; | |
45 } | |
46 | |
47 private: | |
48 mutable volatile int ref_count_; | |
kwiberg-webrtc
2016/05/18 14:03:15
Danger, Will Robinson! State in an interface!
Thi
ossu
2016/05/18 14:42:21
Oh, right... We'd get two reference counts and eve
| |
32 }; | 49 }; |
33 | 50 |
34 } // namespace webrtc | 51 } // namespace webrtc |
35 | 52 |
36 #endif // WEBRTC_MODULES_AUDIO_CODING_CODECS_AUDIO_DECODER_FACTORY_H_ | 53 #endif // WEBRTC_MODULES_AUDIO_CODING_CODECS_AUDIO_DECODER_FACTORY_H_ |
OLD | NEW |