X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fcross.h;h=1145812696ddbda442bae1ef16315f6001dc53c0;hb=83416808c0b1ca732e7a186d3811f1ec796fea08;hp=cd0372338fc062ec3e5a4fce4a631f52f119b0d1;hpb=ad1ef39eda58b3a919ea3b7084401a0439409ec6;p=dcpomatic.git diff --git a/src/lib/cross.h b/src/lib/cross.h index cd0372338..114581269 100644 --- a/src/lib/cross.h +++ b/src/lib/cross.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2012-2018 Carl Hetherington + Copyright (C) 2012-2020 Carl Hetherington This file is part of DCP-o-matic. @@ -29,6 +29,9 @@ #include #endif #include +#include +#include +#include #ifdef DCPOMATIC_WINDOWS #define WEXITSTATUS(w) (w) @@ -37,11 +40,15 @@ class Log; struct AVIOContext; -void dcpomatic_sleep (int); +void dcpomatic_sleep_seconds (int); +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 boost::filesystem::path openssl_path (); +#ifdef DCPOMATIC_DISK +extern boost::filesystem::path disk_writer_path (); +#endif #ifdef DCPOMATIC_OSX extern boost::filesystem::path app_contents (); #endif @@ -55,6 +62,18 @@ extern void start_batch_converter (boost::filesystem::path dcpomatic); extern void start_player (boost::filesystem::path dcpomatic); extern uint64_t thread_id (); extern int avio_open_boost (AVIOContext** s, boost::filesystem::path file, int flags); +extern boost::filesystem::path home_directory (); +extern std::string command_and_read (std::string cmd); +extern bool running_32_on_64 (); +extern void unprivileged (); +extern boost::filesystem::path config_path (); + +class PrivilegeEscalator +{ +public: + PrivilegeEscalator (); + ~PrivilegeEscalator (); +}; /** @class Waker * @brief A class which tries to keep the computer awake on various operating systems. @@ -71,9 +90,55 @@ public: void nudge (); private: + boost::mutex _mutex; #ifdef DCPOMATIC_OSX IOPMAssertionID _assertion_id; #endif }; +class Drive +{ +public: + Drive (std::string device, std::vector mount_points, uint64_t size, boost::optional vendor, boost::optional model) + : _device(device) + , _mount_points(mount_points) + , _size(size) + , _vendor(vendor) + , _model(model) + {} + + explicit Drive (std::string); + + std::string as_xml () const; + + std::string description () const; + + std::string device () const { + return _device; + } + + bool mounted () const { + return !_mount_points.empty(); + } + + std::string log_summary () const; + + /** Unmount any mounted partitions on a drive. + * @return true on success, false on failure. + */ + bool unmount (); + + static std::vector get (); + +private: + std::string _device; + std::vector _mount_points; + /** size in bytes */ + uint64_t _size; + boost::optional _vendor; + boost::optional _model; +}; + +void disk_write_finished (); + #endif