X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Ftypes.h;h=5486f8612279c5a310be54ad2b85020f3d588008;hb=56cb528a5781e67d84bdfb6cb8223931b4d283d0;hp=dafea92f83948faba000c4391be42b169aaecf7a;hpb=978be856218cc15f059b7e267811e7302c37b24d;p=dcpomatic.git diff --git a/src/lib/types.h b/src/lib/types.h index dafea92f8..5486f8612 100644 --- a/src/lib/types.h +++ b/src/lib/types.h @@ -20,24 +20,32 @@ #ifndef DCPOMATIC_TYPES_H #define DCPOMATIC_TYPES_H +#include "position.h" +#include "rect.h" +#include +#include #include #include -#include -#include -#include "dcpomatic_time.h" class Content; class VideoContent; class AudioContent; class SubtitleContent; class FFmpegContent; -class AudioBuffers; + +namespace cxml { + class Node; +} + +namespace xmlpp { + class Node; +} /** The version number of the protocol used to communicate * with servers. Intended to be bumped when incompatibilities - * are introduced. + * are introduced. v2 uses 64+n */ -#define SERVER_LINK_VERSION 1 +#define SERVER_LINK_VERSION (64+0) typedef std::vector > ContentList; typedef std::vector > VideoContentList; @@ -45,26 +53,18 @@ typedef std::vector > AudioContentList; typedef std::vector > SubtitleContentList; typedef std::vector > FFmpegContentList; -struct TimedAudioBuffers -{ - TimedAudioBuffers () - : time (0) - {} - - TimedAudioBuffers (boost::shared_ptr a, DCPTime t) - : audio (a) - , time (t) - {} - - boost::shared_ptr audio; - DCPTime time; -}; +typedef int64_t Frame; enum VideoFrameType { VIDEO_FRAME_TYPE_2D, VIDEO_FRAME_TYPE_3D_LEFT_RIGHT, - VIDEO_FRAME_TYPE_3D_TOP_BOTTOM + VIDEO_FRAME_TYPE_3D_TOP_BOTTOM, + VIDEO_FRAME_TYPE_3D_ALTERNATE, + /** This content is all the left frames of some 3D */ + VIDEO_FRAME_TYPE_3D_LEFT, + /** This content is all the right frames of some 3D */ + VIDEO_FRAME_TYPE_3D_RIGHT }; enum Eyes @@ -75,6 +75,22 @@ enum Eyes EYES_COUNT }; +enum Part +{ + PART_LEFT_HALF, + PART_RIGHT_HALF, + PART_TOP_HALF, + PART_BOTTOM_HALF, + PART_WHOLE +}; + +enum ReelType +{ + REELTYPE_SINGLE, + REELTYPE_ONE_PER_VIDEO, + REELTYPE_BY_LENGTH +}; + /** @struct Crop * @brief A description of the crop of an image or video. */ @@ -82,6 +98,7 @@ struct Crop { Crop () : left (0), right (0), top (0), bottom (0) {} Crop (int l, int r, int t, int b) : left (l), right (r), top (t), bottom (b) {} + Crop (boost::shared_ptr); /** Number of pixels to remove from the left-hand side */ int left; @@ -103,9 +120,26 @@ struct Crop if (s.height < minimum) { s.height = minimum; } - + return s; } + + void as_xml (xmlpp::Node *) const; +}; + +struct CPLSummary +{ + CPLSummary (std::string d, std::string i, std::string a, boost::filesystem::path f) + : dcp_directory (d) + , cpl_id (i) + , cpl_annotation_text (a) + , cpl_file (f) + {} + + std::string dcp_directory; + std::string cpl_id; + std::string cpl_annotation_text; + boost::filesystem::path cpl_file; }; extern bool operator== (Crop const & a, Crop const & b); @@ -119,4 +153,9 @@ enum Resolution { std::string resolution_to_string (Resolution); Resolution string_to_resolution (std::string); +enum Protocol { + PROTOCOL_SCP, + PROTOCOL_FTP +}; + #endif