X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fsubtitle_asset.h;h=9f137abe300c1c1aae52af0e0d8c65c522474af4;hb=9d3e7f716accd67985f23048b4c36e7581348848;hp=d212579f280ca736f59cfa52855a6c8168221b7d;hpb=d927e9b913606f4fc982885c7582ecaf0e3c5a1a;p=libdcp.git diff --git a/src/subtitle_asset.h b/src/subtitle_asset.h index d212579f..9f137abe 100644 --- a/src/subtitle_asset.h +++ b/src/subtitle_asset.h @@ -48,20 +48,29 @@ namespace xmlpp { struct interop_dcp_font_test; struct smpte_dcp_font_test; +struct pull_fonts_test1; +struct pull_fonts_test2; +struct pull_fonts_test3; namespace dcp { class SubtitleString; +class SubtitleImage; class FontNode; class TextNode; class SubtitleNode; class LoadFontNode; +namespace order { + class Part; + class Context; +} + /** @class SubtitleAsset * @brief A parent for classes representing a file containing subtitles. * - * This class holds a list of SubtitleString objects which it can extract + * This class holds a list of Subtitle objects which it can extract * from the appropriate part of either an Interop or SMPTE XML file. * Its subclasses InteropSubtitleAsset and SMPTESubtitleAsset handle the * differences between the two types. @@ -78,12 +87,12 @@ public: NoteHandler note ) const; - std::list subtitles_during (Time from, Time to, bool starting) const; - std::list const & subtitles () const { + std::list > subtitles_during (Time from, Time to, bool starting) const; + std::list > const & subtitles () const { return _subtitles; } - virtual void add (SubtitleString); + virtual void add (boost::shared_ptr); virtual void add_font (std::string id, boost::filesystem::path file) = 0; std::map fonts_with_load_ids () const; @@ -92,22 +101,52 @@ public: Time latest_subtitle_out () const; + void fix_empty_font_ids (); + virtual std::list > load_font_nodes () const = 0; protected: friend struct ::interop_dcp_font_test; friend struct ::smpte_dcp_font_test; - void parse_subtitles ( - boost::shared_ptr xml, - std::list > font_nodes, - std::list > subtitle_nodes - ); + struct ParseState { + boost::optional font_id; + boost::optional size; + boost::optional aspect_adjust; + boost::optional italic; + boost::optional bold; + boost::optional underline; + boost::optional colour; + boost::optional effect; + boost::optional effect_colour; + boost::optional h_position; + boost::optional h_align; + boost::optional v_position; + boost::optional v_align; + boost::optional direction; + boost::optional