X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Futil.h;h=9e811f8ad19f2c823cccbb140885497bfd9cce0d;hb=c2a97b6f83a32483817d02194a1e7c8d6828b0bb;hp=ede53e0d9797c27a1d6ae04847fb4c3bc0df219b;hpb=59f63e2b6d0dba963faee7dfee54fbb48dee396a;p=dcpomatic.git diff --git a/src/lib/util.h b/src/lib/util.h index ede53e0d9..9e811f8ad 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 @@ -24,17 +24,13 @@ #ifndef DCPOMATIC_UTIL_H #define DCPOMATIC_UTIL_H -#include "compose.hpp" #include "types.h" -#include "exceptions.h" #include "dcpomatic_time.h" #include extern "C" { #include -#include } #include -#include #include #include #include @@ -42,10 +38,16 @@ extern "C" { #undef check +namespace dcp { + class PictureAsset; + class SoundAsset; + class SubtitleAsset; +} + /** 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 */ -#define DCPOMATIC_HELLO "Boys, you gotta learn not to talk to nuns that way" +#define DCPOMATIC_HELLO "I mean really, Ray, it's used." /** Number of films to keep in history */ #define HISTORY_SIZE 10 #define REPORT_PROBLEM _("Please report this problem by using Help -> Report a problem or via email to carl@dcpomatic.com") @@ -57,12 +59,11 @@ 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_path_encoding (); extern void dcpomatic_setup_gettext_i18n (std::string); -extern std::vector split_at_spaces_considering_quotes (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); @@ -71,62 +72,30 @@ 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 std::string entities_to_text (std::string e); -extern int dcp_audio_frame_rate (int); +extern dcp::Size fit_ratio_within (float ratio, dcp::Size); extern int stride_round_up (int, int const *, int); -extern int round_to (float n, int r); -extern std::multimap read_key_value (std::istream& s); -extern int get_required_int (std::multimap const & kv, std::string k); -extern float get_required_float (std::multimap const & kv, std::string k); -extern std::string get_required_string (std::multimap const & kv, std::string k); -extern int get_optional_int (std::multimap const & kv, std::string k); -extern std::string get_optional_string (std::multimap const & kv, std::string k); extern void* wrapped_av_malloc (size_t); -extern int64_t divide_with_round (int64_t a, int64_t b); -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 std::map split_get_request (std::string url); +extern std::string video_asset_filename (boost::shared_ptr asset); +extern std::string audio_asset_filename (boost::shared_ptr asset); #endif -