X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fwscript;h=77076c23e06d0c16098ae26c312973d944784c88;hb=6654f028571db33d1e203ff36f85619d03a9f9fb;hp=d2bf33cd35132e194d4253f17a2a6a95f1520cc2;hpb=9bf2cf3509380663e6943f6b0d22dbec6002c332;p=dcpomatic.git diff --git a/src/wx/wscript b/src/wx/wscript index d2bf33cd3..77076c23e 100644 --- a/src/wx/wscript +++ b/src/wx/wscript @@ -1,19 +1,20 @@ # # Copyright (C) 2012-2015 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 @@ -30,55 +31,84 @@ sources = """ audio_mapping_view.cc audio_panel.cc audio_plot.cc + batch_job_view.cc cinema_dialog.cc colour_conversion_editor.cc config_dialog.cc + config_move_dialog.cc + confirm_kdm_email_dialog.cc content_colour_conversion_dialog.cc content_menu.cc content_panel.cc content_properties_dialog.cc content_sub_panel.cc dcp_panel.cc + email_dialog.cc image_sequence_dialog.cc isdcf_metadata_dialog.cc dir_picker_ctrl.cc - dolby_certificate_dialog.cc - doremi_certificate_dialog.cc + dolby_doremi_certificate_panel.cc download_certificate_dialog.cc + download_certificate_panel.cc + export_dialog.cc file_picker_ctrl.cc film_editor.cc + film_name_location_dialog.cc film_viewer.cc filter_dialog.cc filter_editor.cc + focus_manager.cc fonts_dialog.cc font_files_dialog.cc + full_config_dialog.cc gain_calculator_dialog.cc hints_dialog.cc job_view.cc job_view_dialog.cc job_manager_view.cc + kdm_advanced_dialog.cc + kdm_cpl_panel.cc kdm_dialog.cc kdm_output_panel.cc kdm_timing_panel.cc key_dialog.cc make_chain_dialog.cc - new_film_dialog.cc - preset_colour_conversion_dialog.cc + move_to_dialog.cc + nag_dialog.cc + name_format_editor.cc + new_dkdm_folder_dialog.cc + normal_job_view.cc + paste_dialog.cc + player_config_dialog.cc + player_information.cc + playhead_to_timecode_dialog.cc + playhead_to_frame_dialog.cc + question_dialog.cc + recreate_chain_dialog.cc repeat_dialog.cc report_problem_dialog.cc + rename_template_dialog.cc + rgba_colour_picker.cc + save_template_dialog.cc screen_dialog.cc screens_panel.cc + self_dkdm_dialog.cc server_dialog.cc servers_list_dialog.cc + subtitle_appearance_dialog.cc subtitle_panel.cc subtitle_view.cc system_font_dialog.cc table_dialog.cc + templates_dialog.cc + time_picker.cc timecode.cc timeline.cc + timeline_atmos_content_view.cc timeline_content_view.cc timeline_dialog.cc timeline_audio_content_view.cc + timeline_labels_view.cc timeline_subtitle_content_view.cc timeline_reels_view.cc timeline_time_axis_view.cc @@ -86,6 +116,7 @@ sources = """ timeline_view.cc timing_panel.cc update_dialog.cc + verify_dcp_dialog.cc video_panel.cc video_waveform_dialog.cc video_waveform_plot.cc @@ -96,7 +127,7 @@ sources = """ def configure(conf): try: wx_config = 'wx-config-3.0-gtk2' - conf.check_cfg(msg='Checking for wxWidgets', + conf.check_cfg(msg='Checking for wxWidgets using wx-config-3.0-gtk2', package='', path=wx_config, args='--cppflags --cxxflags --libs std,richtext', @@ -104,7 +135,7 @@ def configure(conf): mandatory=True) except: wx_config = 'wx-config' - conf.check_cfg(msg='Checking for wxWidgets', + conf.check_cfg(msg='Checking for wxWidgets using wx-config', package='', path=wx_config, args='--cppflags --cxxflags --libs std,richtext', @@ -136,19 +167,62 @@ def configure(conf): if not wx_version.startswith('3.0.'): conf.fatal('wxwidgets version 3.0.x is required; %s found' % wx_version) + try: + conf.check_cfg(msg='Checking for RtAudio using pkg-config', + package='rtaudio', + args='--cflags --libs', + uselib_store='RTAUDIO', + mandatory=True) + except: + conf.check_cfg(msg='Checking for RtAudio headers using rtaudio-config', + package='', + path='rtaudio-config', + args='--cppflags', + uselib_store='RTAUDIO', + mandatory=True) + + conf.check_cfg(msg='Checking for RtAudio libraries using rtaudio-config', + package='', + path='rtaudio-config', + args='--libs', + uselib_store='RTAUDIO', + mandatory=True) + + # Some rtaudio-configs don't include rtaudio as a link library. Go figure. + conf.env.LIB_RTAUDIO.append('rtaudio') + # Don't explicitly link with pthread on Windows + if conf.env.TARGET_WINDOWS: + conf.env.CFLAGS_RTAUDIO.remove('-pthread') + conf.env.LINKFLAGS_RTAUDIO.remove('-pthread') + + conf.check_cxx(fragment=""" + #include \n + int main() { throw RtError("Hello"); } + """, + msg='Checking for RtError class', + libpath='/usr/local/lib', + lib=['rtaudio'], + uselib_store='', + define_name='DCPOMATIC_USE_RTERROR', + mandatory=False) + + + def build(bld): if bld.env.STATIC_DCPOMATIC: - obj = bld(features = 'cxx cxxstlib') + obj = bld(features='cxx cxxstlib') else: - obj = bld(features = 'cxx cxxshlib') + obj = bld(features='cxx cxxshlib') obj.name = 'libdcpomatic2-wx' obj.export_includes = ['..'] - obj.uselib = 'BOOST_FILESYSTEM BOOST_THREAD BOOST_REGEX WXWIDGETS DCP SUB ZIP ' + obj.uselib = 'BOOST_FILESYSTEM BOOST_THREAD BOOST_REGEX WXWIDGETS DCP SUB ZIP CXML RTAUDIO ' if bld.env.TARGET_LINUX: obj.uselib += 'GTK ' if bld.env.TARGET_WINDOWS: - obj.uselib += 'WINSOCK2 ' + obj.uselib += 'WINSOCK2 OLE32 DSOUND WINMM KSUSER ' + if bld.env.TARGET_OSX: + obj.framework = ['CoreAudio'] obj.use = 'libdcpomatic2' obj.source = sources obj.target = 'dcpomatic2-wx' @@ -156,7 +230,7 @@ def build(bld): i18n.po_to_mo(os.path.join('src', 'wx'), 'libdcpomatic2-wx', bld) def pot(bld): - i18n.pot(os.path.join('src', 'wx'), sources + " editable_list.h", 'libdcpomatic-wx') + i18n.pot(os.path.join('src', 'wx'), sources + " editable_list.h content_widget.h", 'libdcpomatic-wx') def pot_merge(bld): i18n.pot_merge(os.path.join('src', 'wx'), 'libdcpomatic-wx')