X-Git-Url: https://git.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fcross.h;h=4be121d2bb1daec1e46451366e26621ecef7ca63;hp=ac1f028f443a33d9c5864b9329bbf12ed468edcc;hb=bbe336ee97c86c424f8f94e0f947f8e3b20e7123;hpb=59bb9538218eee564ab3c07f923628e0a47bf207 diff --git a/src/lib/cross.h b/src/lib/cross.h index ac1f028f4..4be121d2b 100644 --- a/src/lib/cross.h +++ b/src/lib/cross.h @@ -43,7 +43,7 @@ extern void dcpomatic_sleep_seconds (int); extern void dcpomatic_sleep_milliseconds (int); extern std::string cpu_info (); extern void run_ffprobe (boost::filesystem::path, boost::filesystem::path); -extern std::list > mount_info (); +extern std::list> mount_info (); extern boost::filesystem::path openssl_path (); extern void make_foreground_application (); #ifdef DCPOMATIC_DISK @@ -53,10 +53,7 @@ extern boost::filesystem::path disk_writer_path (); extern void maybe_open_console (); #endif extern boost::filesystem::path resources_path (); -extern boost::filesystem::path xsd_path (); -extern boost::filesystem::path tags_path (); -extern FILE * fopen_boost (boost::filesystem::path, std::string); -extern int dcpomatic_fseek (FILE *, int64_t, int); +extern boost::filesystem::path libdcp_resources_path (); extern void start_batch_converter (); extern void start_player (); extern uint64_t thread_id (); @@ -66,7 +63,6 @@ extern bool running_32_on_64 (); extern void unprivileged (); extern boost::filesystem::path config_path (boost::optional version); extern boost::filesystem::path directory_containing_executable (); -extern boost::filesystem::path fix_long_path (boost::filesystem::path path); extern bool show_in_file_manager (boost::filesystem::path dir, boost::filesystem::path select); namespace dcpomatic { std::string get_process_id (); @@ -142,19 +138,17 @@ void disk_write_finished (); struct OSXMediaPath { - bool real; ///< true for a "real" disk, false for a synthesized APFS one - std::string prt; ///< "PRT" entry from the media path + bool real; ///< true for a "real" disk, false for a synthesized APFS one + std::vector parts; ///< parts of the media path after the : }; - struct OSXDisk { - std::string mount_point; + std::string device; boost::optional vendor; boost::optional model; - bool real; - std::string prt; + OSXMediaPath media_path; bool whole; std::vector mount_points; unsigned long size; @@ -165,4 +159,27 @@ boost::optional analyse_osx_media_path (std::string path); std::vector osx_disks_to_drives (std::vector disks); +class ArgFixer +{ +public: + ArgFixer(int argc, char** argv); + + int argc() const { + return _argc; + } + + char** argv() const { + return _argv; + } + +private: + int _argc; + char** _argv; +#ifdef DCPOMATIC_WINDOWS + std::vector _argv_strings; +#endif + +}; + + #endif