summaryrefslogtreecommitdiff
path: root/src/lib/decoder.h
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2018-11-21 02:45:30 +0000
committerCarl Hetherington <cth@carlh.net>2018-11-21 02:45:30 +0000
commit84012cdd64f451891febd36154b7226ea21a899b (patch)
tree096fb898aa14d936dfc8f8598a6908337508233c /src/lib/decoder.h
parent254b3044d72de6b033d7c584f5abd2b9aa70aad5 (diff)
Put Film pointer into Decoder.
Diffstat (limited to 'src/lib/decoder.h')
-rw-r--r--src/lib/decoder.h15
1 files changed, 11 insertions, 4 deletions
diff --git a/src/lib/decoder.h b/src/lib/decoder.h
index a8a67ee72..d610f8727 100644
--- a/src/lib/decoder.h
+++ b/src/lib/decoder.h
@@ -26,6 +26,7 @@
#define DCPOMATIC_DECODER_H
#include "types.h"
+#include "film.h"
#include "dcpomatic_time.h"
#include <boost/utility.hpp>
@@ -34,7 +35,6 @@ class VideoDecoder;
class AudioDecoder;
class TextDecoder;
class DecoderPart;
-class Film;
/** @class Decoder.
* @brief Parent class for decoders of content.
@@ -42,6 +42,7 @@ class Film;
class Decoder : public boost::noncopyable
{
public:
+ Decoder (boost::weak_ptr<const Film> film);
virtual ~Decoder () {}
boost::shared_ptr<VideoDecoder> video;
@@ -53,10 +54,16 @@ public:
/** Do some decoding and perhaps emit video, audio or subtitle data.
* @return true if this decoder will emit no more data unless a seek() happens.
*/
- virtual bool pass (boost::shared_ptr<const Film> film) = 0;
- virtual void seek (boost::shared_ptr<const Film> film, ContentTime time, bool accurate);
+ virtual bool pass () = 0;
+ virtual void seek (ContentTime time, bool accurate);
- ContentTime position (boost::shared_ptr<const Film> film) const;
+ ContentTime position () const;
+
+protected:
+ boost::shared_ptr<const Film> film () const;
+
+private:
+ boost::weak_ptr<const Film> _film;
};
#endif