return deps
def option_defaults():
- return { "player-only": False, "gui": True, "variant": None }
+ return { "gui": True, "variant": None }
def configure_options(target, options):
opt = ''
if not options['gui']:
opt += ' --disable-gui'
- if options['player-only']:
- opt += ' --player-only'
-
if options['variant'] is not None:
opt += ' --variant=%s' % options['variant']
_image_display = 0;
_respect_kdm_validity_periods = true;
_player_log_file = boost::none;
+ _player_dcp_directory = boost::none;
_allowed_dcp_frame_rates.clear ();
_allowed_dcp_frame_rates.push_back (24);
_image_display = f.optional_number_child<int>("ImageDisplay").get_value_or(0);
_respect_kdm_validity_periods = f.optional_bool_child("RespectKDMValidityPeriods").get_value_or(true);
_player_log_file = f.optional_string_child("PlayerLogFile");
+ _player_dcp_directory = f.optional_string_child("PlayerDCPDirectory");
/* Replace any cinemas from config.xml with those from the configured file */
if (boost::filesystem::exists (_cinemas_file)) {
if (_player_log_file) {
root->add_child("PlayerLogFile")->add_child_text(_player_log_file->string());
}
+ if (_player_dcp_directory) {
+ root->add_child("PlayerDCPDirectory")->add_child_text(_player_dcp_directory->string());
+ }
try {
doc.write_to_file_formatted(config_file().string());
return _player_log_file;
}
+ boost::optional<boost::filesystem::path> player_dcp_directory () const {
+ return _player_dcp_directory;
+ }
+
/* SET (mostly) */
void set_master_encoding_threads (int n) {
changed ();
}
+ void set_player_dcp_directory (boost::filesystem::path p) {
+ maybe_set (_player_dcp_directory, p);
+ }
+
+ void unset_player_dcp_directory () {
+ if (!_player_dcp_directory) {
+ return;
+ }
+ _player_dcp_directory = boost::none;
+ changed ();
+ }
+
void changed (Property p = OTHER);
boost::signals2::signal<void (Property)> Changed;
/** Emitted if read() failed on an existing Config file. There is nothing
int _image_display;
bool _respect_kdm_validity_periods;
boost::optional<boost::filesystem::path> _player_log_file;
+ /** A directory containing DCPs whose contents are presented to the user
+ in the dual-screen player mode. DCPs on the list can be loaded
+ for playback.
+ */
+ boost::optional<boost::filesystem::path> _player_dcp_directory;
static int const _current_version;
if bld.env.TARGET_WINDOWS:
uselib += 'WINSOCK2 DBGHELP SHLWAPI MSWSOCK BOOST_LOCALE WINSOCK2 OLE32 DSOUND WINMM KSUSER '
- if not bld.env.PLAYER_ONLY:
+ if bld.env.VARIANT != "swaroop":
for t in ['dcpomatic_cli', 'dcpomatic_server_cli', 'server_test', 'dcpomatic_kdm_cli', 'dcpomatic_create']:
obj = bld(features='cxx cxxprogram')
obj.uselib = uselib
gui_tools = []
if not bld.env.DISABLE_GUI:
- if bld.env.PLAYER_ONLY:
+ if bld.env.VARIANT == 'swaroop':
gui_tools = ['dcpomatic_player']
else:
gui_tools = ['dcpomatic', 'dcpomatic_batch', 'dcpomatic_server', 'dcpomatic_kdm', 'dcpomatic_player']
*/
+#ifndef DCPOMATIC_DIR_PICKER_CTRL
+#define DCPOMATIC_DIR_PICKER_CTRL
+
#include <wx/wx.h>
class DirPickerCtrl : public wxPanel
wxString _path;
wxSizer* _sizer;
};
+
+#endif
#include <dcp/locale_convert.h>
#include <wx/spinctrl.h>
#include <wx/splash.h>
+#include <wx/filepicker.h>
#include <boost/thread.hpp>
using namespace std;
}
}
+void
+checked_set (wxDirPickerCtrl* widget, boost::filesystem::path value)
+{
+ if (widget->GetPath() != std_to_wx (value.string())) {
+ if (value.empty()) {
+ /* Hack to make wxWidgets clear the control when we are passed
+ an empty value.
+ */
+ value = " ";
+ }
+ widget->SetPath (std_to_wx (value.string()));
+ }
+}
+
void
checked_set (wxSpinCtrl* widget, int value)
{
#endif
class FilePickerCtrl;
+class wxDirPickerCtrl;
class wxSpinCtrl;
class wxSpinCtrlDouble;
class wxGridBagSizer;
extern double calculate_mark_interval (double start);
extern void checked_set (FilePickerCtrl* widget, boost::filesystem::path value);
+extern void checked_set (wxDirPickerCtrl* widget, boost::filesystem::path value);
extern void checked_set (wxSpinCtrl* widget, int value);
extern void checked_set (wxSpinCtrlDouble* widget, double value);
extern void checked_set (wxChoice* widget, int value);
opt.add_option('--enable-debug', action='store_true', default=False, help='build with debugging information and without optimisation')
opt.add_option('--disable-gui', action='store_true', default=False, help='disable building of GUI tools')
- opt.add_option('--player-only', action='store_true', default=False, help='just build the player; no other tools')
opt.add_option('--disable-tests', action='store_true', default=False, help='disable building of tests')
opt.add_option('--install-prefix', default=None, help='prefix of where DCP-o-matic will be installed')
opt.add_option('--target-windows', action='store_true', default=False, help='set up to do a cross-compile to make a Windows package')
# Save conf.options that we need elsewhere in conf.env
conf.env.DISABLE_GUI = conf.options.disable_gui
- conf.env.PLAYER_ONLY = conf.options.player_only
conf.env.DISABLE_TESTS = conf.options.disable_tests
conf.env.TARGET_WINDOWS = conf.options.target_windows
conf.env.TARGET_OSX = sys.platform == 'darwin'
conf.env.append_value('CXXFLAGS', '-O2')
if conf.options.variant is not None:
+ conf.env.VARIANT = conf.options.variant
conf.env.append_value('CXXFLAGS', '-DDCPOMATIC_VARIANT_%s' % conf.options.variant.upper())
#