summaryrefslogtreecommitdiff
path: root/src/lib/audio_decoder.h
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2015-05-27 20:55:51 +0100
committerCarl Hetherington <cth@carlh.net>2015-06-02 13:38:21 +0100
commit0a93237cb5e4642d3b698ff9b7d0cfae5401478c (patch)
treeb0d5255ae2b90d1c9ef489e78239c2f081ea0a9e /src/lib/audio_decoder.h
parent608c146eb09fac2a8fc60e1a72591f6bb8364e1f (diff)
Handle multiple audio streams in a single piece of content
in a similar way to the V1 patch.
Diffstat (limited to 'src/lib/audio_decoder.h')
-rw-r--r--src/lib/audio_decoder.h30
1 files changed, 11 insertions, 19 deletions
diff --git a/src/lib/audio_decoder.h b/src/lib/audio_decoder.h
index 99e9092b3..1b17029b7 100644
--- a/src/lib/audio_decoder.h
+++ b/src/lib/audio_decoder.h
@@ -28,14 +28,15 @@
#include "content.h"
#include "audio_content.h"
#include "content_audio.h"
+#include <boost/enable_shared_from_this.hpp>
class AudioBuffers;
-class Resampler;
+class AudioDecoderStream;
/** @class AudioDecoder.
* @brief Parent class for audio decoders.
*/
-class AudioDecoder : public virtual Decoder
+class AudioDecoder : public virtual Decoder, public boost::enable_shared_from_this<AudioDecoder>
{
public:
AudioDecoder (boost::shared_ptr<const AudioContent>);
@@ -50,26 +51,17 @@ public:
* @param accurate true to try hard to return frames from exactly `frame', false if we don't mind nearby frames.
* @return Time-stamped audio data which may or may not be from the location (and of the length) requested.
*/
- boost::shared_ptr<ContentAudio> get_audio (Frame time, Frame length, bool accurate);
-
-protected:
+ ContentAudio get_audio (AudioStreamPtr stream, Frame time, Frame length, bool accurate);
- void seek (ContentTime time, bool accurate);
- void audio (boost::shared_ptr<const AudioBuffers>, ContentTime);
+protected:
+ void audio (AudioStreamPtr stream, boost::shared_ptr<const AudioBuffers>, ContentTime);
void flush ();
- void reset_decoded_audio ();
- void add (boost::shared_ptr<const AudioBuffers>);
-
+ void seek (ContentTime t, bool accurate);
+
+private:
boost::shared_ptr<const AudioContent> _audio_content;
- boost::shared_ptr<Resampler> _resampler;
- boost::shared_ptr<AudioProcessor> _processor;
- boost::optional<Frame> _audio_position;
- /** Currently-available decoded audio data */
- ContentAudio _decoded_audio;
- /** The time of an accurate seek after which we have not yet received any actual
- data at the seek time.
- */
- boost::optional<ContentTime> _seek_reference;
+ /** An AudioDecoderStream object to manage each stream in _audio_content */
+ std::map<AudioStreamPtr, boost::shared_ptr<AudioDecoderStream> > _streams;
};
#endif