X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fwscript;h=883304effb68e8e3556bbb57eed1ce2e382d6799;hb=90ec60c9e5b45453525368842345ad1a6498fa61;hp=4dbb04eeacaa4cc0da3155f09e6243e5934b7dbb;hpb=9c58fcdb6fd8131c17456dd71c5c277a6b0ae053;p=dcpomatic.git diff --git a/src/wx/wscript b/src/wx/wscript index 4dbb04eea..6a6021c22 100644 --- a/src/wx/wscript +++ b/src/wx/wscript @@ -1,33 +1,105 @@ +import os +import glob +from waflib import Logs +import i18n + +sources = """ + about_dialog.cc + audio_dialog.cc + audio_gain_dialog.cc + audio_mapping_view.cc + audio_panel.cc + audio_plot.cc + cinema_dialog.cc + colour_conversion_editor.cc + config_dialog.cc + content_colour_conversion_dialog.cc + content_menu.cc + content_panel.cc + content_sub_panel.cc + dcp_panel.cc + isdcf_metadata_dialog.cc + dir_picker_ctrl.cc + dolby_certificate_dialog.cc + doremi_certificate_dialog.cc + download_certificate_dialog.cc + film_editor.cc + film_viewer.cc + filter_dialog.cc + filter_editor.cc + gain_calculator_dialog.cc + hints_dialog.cc + job_manager_view.cc + job_wrapper.cc + kdm_dialog.cc + make_signer_chain_dialog.cc + new_film_dialog.cc + preset_colour_conversion_dialog.cc + properties_dialog.cc + repeat_dialog.cc + report_problem_dialog.cc + screen_dialog.cc + server_dialog.cc + servers_list_dialog.cc + subtitle_panel.cc + subtitle_view.cc + table_dialog.cc + timecode.cc + timeline.cc + timeline_dialog.cc + timing_panel.cc + update_dialog.cc + video_panel.cc + wx_util.cc + wx_ui_signaller.cc + """ + def configure(conf): - conf.check_cfg(package = '', path = 'wx-config', args = '--cppflags --cxxflags --libs', uselib_store = 'WXWIDGETS', mandatory = True) + args = '--cppflags --cxxflags' + if not conf.env.BUILD_STATIC: + args += ' --libs std,richtext' + + conf.check_cfg(msg='Checking for wxWidgets', package='', path=conf.options.wx_config, args=args, + uselib_store='WXWIDGETS', mandatory=True) + + if conf.env.BUILD_STATIC: + # wx-config returns its static libraries as full paths, without -l prefixes, which confuses + # check_cfg(), so just hard-code it all. + conf.env.STLIB_WXWIDGETS = ['wx_gtk2u_richtext-3.0', 'wx_gtk2u_xrc-3.0', 'wx_gtk2u_qa-3.0', 'wx_baseu_net-3.0', 'wx_gtk2u_html-3.0', + 'wx_gtk2u_adv-3.0', 'wx_gtk2u_core-3.0', 'wx_baseu_xml-3.0', 'wx_baseu-3.0'] + conf.env.LIB_WXWIDGETS = ['tiff', 'SM', 'dl', 'jpeg', 'png', 'X11', 'expat'] + if conf.env.TARGET_DEBIAN and conf.env.DEBIAN_UNSTABLE: + conf.env.LIB_WXWIDGETS.append('Xext') + conf.env.LIB_WXWIDGETS.append('X11') + + if conf.env.TARGET_CENTOS_7: + conf.env.LIB_WXWIDGETS.append('Xxf86vm') + + conf.in_msg = 1 + wx_version = conf.check_cfg(package='', path=conf.options.wx_config, args='--version').strip() + conf.im_msg = 0 + if not wx_version.startswith('3.0.'): + conf.fatal('wxwidgets version 3.0.x is required; %s found' % wx_version) def build(bld): - if bld.env.STATIC: + if bld.env.BUILD_STATIC: obj = bld(features = 'cxx cxxstlib') else: obj = bld(features = 'cxx cxxshlib') - obj.name = 'libdvdomatic-wx' - obj.includes = [ '..' ] - obj.export_includes = ['.'] - obj.uselib = 'WXWIDGETS' - obj.use = 'libdvdomatic' - obj.source = """ - config_dialog.cc - dci_name_dialog.cc - dir_picker_ctrl.cc - film_editor.cc - film_viewer.cc - filter_dialog.cc - filter_view.cc - gain_calculator_dialog.cc - job_manager_view.cc - job_wrapper.cc - new_film_dialog.cc - properties_dialog.cc - server_dialog.cc - wx_util.cc - wx_ui_signaller.cc - """ - - obj.target = 'dvdomatic-wx' + obj.name = 'libdcpomatic2-wx' + obj.export_includes = ['..'] + obj.uselib = 'WXWIDGETS DCP' + if bld.env.TARGET_LINUX: + obj.uselib += ' GTK' + obj.use = 'libdcpomatic2' + obj.source = sources + obj.target = 'dcpomatic2-wx' + + 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') + +def pot_merge(bld): + i18n.pot_merge(os.path.join('src', 'wx'), 'libdcpomatic-wx')