X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Futil.h;h=aa26bfaf80688f28ff2ced1f1c9cce00353866c1;hb=cf4e4272f72346c39964b128f78b2297f04dba55;hp=523794e40ca955c98a7563b11b8a7dfaf8eea7ac;hpb=da15bff6e278d351301c9c50a4c96737ae4b5545;p=libdcp.git diff --git a/src/util.h b/src/util.h index 523794e4..aa26bfaf 100644 --- a/src/util.h +++ b/src/util.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2012-2020 Carl Hetherington + Copyright (C) 2012-2021 Carl Hetherington This file is part of libdcp. @@ -31,60 +31,128 @@ files in the program, then also delete it here. */ -#ifndef LIBDCP_UTIL_H -#define LIBDCP_UTIL_H /** @file src/util.h - * @brief Utility methods. + * @brief Utility methods and classes */ +#ifndef LIBDCP_UTIL_H +#define LIBDCP_UTIL_H + + #include "array_data.h" #include "types.h" #include "local_time.h" #include -#include +#include #include #include #include #include #include + #define LIBDCP_UNUSED(x) (void)(x) + namespace xmlpp { class Element; class Node; } + namespace dcp { + class CertificateChain; class GammaLUT; class OpenJPEGImage; + extern std::string make_uuid (); + +/** Create a digest for a file + * @param filename File name + * @param progress Optional progress reporting function. The function will be called + * with a progress value between 0 and 1 + * @return Digest + */ extern std::string make_digest (boost::filesystem::path filename, boost::function); + extern std::string make_digest (ArrayData data); + +/** @param s A string + * @return true if the string contains only space, newline or tab characters, or is empty + */ extern bool empty_or_white_space (std::string s); + extern bool ids_equal (std::string a, std::string b); extern std::string remove_urn_uuid (std::string raw); + +/** Set up various bits that the library needs. Should be called once + * by client applications. + * + * @param tags_directory Path to a copy of the tags directory from the source code; + * if none is specified libdcp will look for a tags directory in the environment + * variable LIBDCP_RESOURCES or based on where the current executable is. + */ extern void init (boost::optional tags_directory = boost::optional()); +/** Decode a base64 string. The base64 decode routine in KM_util.cpp + * gives different values to both this and the command-line base64 + * for some inputs. Not sure why. + * + * @param in base64-encoded string + * @param out Output buffer + * @param out_length Length of output buffer + * @return Number of characters written to the output buffer + */ extern int base64_decode (std::string const & in, unsigned char* out, int out_length); + extern boost::optional relative_to_root (boost::filesystem::path root, boost::filesystem::path file); + +/** @param p Path to open + * @param t mode flags, as for fopen(3) + * @return FILE pointer or 0 on error + * + * Apparently there is no way to create an ofstream using a UTF-8 + * filename under Windows. We are hence reduced to using fopen + * with this wrapper. + */ extern FILE * fopen_boost (boost::filesystem::path, std::string); + extern std::string file_to_string (boost::filesystem::path, uintmax_t max_length = 1048576); + +/** @param key RSA private key in PEM format (optionally with -----BEGIN... / -----END...) + * @return SHA1 fingerprint of key + */ extern std::string private_key_fingerprint (std::string key); extern xmlpp::Node* find_child (xmlpp::Node const * node, std::string name); extern std::string openjpeg_version(); extern std::string spaces (int n); extern void indent (xmlpp::Element* element, int initial); + +/** @return true if the day represented by \ref a is less than or + * equal to the one represented by \ref b, ignoring the time parts + */ extern bool day_less_than_or_equal (LocalTime a, LocalTime b); + +/** @return true if the day represented by \ref a is greater than or + * equal to the one represented by \ref b, ignoring the time parts + */ extern bool day_greater_than_or_equal (LocalTime a, LocalTime b); -extern std::string unique_string (std::list existing, std::string base); + +/** Try quite hard to find a string which starts with \ref base and is + * not in \ref existing + */ +extern std::string unique_string (std::vector existing, std::string base); + extern ASDCP::Dictionary const* asdcp_smpte_dict; +extern boost::filesystem::path directory_containing_executable (); +extern boost::filesystem::path resources_directory (); + class ASDCPErrorSuspender { @@ -101,4 +169,5 @@ private: } + #endif