X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Ftools%2Fwscript;h=be5297beb06e8cee0f1ac1f6acf73fc49ca905dd;hp=c9b164ab876f28fba5d3d05304a6769bf7ff13e2;hb=f37c1e40dcd5186c5aee95a4b0e6607c1b0045e4;hpb=bce51f69e4c4839f3e63f21b783c6a6fcd0ba4ae diff --git a/src/tools/wscript b/src/tools/wscript index c9b164ab8..be5297beb 100644 --- a/src/tools/wscript +++ b/src/tools/wscript @@ -1,19 +1,20 @@ # -# Copyright (C) 2012-2015 Carl Hetherington +# Copyright (C) 2012-2020 Carl Hetherington # -# This program is free software; you can redistribute it and/or modify +# This file is part of DCP-o-matic. +# +# DCP-o-matic is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # -# This program is distributed in the hope that it will be useful, +# DCP-o-matic is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License -# along with this program; if not, write to the Free Software -# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. +# along with DCP-o-matic. If not, see . # import os @@ -22,44 +23,72 @@ from waflib import Logs import i18n def configure(conf): - if conf.env.TARGET_WINDOWS: + if conf.env.TARGET_WINDOWS_64 or conf.env.TARGET_WINDOWS_32: conf.env.append_value('CXXFLAGS', ['-mconsole']) conf.env.append_value('LINKFLAGS', ['-mconsole']) def build(bld): - uselib = 'BOOST_THREAD BOOST_DATETIME OPENJPEG DCP XMLSEC CXML XMLPP AVFORMAT AVFILTER AVCODEC ' - uselib += 'AVUTIL SWSCALE POSTPROC CURL BOOST_FILESYSTEM SSH WXWIDGETS ZIP CAIROMM PANGOMM' + uselib = 'BOOST_THREAD BOOST_DATETIME DCP XMLSEC CXML XMLPP AVFORMAT AVFILTER AVCODEC ' + uselib += 'AVUTIL SWSCALE SWRESAMPLE POSTPROC CURL BOOST_FILESYSTEM SSH ZIP CAIROMM FONTCONFIG PANGOMM SUB ' + uselib += 'SNDFILE SAMPLERATE BOOST_REGEX ICU NETTLE RTAUDIO PNG JPEG LEQM_NRT ' + + if bld.env.ENABLE_DISK: + if bld.env.TARGET_LINUX: + uselib += 'POLKIT ' + uselib += 'LWEXT4 NANOMSG ' - if bld.env.TARGET_WINDOWS: - uselib += 'WINSOCK2' + if bld.env.TARGET_WINDOWS_64 or bld.env.TARGET_WINDOWS_32: + uselib += 'WINSOCK2 DBGHELP SHLWAPI MSWSOCK BOOST_LOCALE WINSOCK2 OLE32 DSOUND WINMM KSUSER SETUPAPI ' + if bld.env.TARGET_LINUX: + uselib += 'DL ' - for t in ['dcpomatic_cli', 'dcpomatic_server_cli', 'server_test', 'dcpomatic_kdm', 'dcpomatic_create']: - obj = bld(features = 'cxx cxxprogram') + cli_tools = ['dcpomatic_cli', 'dcpomatic_server_cli', 'server_test', 'dcpomatic_kdm_cli', 'dcpomatic_create'] + if bld.env.ENABLE_DISK and not bld.env.DISABLE_GUI: + cli_tools.append('dcpomatic_disk_writer') + + for t in cli_tools: + obj = bld(features='cxx cxxprogram') obj.uselib = uselib obj.includes = ['..'] obj.use = ['libdcpomatic2'] obj.source = '%s.cc' % t + if (bld.env.TARGET_WINDOWS_64 or bld.env.TARGET_WINDOWS_32) and t == 'dcpomatic_disk_writer': + obj.source += ' ../../platform/windows/%s.rc' % t + # Prevent a console window opening when we start dcpomatic2_disk_writer + obj.env.append_value('LINKFLAGS', '-Wl,-subsystem,windows') obj.target = t.replace('dcpomatic', 'dcpomatic2') if t == 'server_test': obj.install_path = None + gui_tools = [] if not bld.env.DISABLE_GUI: - for t in ['dcpomatic', 'dcpomatic_batch', 'dcpomatic_server']: - obj = bld(features = 'cxx cxxprogram') - obj.uselib = uselib - if bld.env.BUILD_STATIC or bld.env.TARGET_LINUX: - obj.uselib += ' GTK' - obj.includes = ['..'] - obj.use = ['libdcpomatic2', 'libdcpomatic2-wx'] - obj.source = '%s.cc' % t - if bld.env.TARGET_WINDOWS: - obj.source += ' ../../platform/windows/dcpomatic.rc' - obj.target = t.replace('dcpomatic', 'dcpomatic2') + gui_tools = ['dcpomatic', 'dcpomatic_batch', 'dcpomatic_server', 'dcpomatic_kdm', 'dcpomatic_player', 'dcpomatic_playlist', 'dcpomatic_combiner', 'dcpomatic_editor'] + 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' + if bld.env.TARGET_WINDOWS_64 or bld.env.TARGET_WINDOWS_32: + obj.uselib += ' GLEW' + obj.includes = ['..'] + obj.use = ['libdcpomatic2', 'libdcpomatic2-wx'] + obj.source = '%s.cc' % t + if bld.env.TARGET_WINDOWS_64 or bld.env.TARGET_WINDOWS_32: + obj.source += ' ../../platform/windows/%s.rc' % t + obj.target = t.replace('dcpomatic', 'dcpomatic2') - 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') + 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')