Fix build on old GCC.
[libdcp.git] / src / subtitle_image.cc
index 90aadf29d09ddb0445ecc0e24054a0f5415f48d0..b281d7541a2cea3dbbe61387ac3230d0a814e42e 100644 (file)
@@ -1,5 +1,5 @@
 /*
-    Copyright (C) 2018 Carl Hetherington <cth@carlh.net>
+    Copyright (C) 2018-2021 Carl Hetherington <cth@carlh.net>
 
     This file is part of libdcp.
 
     files in the program, then also delete it here.
 */
 
+
+/** @file  src/subtitle_image.cc
+ *  @brief SubtitleImage class
+ */
+
+
 #include "subtitle_image.h"
+#include "util.h"
+
 
+using std::ostream;
+using std::string;
+using std::shared_ptr;
 using namespace dcp;
 
+
 SubtitleImage::SubtitleImage (
-       Data png_image,
+       ArrayData png_image,
        Time in,
        Time out,
        float h_position,
@@ -48,6 +60,147 @@ SubtitleImage::SubtitleImage (
        )
        : Subtitle (in, out, h_position, h_align, v_position, v_align, fade_up_time, fade_down_time)
        , _png_image (png_image)
+       , _id (make_uuid ())
 {
 
 }
+
+
+SubtitleImage::SubtitleImage (
+       ArrayData png_image,
+       string id,
+       Time in,
+       Time out,
+       float h_position,
+       HAlign h_align,
+       float v_position,
+       VAlign v_align,
+       Time fade_up_time,
+       Time fade_down_time
+       )
+       : Subtitle (in, out, h_position, h_align, v_position, v_align, fade_up_time, fade_down_time)
+       , _png_image (png_image)
+       , _id (id)
+{
+
+}
+
+
+void
+SubtitleImage::read_png_file (boost::filesystem::path file)
+{
+       _file = file;
+       _png_image = ArrayData (file);
+}
+
+
+void
+SubtitleImage::write_png_file (boost::filesystem::path file) const
+{
+       _file = file;
+       png_image().write (file);
+}
+
+
+bool
+dcp::operator== (SubtitleImage const & a, SubtitleImage const & b)
+{
+       return (
+               a.png_image() == b.png_image() &&
+               a.id() == b.id() &&
+               a.in() == b.in() &&
+               a.out() == b.out() &&
+               a.h_position() == b.h_position() &&
+               a.h_align() == b.h_align() &&
+               a.v_position() == b.v_position() &&
+               a.v_align() == b.v_align() &&
+               a.fade_up_time() == b.fade_up_time() &&
+               a.fade_down_time() == b.fade_down_time()
+               );
+}
+
+
+bool
+dcp::operator!= (SubtitleImage const & a, SubtitleImage const & b)
+{
+       return !(a == b);
+}
+
+
+bool
+SubtitleImage::equals (shared_ptr<SubtitleImage> other, EqualityOptions options, NoteHandler note)
+{
+       if (png_image() != other->png_image()) {
+               note (NoteType::ERROR, "subtitle image PNG data differs");
+               if (options.export_differing_subtitles) {
+                       string const base = "dcpdiff_subtitle_";
+                       if (boost::filesystem::exists(base + "A.png")) {
+                               note (NoteType::ERROR, "could not export subtitle as " + base + "A.png already exists");
+                       } else {
+                               png_image().write(base + "A.png");
+                       }
+                       if (boost::filesystem::exists(base + "B.png")) {
+                               note (NoteType::ERROR, "could not export subtitle as " + base + "B.png already exists");
+                       } else {
+                               other->png_image().write(base + "B.png");
+                       }
+                       options.export_differing_subtitles = false;
+               }
+               return false;
+       }
+
+       if (in() != other->in()) {
+               note (NoteType::ERROR, "subtitle in times differ");
+               return false;
+       }
+
+       if (out() != other->out()) {
+               note (NoteType::ERROR, "subtitle out times differ");
+               return false;
+       }
+
+       if (h_position() != other->h_position()) {
+               note (NoteType::ERROR, "subtitle horizontal positions differ");
+               return false;
+       }
+
+       if (h_align() != other->h_align()) {
+               note (NoteType::ERROR, "subtitle horizontal alignments differ");
+               return false;
+       }
+
+       if (v_position() != other->v_position()) {
+               note (NoteType::ERROR, "subtitle vertical positions differ");
+               return false;
+       }
+
+       if (v_align() != other->v_align()) {
+               note (NoteType::ERROR, "subtitle vertical alignments differ");
+               return false;
+       }
+
+       if (fade_up_time() != other->fade_up_time()) {
+               note (NoteType::ERROR, "subtitle fade-up times differ");
+               return false;
+       }
+
+       if (fade_down_time() != other->fade_down_time()) {
+               note (NoteType::ERROR, "subtitle fade-down times differ");
+               return false;
+       }
+
+       return true;
+}
+
+
+ostream&
+dcp::operator<< (ostream& s, SubtitleImage const & sub)
+{
+       s << "\n[IMAGE] from " << sub.in() << " to " << sub.out() << ";\n"
+         << "fade up " << sub.fade_up_time() << ", fade down " << sub.fade_down_time() << ";\n"
+         << "v pos " << sub.v_position() << ", valign " << ((int) sub.v_align())
+         << ", hpos " << sub.h_position() << ", halign " << ((int) sub.h_align()) << "\n";
+
+       return s;
+}
+