X-Git-Url: https://git.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fcross.h;h=aad223d60fd4d392310124e07ff2192cfdbdc4c7;hp=bdcae353786103146d40f632c7d6e6a096193c73;hb=9b9202c7f9fc26fcef0984189aaed366b7c6d726;hpb=87df63f0ca9cf1df4f99f5818dad45bbc4c6e3e3 diff --git a/src/lib/cross.h b/src/lib/cross.h index bdcae3537..aad223d60 100644 --- a/src/lib/cross.h +++ b/src/lib/cross.h @@ -31,7 +31,6 @@ #include #include #include -#include #ifdef DCPOMATIC_WINDOWS #define WEXITSTATUS(w) (w) @@ -65,21 +64,14 @@ extern int avio_open_boost (AVIOContext** s, boost::filesystem::path file, int f extern boost::filesystem::path home_directory (); extern bool running_32_on_64 (); extern void unprivileged (); -extern boost::filesystem::path config_path (); +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 (); } -class PrivilegeEscalator -{ -public: - PrivilegeEscalator (); - ~PrivilegeEscalator (); - - static bool test; -}; /** @class Waker * @brief A class which tries to keep the computer awake on various operating systems. @@ -147,4 +139,28 @@ private: void disk_write_finished (); + +struct OSXMediaPath +{ + 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 device; + boost::optional vendor; + boost::optional model; + OSXMediaPath media_path; + bool whole; + std::vector mount_points; + unsigned long size; +}; + + +boost::optional analyse_osx_media_path (std::string path); +std::vector osx_disks_to_drives (std::vector disks); + + #endif