+ IOPMAssertionID _assertion_id;
+#endif
+};
+
+class Drive
+{
+public:
+ Drive (std::string device, std::vector<boost::filesystem::path> mount_points, uint64_t size, boost::optional<std::string> vendor, boost::optional<std::string> 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<Drive> get ();
+
+private:
+ std::string _device;
+ std::vector<boost::filesystem::path> _mount_points;
+ /** size in bytes */
+ uint64_t _size;
+ boost::optional<std::string> _vendor;
+ boost::optional<std::string> _model;
+};
+
+void disk_write_finished ();
+
+
+struct OSXMediaPath
+{
+ bool real; ///< true for a "real" disk, false for a synthesized APFS one
+ std::vector<std::string> parts; ///< parts of the media path after the :
+};
+
+
+struct OSXDisk
+{
+ std::string device;
+ boost::optional<std::string> vendor;
+ boost::optional<std::string> model;
+ OSXMediaPath media_path;
+ bool whole;
+ std::vector<boost::filesystem::path> mount_points;
+ unsigned long size;
+};
+
+
+boost::optional<OSXMediaPath> analyse_osx_media_path (std::string path);
+std::vector<Drive> osx_disks_to_drives (std::vector<OSXDisk> 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<std::string> _argv_strings;
+#endif
+
+};
+
+