2 Copyright (C) 2012-2020 Carl Hetherington <cth@carlh.net>
4 This file is part of DCP-o-matic.
6 DCP-o-matic is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
11 DCP-o-matic is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with DCP-o-matic. If not, see <http://www.gnu.org/licenses/>.
21 /** @file src/lib/cross.h
22 * @brief Cross-platform compatibility code.
25 #ifndef DCPOMATIC_CROSS_H
26 #define DCPOMATIC_CROSS_H
29 #include <IOKit/pwr_mgt/IOPMLib.h>
31 #include <boost/filesystem.hpp>
32 #include <boost/thread/mutex.hpp>
33 #include <boost/optional.hpp>
35 #ifdef DCPOMATIC_WINDOWS
36 #define WEXITSTATUS(w) (w)
42 extern void dcpomatic_sleep_seconds (int);
43 extern void dcpomatic_sleep_milliseconds (int);
44 extern std::string cpu_info ();
45 extern void run_ffprobe (boost::filesystem::path, boost::filesystem::path);
46 extern std::list<std::pair<std::string, std::string>> mount_info ();
47 extern boost::filesystem::path openssl_path ();
48 extern void make_foreground_application ();
50 extern boost::filesystem::path disk_writer_path ();
52 #ifdef DCPOMATIC_WINDOWS
53 extern void maybe_open_console ();
55 extern boost::filesystem::path resources_path ();
56 extern boost::filesystem::path libdcp_resources_path ();
57 extern void start_batch_converter ();
58 extern void start_player ();
59 extern uint64_t thread_id ();
60 extern int avio_open_boost (AVIOContext** s, boost::filesystem::path file, int flags);
61 extern boost::filesystem::path home_directory ();
62 extern bool running_32_on_64 ();
63 extern void unprivileged ();
64 extern boost::filesystem::path config_path (boost::optional<std::string> version);
65 extern boost::filesystem::path directory_containing_executable ();
66 extern bool show_in_file_manager (boost::filesystem::path dir, boost::filesystem::path select);
68 std::string get_process_id ();
73 * @brief A class which tries to keep the computer awake on various operating systems.
75 * Create a Waker to prevent sleep, and call nudge() every so often (every minute or so).
76 * Destroy the Waker to allow sleep again.
89 IOPMAssertionID _assertion_id;
96 Drive (std::string device, std::vector<boost::filesystem::path> mount_points, uint64_t size, boost::optional<std::string> vendor, boost::optional<std::string> model)
98 , _mount_points(mount_points)
104 explicit Drive (std::string);
106 std::string as_xml () const;
108 std::string description () const;
110 std::string device () const {
114 bool mounted () const {
115 return !_mount_points.empty();
118 std::string log_summary () const;
120 /** Unmount any mounted partitions on a drive.
121 * @return true on success, false on failure.
125 static std::vector<Drive> get ();
129 std::vector<boost::filesystem::path> _mount_points;
132 boost::optional<std::string> _vendor;
133 boost::optional<std::string> _model;
136 void disk_write_finished ();
141 bool real; ///< true for a "real" disk, false for a synthesized APFS one
142 std::vector<std::string> parts; ///< parts of the media path after the :
149 boost::optional<std::string> vendor;
150 boost::optional<std::string> model;
151 OSXMediaPath media_path;
153 std::vector<boost::filesystem::path> mount_points;
158 boost::optional<OSXMediaPath> analyse_osx_media_path (std::string path);
159 std::vector<Drive> osx_disks_to_drives (std::vector<OSXDisk> disks);
165 ArgFixer(int argc, char** argv);
171 char** argv() const {
178 #ifdef DCPOMATIC_WINDOWS
179 std::vector<std::string> _argv_strings;