Basics of send-to-batch-converter; not tested on Windows nor OS X.
[dcpomatic.git] / src / lib / cross.h
1 /*
2     Copyright (C) 2012-2015 Carl Hetherington <cth@carlh.net>
3
4     This program is free software; you can redistribute it and/or modify
5     it under the terms of the GNU General Public License as published by
6     the Free Software Foundation; either version 2 of the License, or
7     (at your option) any later version.
8
9     This program is distributed in the hope that it will be useful,
10     but WITHOUT ANY WARRANTY; without even the implied warranty of
11     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12     GNU General Public License for more details.
13
14     You should have received a copy of the GNU General Public License
15     along with this program; if not, write to the Free Software
16     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17
18 */
19
20 /** @file  src/lib/cross.h
21  *  @brief Cross-platform compatibility code.
22  */
23
24 #ifndef DCPOMATIC_CROSS_H
25 #define DCPOMATIC_CROSS_H
26
27 #ifdef DCPOMATIC_OSX
28 #include <IOKit/pwr_mgt/IOPMLib.h>
29 #endif
30 #include <boost/filesystem.hpp>
31
32 #ifdef DCPOMATIC_WINDOWS
33 #define WEXITSTATUS(w) (w)
34 #endif
35
36 class Log;
37
38 void dcpomatic_sleep (int);
39 extern std::string cpu_info ();
40 extern void run_ffprobe (boost::filesystem::path, boost::filesystem::path, boost::shared_ptr<Log>);
41 extern std::list<std::pair<std::string, std::string> > mount_info ();
42 extern boost::filesystem::path openssl_path ();
43 #ifdef DCPOMATIC_OSX
44 extern boost::filesystem::path app_contents ();
45 #endif
46 extern boost::filesystem::path shared_path ();
47 extern FILE * fopen_boost (boost::filesystem::path, std::string);
48 extern int dcpomatic_fseek (FILE *, int64_t, int);
49 extern void start_batch_converter (boost::filesystem::path dcpomatic);
50
51 /** @class Waker
52  *  @brief A class which tries to keep the computer awake on various operating systems.
53  *
54  *  Create a Waker to prevent sleep, and call ::nudge every so often (every minute or so).
55  *  Destroy the Waker to allow sleep again.
56  */
57 class Waker
58 {
59 public:
60         Waker ();
61         ~Waker ();
62
63         void nudge ();
64
65 private:
66 #ifdef DCPOMATIC_OSX
67         IOPMAssertionID _assertion_id;
68 #endif
69 };
70
71 #endif