Make terminate_threads() less likely to leave _threads containing invalid pointers.
[dcpomatic.git] / src / lib / image_content.h
index bc0f331515f861f71134706c661b246f7efd8b2e..959923a51db83e0e1c4851d9fa95a39c161a7c2d 100644 (file)
@@ -33,11 +33,16 @@ public:
                return boost::dynamic_pointer_cast<ImageContent> (Content::shared_from_this ());
        };
 
+       boost::shared_ptr<const ImageContent> shared_from_this () const {
+               return boost::dynamic_pointer_cast<const ImageContent> (Content::shared_from_this ());
+       };
+
        void examine (boost::shared_ptr<const Film> film, boost::shared_ptr<Job>);
        std::string summary () const;
        std::string technical_summary () const;
        void as_xml (xmlpp::Node *, bool with_paths) const;
        DCPTime full_length (boost::shared_ptr<const Film> film) const;
+       DCPTime approximate_length () const;
 
        std::string identifier () const;
 
@@ -46,7 +51,7 @@ public:
        bool still () const;
 
 private:
-       void add_properties (std::list<UserProperty>& p) const;
+       void add_properties (boost::shared_ptr<const Film> film, std::list<UserProperty>& p) const;
 
        boost::optional<boost::filesystem::path> _path_to_scan;
 };