float v_position;
VAlign v_align;
std::string text;
- Time fade_up_time;
- Time fade_down_time;
-
-private:
- Time fade_time (std::string name);
-
+ std::list<boost::shared_ptr<FontNode> > font_nodes;
};
class SubtitleNode : public XMLNode
Time in;
Time out;
+ Time fade_up_time;
+ Time fade_down_time;
std::list<boost::shared_ptr<FontNode> > font_nodes;
std::list<boost::shared_ptr<TextNode> > text_nodes;
+
+private:
+ Time fade_time (std::string name);
};
class FontNode : public XMLNode
FontNode (xmlpp::Node const * node);
FontNode (std::list<boost::shared_ptr<FontNode> > const & font_nodes);
+ std::string text;
std::string id;
int size;
boost::optional<bool> italic;
bool operator== (Subtitle const & a, Subtitle const & b);
std::ostream& operator<< (std::ostream& s, Subtitle const & sub);
-class SubtitleAsset : public Asset, public XMLFile
+class SubtitleAsset : public Asset
{
public:
- SubtitleAsset (std::string directory, std::string xml);
+ SubtitleAsset (std::string directory, std::string xml_file);
+ SubtitleAsset (std::string directory, std::string movie_title, std::string language);
- void write_to_cpl (std::ostream&) const {}
- virtual std::list<std::string> equals (boost::shared_ptr<const Asset>, EqualityOptions) const {
+ void write_to_cpl (std::ostream&) const;
+ virtual bool equals (boost::shared_ptr<const Asset>, EqualityOptions, std::list<std::string>& notes) const {
/* XXX */
- return std::list<std::string> ();
+ notes.push_back ("subtitle assets not compared yet");
+ return true;
}
std::string language () const {
return _subtitles;
}
+ void add (boost::shared_ptr<Subtitle>);
+
+ void write_xml ();
+
private:
std::string font_id_to_name (std::string id) const;
+ struct ParseState {
+ std::list<boost::shared_ptr<FontNode> > font_nodes;
+ std::list<boost::shared_ptr<TextNode> > text_nodes;
+ std::list<boost::shared_ptr<SubtitleNode> > subtitle_nodes;
+ };
+
+ void maybe_add_subtitle (std::string text, ParseState const & parse_state);
+
void examine_font_nodes (
+ boost::shared_ptr<XMLFile> xml,
std::list<boost::shared_ptr<FontNode> > const & font_nodes,
- std::list<boost::shared_ptr<FontNode> >& current_font_nodes,
- std::list<boost::shared_ptr<SubtitleNode> >& current_subtitle_nodes
+ ParseState& parse_state
);
void examine_text_nodes (
- boost::shared_ptr<SubtitleNode> subtitle_node,
+ boost::shared_ptr<XMLFile> xml,
std::list<boost::shared_ptr<TextNode> > const & text_nodes,
- std::list<boost::shared_ptr<FontNode> >& current_font_nodes
+ ParseState& parse_state
);
-
- std::string _subtitle_id;
+
std::string _movie_title;
- int64_t _reel_number;
+ /* strangely, this is sometimes a string */
+ std::string _reel_number;
std::string _language;
std::list<boost::shared_ptr<LoadFontNode> > _load_font_nodes;