+#
+# Copyright (C) 2012-2015 Carl Hetherington <cth@carlh.net>
+#
+# This program 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,
+# 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.
+#
+
import os
+import subprocess
+import shlex
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
- dci_metadata_dialog.cc
+ content_colour_conversion_dialog.cc
+ content_menu.cc
+ content_panel.cc
+ content_properties_dialog.cc
+ content_sub_panel.cc
+ dcp_panel.cc
+ editable_list.cc
+ email_dialog.cc
+ image_sequence_dialog.cc
+ image_subtitle_colour_dialog.cc
+ isdcf_metadata_dialog.cc
dir_picker_ctrl.cc
+ dolby_doremi_certificate_panel.cc
+ download_certificate_dialog.cc
+ download_certificate_panel.cc
+ file_picker_ctrl.cc
film_editor.cc
film_viewer.cc
filter_dialog.cc
- filter_view.cc
+ filter_editor.cc
+ fonts_dialog.cc
+ font_files_dialog.cc
gain_calculator_dialog.cc
- imagemagick_content_dialog.cc
+ hints_dialog.cc
+ job_view.cc
+ job_view_dialog.cc
job_manager_view.cc
- job_wrapper.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
- properties_dialog.cc
+ preset_colour_conversion_dialog.cc
+ repeat_dialog.cc
+ report_problem_dialog.cc
+ rgba_colour_picker.cc
+ screen_dialog.cc
+ screens_panel.cc
+ self_dkdm_dialog.cc
server_dialog.cc
+ servers_list_dialog.cc
+ subtitle_panel.cc
+ subtitle_view.cc
+ system_font_dialog.cc
+ table_dialog.cc
+ text_subtitle_appearance_dialog.cc
+ timecode.cc
+ timeline.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
+ timeline_video_content_view.cc
+ timeline_view.cc
+ timing_panel.cc
+ update_dialog.cc
+ video_panel.cc
+ video_waveform_dialog.cc
+ video_waveform_plot.cc
wx_util.cc
- wx_ui_signaller.cc
+ wx_signal_manager.cc
"""
def configure(conf):
- conf.check_cfg(package = '', path = conf.options.wx_config, args = '--cppflags --cxxflags --libs', uselib_store = 'WXWIDGETS', mandatory = True)
+ try:
+ wx_config = 'wx-config-3.0-gtk2'
+ conf.check_cfg(msg='Checking for wxWidgets using wx-config-3.0-gtk2',
+ package='',
+ path=wx_config,
+ args='--cppflags --cxxflags --libs std,richtext',
+ uselib_store='WXWIDGETS',
+ mandatory=True)
+ except:
+ wx_config = 'wx-config'
+ conf.check_cfg(msg='Checking for wxWidgets using wx-config',
+ package='',
+ path=wx_config,
+ args='--cppflags --cxxflags --libs std,richtext',
+ uselib_store='WXWIDGETS',
+ mandatory=True)
+
+ if conf.options.static_wxwidgets:
+ # wx-config returns its static libraries as full paths, without -l prefixes, which confuses
+ # check_cfg(). It puts the static libraries into LINKFLAGS_WXWIDGETS, so fish them out.
+ stlibs = []
+ new_linkflags = []
+ stlib_paths = []
+ for f in conf.env.LINKFLAGS_WXWIDGETS:
+ if f.startswith('/'):
+ d = os.path.dirname(f)
+ if not d in stlib_paths:
+ stlib_paths.append(d)
+ stlibs.append(os.path.basename(f)[3:-2])
+ else:
+ new_linkflags.append(f)
+
+ conf.env.STLIB_WXWIDGETS = stlibs
+ conf.env.LINKFLAGS_WXWIDGETS = new_linkflags
+ conf.env.STLIBPATH_WXWIDGETS = stlib_paths
+
+ conf.in_msg = 1
+ wx_version = conf.check_cfg(package='', path=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.STATIC_DCPOMATIC:
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.name = 'libdcpomatic2-wx'
+ obj.export_includes = ['..']
+ obj.uselib = 'BOOST_FILESYSTEM BOOST_THREAD BOOST_REGEX WXWIDGETS DCP SUB ZIP '
+ if bld.env.TARGET_LINUX:
+ obj.uselib += 'GTK '
+ if bld.env.TARGET_WINDOWS:
+ obj.uselib += 'WINSOCK2 '
+ obj.use = 'libdcpomatic2'
obj.source = sources
- obj.target = 'dvdomatic-wx'
+ obj.target = 'dcpomatic2-wx'
- i18n.po_to_mo(os.path.join('src', 'wx'), 'libdvdomatic-wx', bld)
+ i18n.po_to_mo(os.path.join('src', 'wx'), 'libdcpomatic2-wx', bld)
def pot(bld):
- i18n.pot(os.path.join('src', 'wx'), sources, 'libdvdomatic-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'), 'libdvdomatic-wx')
+ i18n.pot_merge(os.path.join('src', 'wx'), 'libdcpomatic-wx')