Add LEQ(m) when analysing audio (#1382).
[dcpomatic.git] / src / lib / cross.h
index 20bab38a29e7296f8a52130cfd204aa56a417efd..1145812696ddbda442bae1ef16315f6001dc53c0 100644 (file)
@@ -31,6 +31,7 @@
 #include <boost/filesystem.hpp>
 #include <boost/thread/mutex.hpp>
 #include <boost/optional.hpp>
+#include <boost/function.hpp>
 
 #ifdef DCPOMATIC_WINDOWS
 #define WEXITSTATUS(w) (w)
@@ -45,7 +46,9 @@ extern std::string cpu_info ();
 extern void run_ffprobe (boost::filesystem::path, boost::filesystem::path);
 extern std::list<std::pair<std::string, std::string> > 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
@@ -96,31 +99,46 @@ private:
 class Drive
 {
 public:
-       Drive (std::string internal_name, uint64_t size, bool mounted, boost::optional<std::string> vendor, boost::optional<std::string> model)
-               : _internal_name(internal_name)
+       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)
-               , _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<Drive> get ();
+
 private:
-       std::string _internal_name;
+       std::string _device;
+       std::vector<boost::filesystem::path> _mount_points;
        /** size in bytes */
        uint64_t _size;
-       bool _mounted;
        boost::optional<std::string> _vendor;
        boost::optional<std::string> _model;
 };
 
-std::vector<Drive> get_drives ();
+void disk_write_finished ();
 
 #endif