X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Futil.h;h=51770c288695fd064d9d4fc73574664fe7146fb7;hb=f188128e2577942f030374631d3cf1324a00624a;hp=9ae149ef4cd76a8e79583a6f73ab05658d098077;hpb=937b96045830a2326daff83b70b892f2d25244ff;p=dcpomatic.git diff --git a/src/lib/util.h b/src/lib/util.h index 9ae149ef4..51770c288 100644 --- a/src/lib/util.h +++ b/src/lib/util.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2012-2014 Carl Hetherington + Copyright (C) 2012-2015 Carl Hetherington This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -29,12 +29,12 @@ #include "exceptions.h" #include "dcpomatic_time.h" #include +#include extern "C" { #include #include } #include -#include #include #include #include @@ -42,6 +42,12 @@ extern "C" { #undef check +namespace dcp { + class PictureMXF; + class SoundMXF; + class SubtitleContent; +} + /** The maximum number of audio channels that we can have in a DCP */ #define MAX_DCP_AUDIO_CHANNELS 12 /** Message broadcast to find possible encoding servers */ @@ -57,11 +63,10 @@ struct AVSubtitle; extern std::string seconds_to_hms (int); extern std::string seconds_to_approximate_hms (int); -extern std::string dependency_version_summary (); extern double seconds (struct timeval); extern void dcpomatic_setup (); extern void dcpomatic_setup_gettext_i18n (std::string); -extern std::string md5_digest (std::vector, boost::shared_ptr); +extern std::string md5_digest_head_tail (std::vector, boost::uintmax_t size); extern void ensure_ui_thread (); extern std::string audio_channel_name (int); extern bool valid_image_file (boost::filesystem::path); @@ -70,54 +75,36 @@ extern bool valid_j2k_file (boost::filesystem::path); extern boost::filesystem::path mo_path (); #endif extern std::string tidy_for_filename (std::string); -extern dcp::Size fit_ratio_within (float ratio, dcp::Size, int); +extern dcp::Size fit_ratio_within (float ratio, dcp::Size); extern int dcp_audio_frame_rate (int); extern int stride_round_up (int, int const *, int); extern int round_to (float n, int r); extern void* wrapped_av_malloc (size_t); -extern ContentTimePeriod subtitle_period (AVSubtitle const &); -extern void set_backtrace_file (boost::filesystem::path); -/** @class Socket - * @brief A class to wrap a boost::asio::ip::tcp::socket with some things - * that are useful for DCP-o-matic. - * - * This class wraps some things that I could not work out how to do with boost; - * most notably, sync read/write calls with timeouts. - */ -class Socket +class FFmpegSubtitlePeriod { public: - Socket (int timeout = 30); - ~Socket (); - - /** @return Our underlying socket */ - boost::asio::ip::tcp::socket& socket () { - return _socket; - } - - void connect (boost::asio::ip::tcp::endpoint); - void accept (int); - - void write (uint32_t n); - void write (uint8_t const * data, int size); - - void read (uint8_t* data, int size); - uint32_t read_uint32 (); - -private: - void check (); - - Socket (Socket const &); - - boost::asio::io_service _io_service; - boost::asio::deadline_timer _deadline; - boost::asio::ip::tcp::socket _socket; - boost::asio::ip::tcp::acceptor* _acceptor; - int _timeout; + FFmpegSubtitlePeriod (ContentTime f) + : from (f) + {} + + FFmpegSubtitlePeriod (ContentTime f, ContentTime t) + : from (f) + , to (t) + {} + + ContentTime from; + boost::optional to; }; -extern int64_t video_frames_to_audio_frames (VideoFrame v, float audio_sample_rate, float frames_per_second); +extern FFmpegSubtitlePeriod subtitle_period (AVSubtitle const &); +extern void set_backtrace_file (boost::filesystem::path); +extern dcp::FrameInfo read_frame_info (FILE* file, int frame, Eyes eyes); +extern void write_frame_info (FILE* file, int frame, Eyes eyes, dcp::FrameInfo info); +extern std::map split_get_request (std::string url); +extern std::string video_mxf_filename (boost::shared_ptr mxf); +extern std::string audio_mxf_filename (boost::shared_ptr mxf); +extern std::string subtitle_content_filename (boost::shared_ptr content); #endif