X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fwscript;h=9dea367c9faeaf73bd3ffe4c93f1bb51af4dbcac;hb=59404039618db5d70a2f8fc0cb8c49ae4f8ce527;hp=df2edbde1b31a14196735de7bdf030051dca67df;hpb=4d3caea8b70b4a19c8aa80d626d52d4f95114f8e;p=dcpomatic.git diff --git a/src/wx/wscript b/src/wx/wscript index df2edbde1..9dea367c9 100644 --- a/src/wx/wscript +++ b/src/wx/wscript @@ -1,36 +1,75 @@ +import os +import glob +from waflib import Logs +import i18n + +sources = """ + about_dialog.cc + audio_dialog.cc + audio_mapping_view.cc + audio_plot.cc + config_dialog.cc + dci_metadata_dialog.cc + dir_picker_ctrl.cc + film_editor.cc + film_viewer.cc + filter_dialog.cc + filter_view.cc + gain_calculator_dialog.cc + imagemagick_content_dialog.cc + job_manager_view.cc + job_wrapper.cc + new_film_dialog.cc + properties_dialog.cc + server_dialog.cc + timecode.cc + timeline.cc + timeline_dialog.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.STATIC: + args += ' --libs' + + conf.check_cfg(msg='Checking for wxWidgets', package='', path=conf.options.wx_config, args=args, + uselib_store='WXWIDGETS', mandatory=True) + + if conf.env.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_xrc-2.9', 'wx_gtk2u_qa-2.9', 'wx_baseu_net-2.9', 'wx_gtk2u_html-2.9', + 'wx_gtk2u_adv-2.9', 'wx_gtk2u_core-2.9', 'wx_baseu_xml-2.9', 'wx_baseu-2.9'] + conf.env.LIB_WXWIDGETS = ['tiff', 'SM', 'dl', 'jpeg', 'png', 'X11'] + + conf.in_msg = 1 + wx_version = conf.check_cfg(package='', path=conf.options.wx_config, args='--version').strip() + conf.im_msg = 0 + if wx_version != '2.9.4': + conf.fatal('wxwidgets version 2.9.4 is required; %s found' % wx_version) def build(bld): - obj = bld(features = 'cxx cxxshlib') - obj.name = 'libdvdomatic-wx' - obj.includes = [ '..' ] - obj.export_includes = ['.'] + if bld.env.STATIC: + obj = bld(features = 'cxx cxxstlib') + else: + obj = bld(features = 'cxx cxxshlib') + + obj.name = 'libdcpomatic-wx' +# obj.includes = [ '..' ] + obj.export_includes = ['..'] obj.uselib = 'WXWIDGETS' - obj.use = 'libdvdomatic' - obj.source = """ - config_dialog.cc - dci_name_dialog.cc - dcp_range_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 - """ - -# alignment.cc -# film_list.cc -# dvd_title_dialog.cc - - if not bld.env.DISABLE_PLAYER: - obj.source += " film_player.cc" - - obj.target = 'dvdomatic-wx' + if bld.env.TARGET_LINUX: + obj.uselib += ' GTK' + obj.use = 'libdcpomatic' + obj.source = sources + obj.target = 'dcpomatic-wx' + + i18n.po_to_mo(os.path.join('src', 'wx'), 'libdcpomatic-wx', bld) + +def pot(bld): + i18n.pot(os.path.join('src', 'wx'), sources, 'libdcpomatic-wx') + +def pot_merge(bld): + i18n.pot_merge(os.path.join('src', 'wx'), 'libdcpomatic-wx')