X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fcross.h;h=ece36fe252aef51da20217295dcba7ad6211b1b7;hb=6d27b49a7a767a9c8b31dc0f799da940ddb7232f;hp=6d3c2bd2ea17a8c1d346f2ead2a02642df289df7;hpb=ddccef68ae80bac6b4aa8583dd8e0a7c943b535c;p=dcpomatic.git diff --git a/src/lib/cross.h b/src/lib/cross.h index 6d3c2bd2e..ece36fe25 100644 --- a/src/lib/cross.h +++ b/src/lib/cross.h @@ -98,31 +98,44 @@ private: class Drive { public: - Drive (std::string internal_name, uint64_t size, bool mounted, boost::optional vendor, boost::optional model) - : _internal_name(internal_name) + 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) - , _mounted(mounted) , _vendor(vendor) , _model(model) {} + explicit Drive (std::string); + + std::string as_xml () const; + std::string description () const; - std::string internal_name () const { - return _internal_name; + + std::string device () const { + return _device; } + bool mounted () const { - return _mounted; + 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 _internal_name; + std::string _device; + std::vector _mount_points; /** size in bytes */ uint64_t _size; - bool _mounted; boost::optional _vendor; boost::optional _model; }; -std::vector get_drives (); - #endif