X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Ftools%2Fwscript;h=c7c953a318b04eb3534679f8bbfef97e6ea871a7;hb=b029cb06c4e0fca1fad9fecd78939efe5532fa9a;hp=0670dd852c48bd5bdb403937bc548fe0cc3db981;hpb=e362d542009ffeadb4fc892bea605d03d9802bdf;p=dcpomatic.git diff --git a/src/tools/wscript b/src/tools/wscript index 0670dd852..c7c953a31 100644 --- a/src/tools/wscript +++ b/src/tools/wscript @@ -29,40 +29,75 @@ def configure(conf): def build(bld): uselib = 'BOOST_THREAD BOOST_DATETIME DCP XMLSEC CXML XMLPP AVFORMAT AVFILTER AVCODEC ' - uselib += 'AVUTIL SWSCALE POSTPROC CURL BOOST_FILESYSTEM SSH ZIP CAIROMM FONTCONFIG PANGOMM SUB MAGICK SNDFILE SAMPLERATE BOOST_REGEX ' - uselib += 'ICU NETTLE ' + uselib += 'AVUTIL SWSCALE SWRESAMPLE POSTPROC CURL BOOST_FILESYSTEM SSH ZIP CAIROMM FONTCONFIG PANGOMM SUB ' + uselib += 'SNDFILE SAMPLERATE BOOST_REGEX ICU NETTLE RTAUDIO PNG ' + + if bld.env.ENABLE_DISK: + if bld.env.TARGET_LINUX: + uselib += 'POLKIT ' + uselib += 'LWEXT4 NANOMSG ' if bld.env.TARGET_WINDOWS: - uselib += 'WINSOCK2 BFD DBGHELP IBERTY SHLWAPI MSWSOCK BOOST_LOCALE ' + uselib += 'WINSOCK2 DBGHELP SHLWAPI MSWSOCK BOOST_LOCALE WINSOCK2 OLE32 DSOUND WINMM KSUSER ' + if bld.env.TARGET_LINUX: + uselib += 'DL ' + + cli_tools = [] + if bld.env.VARIANT == 'swaroop-theater': + cli_tools = ['swaroop_dcpomatic_uuid'] + elif bld.env.VARIANT == 'swaroop-studio': + cli_tools = ['dcpomatic_cli', 'dcpomatic_server_cli', 'server_test', 'dcpomatic_kdm_cli', 'dcpomatic_create', 'swaroop_dcpomatic_ecinema', 'swaroop_dcpomatic_uuid'] + else: + cli_tools = ['dcpomatic_cli', 'dcpomatic_server_cli', 'server_test', 'dcpomatic_kdm_cli', 'dcpomatic_create'] + if bld.env.ENABLE_DISK: + cli_tools.append('dcpomatic_disk_writer') - for t in ['dcpomatic_cli', 'dcpomatic_server_cli', 'server_test', 'dcpomatic_kdm_cli', 'dcpomatic_create']: + for t in cli_tools: obj = bld(features='cxx cxxprogram') obj.uselib = uselib obj.includes = ['..'] obj.use = ['libdcpomatic2'] obj.source = '%s.cc' % t - obj.target = t.replace('dcpomatic', 'dcpomatic2') + if bld.env.TARGET_WINDOWS and t == 'dcpomatic_disk_writer': + obj.source += ' ../../platform/windows/%s.rc' % t + # Prevent a console window opening when we start dcpomatic2_disk_writer + bld.env.LINKFLAGS.append('-Wl,-subsystem,windows') + obj.target = t.replace('dcpomatic', 'dcpomatic2').replace('swaroop_', '') if t == 'server_test': obj.install_path = None + gui_tools = [] if not bld.env.DISABLE_GUI: - for t in ['dcpomatic', 'dcpomatic_batch', 'dcpomatic_server', 'dcpomatic_kdm']: - obj = bld(features='cxx cxxprogram') - obj.uselib = uselib - if bld.env.BUILD_STATIC or bld.env.TARGET_LINUX: - obj.uselib += ' GTK' - obj.uselib += ' WXWIDGETS' - obj.includes = ['..'] - obj.use = ['libdcpomatic2', 'libdcpomatic2-wx'] - obj.source = '%s.cc' % t - if bld.env.TARGET_WINDOWS: - obj.source += ' ../../platform/windows/%s.rc' % t - obj.target = t.replace('dcpomatic', 'dcpomatic2') + if bld.env.VARIANT == 'swaroop-theater': + gui_tools = ['dcpomatic_player', 'swaroop_dcpomatic_playlist'] + elif bld.env.VARIANT == 'swaroop-studio': + gui_tools = ['dcpomatic', 'dcpomatic_batch', 'dcpomatic_server', 'dcpomatic_kdm', 'dcpomatic_player', 'swaroop_dcpomatic_playlist'] + else: + gui_tools = ['dcpomatic', 'dcpomatic_batch', 'dcpomatic_server', 'dcpomatic_kdm', 'dcpomatic_player', 'dcpomatic_playlist'] + if bld.env.ENABLE_DISK: + gui_tools.append('dcpomatic_disk') + + for t in gui_tools: + obj = bld(features='cxx cxxprogram') + obj.uselib = uselib + if bld.env.BUILD_STATIC or bld.env.TARGET_LINUX: + obj.uselib += ' GTK' + obj.uselib += ' WXWIDGETS' + if not bld.env.TARGET_OSX: + obj.uselib += ' GL GLU' + if bld.env.TARGET_LINUX: + obj.uselib += ' X11' + obj.includes = ['..'] + obj.use = ['libdcpomatic2', 'libdcpomatic2-wx'] + obj.source = '%s.cc' % t + if bld.env.TARGET_WINDOWS: + obj.source += ' ../../platform/windows/%s.rc' % t + obj.target = t.replace('dcpomatic', 'dcpomatic2').replace('swaroop_', '') - i18n.po_to_mo(os.path.join('src', 'tools'), 'dcpomatic2', bld) + i18n.po_to_mo(os.path.join('src', 'tools'), 'dcpomatic2', bld) def pot(bld): - i18n.pot(os.path.join('src', 'tools'), 'dcpomatic.cc dcpomatic_batch.cc dcpomatic_kdm.cc dcpomatic_server.cc', 'dcpomatic') + i18n.pot(os.path.join('src', 'tools'), 'dcpomatic.cc dcpomatic_batch.cc dcpomatic_kdm.cc dcpomatic_server.cc dcpomatic_player.cc dcpomatic_playlist.cc', 'dcpomatic') def pot_merge(bld): i18n.pot_merge(os.path.join('src', 'tools'), 'dcpomatic')