+#
+# 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 subprocess
import os
+import shlex
import sys
+import glob
import distutils
import distutils.spawn
+from waflib import Logs
APPNAME = 'dcpomatic'
-VERSION = '2.0.39'
+VERSION = '2.1.23'
def options(opt):
opt.load('compiler_cxx')
opt.add_option('--enable-debug', action='store_true', default=False, help='build with debugging information and without optimisation')
opt.add_option('--disable-gui', action='store_true', default=False, help='disable building of GUI tools')
opt.add_option('--disable-tests', action='store_true', default=False, help='disable building of tests')
- opt.add_option('--target-windows', action='store_true', default=False, help='set up to do a cross-compile to make a Windows package')
- opt.add_option('--target-debian', action='store_true', default=False, help='set up to compile for a Debian/Ubuntu package')
- opt.add_option('--debian-unstable', action='store_true', default=False, help='add extra libraries to static-build correctly on Debian unstable')
- opt.add_option('--target-centos-6', action='store_true', default=False, help='set up to compile for a Centos 6.5 package')
- opt.add_option('--target-centos-7', action='store_true', default=False, help='set up to compile for a Centos 7 package')
- opt.add_option('--magickpp-config', action='store', default='Magick++-config', help='path to Magick++-config')
- opt.add_option('--wx-config', action='store', default='wx-config', help='path to wx-config')
- opt.add_option('--address-sanitizer', action='store_true', default=False, help='build with address sanitizer')
opt.add_option('--install-prefix', default=None, help='prefix of where DCP-o-matic will be installed')
-
-def static_ffmpeg(conf):
- conf.check_cfg(package='libavformat', args='--cflags', uselib_store='AVFORMAT', mandatory=True)
- conf.env.STLIB_AVFORMAT = ['avformat']
- conf.check_cfg(package='libavfilter', args='--cflags', uselib_store='AVFILTER', mandatory=True)
- conf.env.STLIB_AVFILTER = ['avfilter', 'swresample']
- conf.check_cfg(package='libavcodec', args='--cflags', uselib_store='AVCODEC', mandatory=True)
- # lzma link is needed by Centos 7, at least
- conf.env.STLIB_AVCODEC = ['avcodec']
- conf.env.LIB_AVCODEC = ['z', 'lzma']
- conf.check_cfg(package='libavutil', args='--cflags', uselib_store='AVUTIL', mandatory=True)
- conf.env.STLIB_AVUTIL = ['avutil']
- conf.check_cfg(package='libswscale', args='--cflags', uselib_store='SWSCALE', mandatory=True)
- conf.env.STLIB_SWSCALE = ['swscale']
- conf.check_cfg(package='libswresample', args='--cflags', uselib_store='SWRESAMPLE', mandatory=True)
- conf.env.STLIB_SWRESAMPLE = ['swresample']
- conf.check_cfg(package='libpostproc', args='--cflags', uselib_store='POSTPROC', mandatory=True)
- conf.env.STLIB_POSTPROC = ['postproc']
-
-def dynamic_ffmpeg(conf):
- conf.check_cfg(package='libavformat', args='--cflags --libs', uselib_store='AVFORMAT', mandatory=True)
- conf.check_cfg(package='libavfilter', args='--cflags --libs', uselib_store='AVFILTER', mandatory=True)
- conf.check_cfg(package='libavcodec', args='--cflags --libs', uselib_store='AVCODEC', mandatory=True)
- conf.check_cfg(package='libavutil', args='--cflags --libs', uselib_store='AVUTIL', mandatory=True)
- conf.check_cfg(package='libswscale', args='--cflags --libs', uselib_store='SWSCALE', mandatory=True)
- conf.check_cfg(package='libswresample', args='--cflags --libs', uselib_store='SWRESAMPLE', mandatory=True)
- conf.check_cfg(package='libpostproc', args='--cflags --libs', uselib_store='POSTPROC', mandatory=True)
-
-def static_openjpeg(conf):
- conf.check_cfg(package='libopenjpeg', args='--cflags', atleast_version='1.5.0', uselib_store='OPENJPEG', mandatory=True)
- conf.check_cfg(package='libopenjpeg', args='--cflags', max_version='1.5.2', mandatory=True)
- conf.env.STLIB_OPENJPEG = ['openjpeg']
-
-def dynamic_openjpeg(conf):
- conf.check_cfg(package='libopenjpeg', args='--cflags --libs', atleast_version='1.5.0', uselib_store='OPENJPEG', mandatory=True)
- conf.check_cfg(package='libopenjpeg', args='--cflags --libs', max_version='1.5.2', mandatory=True)
-
-def static_sub(conf):
- conf.check_cfg(package='libsub-1.0', atleast_version='1.0.0', args='--cflags', uselib_store='SUB', mandatory=True)
- conf.env.DEFINES_SUB = [f.replace('\\', '') for f in conf.env.DEFINES_SUB]
- conf.env.STLIB_SUB = ['sub-1.0']
-
-def static_dcp(conf, static_boost, static_xmlpp, static_xmlsec, static_ssh):
- conf.check_cfg(package='libdcp-1.0', atleast_version='1.0', args='--cflags', uselib_store='DCP', mandatory=True)
- conf.env.DEFINES_DCP = [f.replace('\\', '') for f in conf.env.DEFINES_DCP]
- conf.env.STLIB_DCP = ['dcp-1.0', 'asdcp-libdcp-1.0', 'kumu-libdcp-1.0']
- conf.env.LIB_DCP = ['glibmm-2.4', 'ssl', 'crypto', 'bz2', 'xslt']
-
- if static_boost:
- conf.env.STLIB_DCP.append('boost_system')
-
- if static_xmlpp:
- conf.env.STLIB_DCP.append('xml++-2.6')
- else:
- conf.env.LIB_DCP.append('xml++-2.6')
-
- if static_xmlsec:
- conf.env.STLIB_DCP.append('xmlsec1-openssl')
- conf.env.STLIB_DCP.append('xmlsec1')
- else:
- conf.env.LIB_DCP.append('xmlsec1-openssl')
- conf.env.LIB_DCP.append('xmlsec1')
-
- if static_ssh:
- conf.env.STLIB_DCP.append('ssh')
- else:
- conf.env.LIB_DCP.append('ssh')
-
-def dynamic_dcp(conf):
- conf.check_cfg(package='libdcp-1.0', atleast_version='0.92', args='--cflags --libs', uselib_store='DCP', mandatory=True)
- conf.env.DEFINES_DCP = [f.replace('\\', '') for f in conf.env.DEFINES_DCP]
-
-def dynamic_sub(conf):
- conf.check_cfg(package='libsub-1.0', atleast_version='1.0.0', args='--cflags --libs', uselib_store='SUB', mandatory=True)
- conf.env.DEFINES_SUB = [f.replace('\\', '') for f in conf.env.DEFINES_SUB]
-
-def dynamic_ssh(conf):
- conf.check_cc(fragment="""
- #include <libssh/libssh.h>\n
- int main () {\n
- ssh_session s = ssh_new ();\n
- return 0;\n
- }
- """, msg='Checking for library libssh', mandatory=True, lib='ssh', uselib_store='SSH')
-
-def dynamic_boost(conf, lib_suffix, thread):
- conf.check_cxx(fragment="""
- #include <boost/version.hpp>\n
- #if BOOST_VERSION < 104500\n
- #error boost too old\n
- #endif\n
- int main(void) { return 0; }\n
- """,
- mandatory=True,
- msg='Checking for boost library >= 1.45',
- okmsg='yes',
- errmsg='too old\nPlease install boost version 1.45 or higher.')
-
- conf.check_cxx(fragment="""
- #include <boost/thread.hpp>\n
- int main() { boost::thread t (); }\n
- """, msg='Checking for boost threading library',
- libpath='/usr/local/lib',
- lib=[thread, 'boost_system%s' % lib_suffix],
- uselib_store='BOOST_THREAD')
-
- conf.check_cxx(fragment="""
- #include <boost/filesystem.hpp>\n
- int main() { boost::filesystem::copy_file ("a", "b"); }\n
- """, msg='Checking for boost filesystem library',
- libpath='/usr/local/lib',
- lib=['boost_filesystem%s' % lib_suffix, 'boost_system%s' % lib_suffix],
- uselib_store='BOOST_FILESYSTEM')
-
- conf.check_cxx(fragment="""
- #include <boost/date_time.hpp>\n
- int main() { boost::gregorian::day_clock::local_day(); }\n
- """, msg='Checking for boost datetime library',
- libpath='/usr/local/lib',
- lib=['boost_date_time%s' % lib_suffix, 'boost_system%s' % lib_suffix],
- uselib_store='BOOST_DATETIME')
-
- conf.check_cxx(fragment="""
- #include <boost/signals2.hpp>\n
- int main() { boost::signals2::signal<void (int)> x; }\n
- """,
- msg='Checking for boost signals2 library',
- uselib_store='BOOST_SIGNALS2')
-
-def static_boost(conf, lib_suffix):
- conf.env.STLIB_BOOST_THREAD = ['boost_thread']
- conf.env.STLIB_BOOST_FILESYSTEM = ['boost_filesystem%s' % lib_suffix]
- conf.env.STLIB_BOOST_DATETIME = ['boost_date_time%s' % lib_suffix, 'boost_system%s' % lib_suffix]
- conf.env.STLIB_BOOST_SIGNALS2 = ['boost_signals2']
+ opt.add_option('--target-windows', action='store_true', default=False, help='set up to do a cross-compile to make a Windows package')
+ opt.add_option('--static-dcpomatic', action='store_true', default=False, help='link to components of DCP-o-matic statically')
+ opt.add_option('--static-boost', action='store_true', default=False, help='link statically to Boost')
+ opt.add_option('--static-openjpeg', action='store_true', default=False, help='link statically to OpenJPEG')
+ opt.add_option('--static-wxwidgets', action='store_true', default=False, help='link statically to wxWidgets')
+ opt.add_option('--static-ffmpeg', action='store_true', default=False, help='link statically to FFmpeg')
+ opt.add_option('--static-xmlpp', action='store_true', default=False, help='link statically to libxml++')
+ opt.add_option('--static-xmlsec', action='store_true', default=False, help='link statically to xmlsec')
+ opt.add_option('--static-ssh', action='store_true', default=False, help='link statically to libssh')
+ opt.add_option('--static-cxml', action='store_true', default=False, help='link statically to libcxml')
+ opt.add_option('--static-dcp', action='store_true', default=False, help='link statically to libdcp')
+ opt.add_option('--static-sub', action='store_true', default=False, help='link statically to libsub')
+ opt.add_option('--static-curl', action='store_true', default=False, help='link statically to libcurl')
+ opt.add_option('--workaround-gssapi', action='store_true', default=False, help='link to gssapi_krb5')
def configure(conf):
conf.load('compiler_cxx')
if conf.options.target_windows:
conf.load('winres')
- # conf.options -> conf.env
- conf.env.TARGET_WINDOWS = conf.options.target_windows
+ # Save conf.options that we need elsewhere in conf.env
conf.env.DISABLE_GUI = conf.options.disable_gui
conf.env.DISABLE_TESTS = conf.options.disable_tests
- conf.env.TARGET_DEBIAN = conf.options.target_debian
- conf.env.DEBIAN_UNSTABLE = conf.options.debian_unstable
- conf.env.TARGET_CENTOS_6 = conf.options.target_centos_6
- conf.env.TARGET_CENTOS_7 = conf.options.target_centos_7
- conf.env.VERSION = VERSION
+ conf.env.TARGET_WINDOWS = conf.options.target_windows
conf.env.TARGET_OSX = sys.platform == 'darwin'
conf.env.TARGET_LINUX = not conf.env.TARGET_WINDOWS and not conf.env.TARGET_OSX
- # true if we should build dcpomatic/libdcpomatic/libdcpomatic-wx statically
- conf.env.BUILD_STATIC = conf.options.target_debian or conf.options.target_centos_6 or conf.options.target_centos_7
+ conf.env.VERSION = VERSION
+ conf.env.DEBUG = conf.options.enable_debug
+ conf.env.STATIC_DCPOMATIC = conf.options.static_dcpomatic
if conf.options.install_prefix is None:
conf.env.INSTALL_PREFIX = conf.env.PREFIX
else:
conf.env.INSTALL_PREFIX = conf.options.install_prefix
# Common CXXFLAGS
- conf.env.append_value('CXXFLAGS', ['-D__STDC_CONSTANT_MACROS', '-D__STDC_LIMIT_MACROS', '-msse', '-ffast-math', '-fno-strict-aliasing',
- '-Wall', '-Wno-attributes', '-Wextra', '-Wno-unused-result', '-D_FILE_OFFSET_BITS=64'])
+ conf.env.append_value('CXXFLAGS', ['-D__STDC_CONSTANT_MACROS',
+ '-D__STDC_LIMIT_MACROS',
+ '-D__STDC_FORMAT_MACROS',
+ '-msse',
+ '-ffast-math',
+ '-fno-strict-aliasing',
+ '-Wall',
+ '-Wno-attributes',
+ '-Wextra',
+ '-Wno-unused-result',
+ '-D_FILE_OFFSET_BITS=64'])
if conf.options.enable_debug:
conf.env.append_value('CXXFLAGS', ['-g', '-DDCPOMATIC_DEBUG'])
else:
conf.env.append_value('CXXFLAGS', '-O2')
- if conf.options.address_sanitizer:
- conf.env.append_value('CXXFLAGS', ['-fsanitize=address', '-fno-omit-frame-pointer'])
- conf.env.append_value('LINKFLAGS', ['-fsanitize=address'])
-
#
- # Platform-specific CFLAGS hacks and other tinkering
+ # Windows/Linux/OS X specific
#
# Windows
conf.check(lib='mswsock', uselib_store='MSWSOCK', msg="Checking for library mswsock")
boost_lib_suffix = '-mt'
boost_thread = 'boost_thread_win32-mt'
+ conf.check_cxx(fragment="""
+ #include <boost/locale.hpp>\n
+ int main() { std::locale::global (boost::locale::generator().generate ("")); }\n
+ """,
+ msg='Checking for boost locale library',
+ libpath='/usr/local/lib',
+ lib=['boost_locale%s' % boost_lib_suffix, 'boost_system%s' % boost_lib_suffix],
+ uselib_store='BOOST_LOCALE')
# POSIX
if conf.env.TARGET_LINUX or conf.env.TARGET_OSX:
conf.env.append_value('CXXFLAGS', '-DDCPOMATIC_POSIX')
- conf.env.append_value('CXXFLAGS', '-DPOSIX_LOCALE_PREFIX="%s/share/locale"' % conf.env['INSTALL_PREFIX'])
- conf.env.append_value('CXXFLAGS', '-DPOSIX_ICON_PREFIX="%s/share/dcpomatic2"' % conf.env['INSTALL_PREFIX'])
boost_lib_suffix = ''
boost_thread = 'boost_thread'
conf.env.append_value('LINKFLAGS', '-pthread')
# Linux
if conf.env.TARGET_LINUX:
conf.env.append_value('CXXFLAGS', '-mfpmath=sse')
+ conf.env.append_value('CXXFLAGS', '-DLINUX_LOCALE_PREFIX="%s/share/locale"' % conf.env['INSTALL_PREFIX'])
+ conf.env.append_value('CXXFLAGS', '-DLINUX_SHARE_PREFIX="%s/share/dcpomatic2"' % conf.env['INSTALL_PREFIX'])
conf.env.append_value('CXXFLAGS', '-DDCPOMATIC_LINUX')
-
- if conf.env.TARGET_DEBIAN:
- # libxml2 seems to be linked against this on Ubuntu but it doesn't mention it in its .pc file
- conf.check_cfg(package='liblzma', args='--cflags --libs', uselib_store='LZMA', mandatory=True)
-
- if conf.env.TARGET_CENTOS_6 or conf.env.TARGET_CENTOS_7:
- # libavcodec seems to be linked against this on Centos
- conf.check_cfg(package='liblzma', args='--cflags --libs', uselib_store='LZMA', mandatory=True)
-
- if not conf.env.DISABLE_GUI and conf.env.TARGET_LINUX:
- conf.check_cfg(package='gtk+-2.0', args='--cflags --libs', uselib_store='GTK', mandatory=True)
+ if not conf.env.DISABLE_GUI:
+ conf.check_cfg(package='gtk+-2.0', args='--cflags --libs', uselib_store='GTK', mandatory=True)
# OSX
if conf.env.TARGET_OSX:
#
# Dependencies.
- # There's probably a neater way of expressing these, but I've gone for brute force for now.
#
- if conf.env.TARGET_DEBIAN:
- conf.check_cfg(package='libcxml', atleast_version='0.11', args='--cflags', uselib_store='CXML', mandatory=True)
- conf.env.STLIB_CXML = ['cxml']
- conf.check_cfg(package='libxml++-2.6', args='--cflags --libs', uselib_store='XMLPP', mandatory=True)
- conf.check_cfg(package='libcurl', args='--cflags --libs', uselib_store='CURL', mandatory=True)
- static_ffmpeg(conf)
- static_openjpeg(conf)
- static_sub(conf)
- static_dcp(conf, False, False, False, False)
- dynamic_boost(conf, boost_lib_suffix, boost_thread)
-
- if conf.env.TARGET_CENTOS_6:
- # Centos 6.5's boost is too old, so we build a new version statically in the chroot
- conf.check_cfg(package='libcxml', atleast_version='0.08', args='--cflags --libs-only-L', uselib_store='CXML', mandatory=True)
- conf.env.STLIB_CXML = ['cxml', 'boost_filesystem']
- conf.check_cfg(package='libcurl', args='--cflags --libs-only-L', uselib_store='CURL', mandatory=True)
+ # It should be possible to use check_cfg for both dynamic and static linking, but
+ # e.g. pkg-config --libs --static foo returns some libraries that should be statically
+ # linked and others that should be dynamic. This doesn't work too well with waf
+ # as it wants them separate.
+
+ # libcurl
+ if conf.options.static_curl:
conf.env.STLIB_CURL = ['curl']
conf.env.LIB_CURL = ['ssh2', 'idn']
- static_ffmpeg(conf)
- static_openjpeg(conf)
- static_sub(conf)
- static_dcp(conf, True, True, True, True)
- static_boost(conf, boost_lib_suffix)
-
- if conf.env.TARGET_CENTOS_7:
- # Centos 7's boost is ok so we link it dynamically
- conf.check_cfg(package='libcxml', atleast_version='0.08', args='--cflags', uselib_store='CXML', mandatory=True)
- conf.env.STLIB_CXML = ['cxml']
+ else:
conf.check_cfg(package='libcurl', args='--cflags --libs', uselib_store='CURL', mandatory=True)
- conf.env.LIB_SSH = ['gssapi_krb5']
- conf.env.LIB_XMLPP = ['xml2']
- conf.env.LIB_XMLSEC = ['ltdl']
- static_ffmpeg(conf)
- static_openjpeg(conf)
- static_sub(conf)
- static_dcp(conf, False, True, True, True)
- dynamic_boost(conf, boost_lib_suffix, boost_thread)
- if conf.env.TARGET_WINDOWS:
- conf.check_cfg(package='libxml++-2.6', args='--cflags --libs', uselib_store='XMLPP', mandatory=True)
- conf.check_cfg(package='libcurl', args='--cflags --libs', uselib_store='CURL', mandatory=True)
- conf.check_cxx(fragment="""
- #include <boost/locale.hpp>\n
- int main() { std::locale::global (boost::locale::generator().generate ("")); }\n
- """, msg='Checking for boost locale library',
- libpath='/usr/local/lib',
- lib=['boost_locale%s' % boost_lib_suffix, 'boost_system%s' % boost_lib_suffix],
- uselib_store='BOOST_LOCALE')
- dynamic_boost(conf, boost_lib_suffix, boost_thread)
- dynamic_ffmpeg(conf)
- dynamic_openjpeg(conf)
- dynamic_dcp(conf)
- dynamic_sub(conf)
- dynamic_ssh(conf)
-
- # Not packaging; just a straight build
- if not conf.env.TARGET_WINDOWS and not conf.env.TARGET_DEBIAN and not conf.env.TARGET_CENTOS_6 and not conf.env.TARGET_CENTOS_7:
- conf.check_cfg(package='libcxml', atleast_version='0.08', args='--cflags --libs', uselib_store='CXML', mandatory=True)
- conf.check_cfg(package='libxml++-2.6', args='--cflags --libs', uselib_store='XMLPP', mandatory=True)
- conf.check_cfg(package='libcurl', args='--cflags --libs', uselib_store='CURL', mandatory=True)
- dynamic_boost(conf, boost_lib_suffix, boost_thread)
- dynamic_ffmpeg(conf)
- dynamic_dcp(conf)
- dynamic_sub(conf)
- dynamic_openjpeg(conf)
- dynamic_ssh(conf)
-
- # Dependencies which are always dynamically linked
+
+ # libsndfile
conf.check_cfg(package='sndfile', args='--cflags --libs', uselib_store='SNDFILE', mandatory=True)
+
+ # glib
conf.check_cfg(package='glib-2.0', args='--cflags --libs', uselib_store='GLIB', mandatory=True)
- if distutils.spawn.find_executable(conf.options.magickpp_config):
- conf.check_cfg(package='', path=conf.options.magickpp_config, args='--cppflags --cxxflags --libs', uselib_store='MAGICK', mandatory=True)
+
+ # ImageMagick / GraphicsMagick
+ if distutils.spawn.find_executable('Magick++-config'):
+ conf.check_cfg(package='', path='Magick++-config', args='--cppflags --cxxflags --libs', uselib_store='MAGICK', mandatory=True)
conf.env.append_value('CXXFLAGS', '-DDCPOMATIC_IMAGE_MAGICK')
else:
- conf.check_cfg(package='GraphicsMagick++', args='--cflags --libs', uselib_store='MAGICK', mandatory=True)
- conf.env.append_value('CXXFLAGS', '-DDCPOMATIC_GRAPHICS_MAGICK')
-
+ image = conf.check_cfg(package='ImageMagick++', args='--cflags --libs', uselib_store='MAGICK', mandatory=False)
+ graphics = conf.check_cfg(package='GraphicsMagick++', args='--cflags --libs', uselib_store='MAGICK', mandatory=False)
+ if image is None and graphics is None:
+ Logs.pprint('RED', 'Neither ImageMagick++ nor GraphicsMagick++ found: one or the other is required')
+ if image is not None:
+ conf.env.append_value('CXXFLAGS', '-DDCPOMATIC_IMAGE_MAGICK')
+ if graphics is not None:
+ conf.env.append_value('CXXFLAGS', '-DDCPOMATIC_GRAPHICS_MAGICK')
+
+ # libzip
conf.check_cfg(package='libzip', args='--cflags --libs', uselib_store='ZIP', mandatory=True)
+
+ # pangomm
conf.check_cfg(package='pangomm-1.4', args='--cflags --libs', uselib_store='PANGOMM', mandatory=True)
+
+ # cairomm
conf.check_cfg(package='cairomm-1.0', args='--cflags --libs', uselib_store='CAIROMM', mandatory=True)
- conf.check_cc(fragment="""
- #include <glib.h>
- int main() { g_format_size (1); }
- """, msg='Checking for g_format_size ()',
- uselib='GLIB',
- define_name='HAVE_G_FORMAT_SIZE',
- mandatory=False)
+ # libcxml
+ if conf.options.static_cxml:
+ conf.check_cfg(package='libcxml', atleast_version='0.08', args='--cflags', uselib_store='CXML', mandatory=True)
+ conf.env.STLIB_CXML = ['cxml']
+ else:
+ conf.check_cfg(package='libcxml', atleast_version='0.08', args='--cflags --libs', uselib_store='CXML', mandatory=True)
+
+ # libssh
+ if conf.options.static_ssh:
+ conf.env.STLIB_SSH = ['ssh']
+ if conf.options.workaround_gssapi:
+ conf.env.LIB_SSH = ['gssapi_krb5']
+ else:
+ conf.check_cc(fragment="""
+ #include <libssh/libssh.h>\n
+ int main () {\n
+ ssh_session s = ssh_new ();\n
+ return 0;\n
+ }
+ """,
+ msg='Checking for library libssh',
+ mandatory=True,
+ lib='ssh',
+ uselib_store='SSH')
+
+ # libdcp
+ if conf.options.static_dcp:
+ conf.check_cfg(package='libdcp-1.0', atleast_version='1.1.0', args='--cflags', uselib_store='DCP', mandatory=True)
+ conf.env.DEFINES_DCP = [f.replace('\\', '') for f in conf.env.DEFINES_DCP]
+ conf.env.STLIB_DCP = ['dcp-1.0', 'asdcp-libdcp-1.0', 'kumu-libdcp-1.0']
+ conf.env.LIB_DCP = ['glibmm-2.4', 'ssl', 'crypto', 'bz2', 'xslt']
+ else:
+ conf.check_cfg(package='libdcp-1.0', atleast_version='1.1.0', args='--cflags --libs', uselib_store='DCP', mandatory=True)
+ conf.env.DEFINES_DCP = [f.replace('\\', '') for f in conf.env.DEFINES_DCP]
+
+ # libsub
+ if conf.options.static_sub:
+ conf.check_cfg(package='libsub-1.0', atleast_version='1.1.0', args='--cflags', uselib_store='SUB', mandatory=True)
+ conf.env.DEFINES_SUB = [f.replace('\\', '') for f in conf.env.DEFINES_SUB]
+ conf.env.STLIB_SUB = ['sub-1.0']
+ else:
+ conf.check_cfg(package='libsub-1.0', atleast_version='1.1.0', args='--cflags --libs', uselib_store='SUB', mandatory=True)
+ conf.env.DEFINES_SUB = [f.replace('\\', '') for f in conf.env.DEFINES_SUB]
+
+ # libxml++
+ if conf.options.static_xmlpp:
+ conf.env.STLIB_XMLPP = ['xml++-2.6']
+ else:
+ conf.check_cfg(package='libxml++-2.6', args='--cflags --libs', uselib_store='XMLPP', mandatory=True)
+
+ # libxmlsec
+ if conf.options.static_xmlsec:
+ conf.env.STLIB_XMLSEC = ['xmlsec1-openssl', 'xmlsec1']
+ else:
+ conf.env.LIB_XMLSEC = ['xmlsec1-openssl', 'xmlsec1']
+
+ # OpenJPEG
+ if conf.options.static_openjpeg:
+ conf.check_cfg(package='libopenjpeg', args='--cflags', atleast_version='1.5.0', uselib_store='OPENJPEG', mandatory=True)
+ conf.check_cfg(package='libopenjpeg', args='--cflags', max_version='1.5.2', mandatory=True)
+ conf.env.STLIB_OPENJPEG = ['openjpeg']
+ else:
+ conf.check_cfg(package='libopenjpeg', args='--cflags --libs', atleast_version='1.5.0', uselib_store='OPENJPEG', mandatory=True)
+ conf.check_cfg(package='libopenjpeg', args='--cflags --libs', max_version='1.5.2', mandatory=True)
+
+ # FFmpeg
+ if conf.options.static_ffmpeg:
+ names = ['avformat', 'avfilter', 'avcodec', 'avutil', 'swscale', 'swresample', 'postproc']
+ for name in names:
+ static = subprocess.Popen(shlex.split('pkg-config --static --libs lib%s' % name), stdout=subprocess.PIPE).communicate()[0]
+ libs = []
+ stlibs = []
+ include = []
+ libpath = []
+ for s in static.split():
+ if s.startswith('-L'):
+ libpath.append(s[2:])
+ elif s.startswith('-I'):
+ include.append(s[2:])
+ elif s.startswith('-l'):
+ if s[2:] not in names:
+ libs.append(s[2:])
+ else:
+ stlibs.append(s[2:])
+
+ conf.env['LIB_%s' % name.upper()] = libs
+ conf.env['STLIB_%s' % name.upper()] = stlibs
+ conf.env['INCLUDE_%s' % name.upper()] = include
+ conf.env['LIBPATH_%s' % name.upper()] = libpath
+ else:
+ conf.check_cfg(package='libavformat', args='--cflags --libs', uselib_store='AVFORMAT', mandatory=True)
+ conf.check_cfg(package='libavfilter', args='--cflags --libs', uselib_store='AVFILTER', mandatory=True)
+ conf.check_cfg(package='libavcodec', args='--cflags --libs', uselib_store='AVCODEC', mandatory=True)
+ conf.check_cfg(package='libavutil', args='--cflags --libs', uselib_store='AVUTIL', mandatory=True)
+ conf.check_cfg(package='libswscale', args='--cflags --libs', uselib_store='SWSCALE', mandatory=True)
+ conf.check_cfg(package='libswresample', args='--cflags --libs', uselib_store='SWRESAMPLE', mandatory=True)
+ conf.check_cfg(package='libpostproc', args='--cflags --libs', uselib_store='POSTPROC', mandatory=True)
+
+ # Boost
+ if conf.options.static_boost:
+ conf.env.STLIB_BOOST_THREAD = ['boost_thread']
+ conf.env.STLIB_BOOST_FILESYSTEM = ['boost_filesystem%s' % boost_lib_suffix]
+ conf.env.STLIB_BOOST_DATETIME = ['boost_date_time%s' % boost_lib_suffix, 'boost_system%s' % boost_lib_suffix]
+ conf.env.STLIB_BOOST_SIGNALS2 = ['boost_signals2']
+ conf.env.STLIB_BOOST_SYSTEM = ['boost_system']
+ conf.env.STLIB_BOOST_REGEX = ['boost_regex']
+ else:
+ conf.check_cxx(fragment="""
+ #include <boost/version.hpp>\n
+ #if BOOST_VERSION < 104500\n
+ #error boost too old\n
+ #endif\n
+ int main(void) { return 0; }\n
+ """,
+ mandatory=True,
+ msg='Checking for boost library >= 1.45',
+ okmsg='yes',
+ errmsg='too old\nPlease install boost version 1.45 or higher.')
+
+ conf.check_cxx(fragment="""
+ #include <boost/thread.hpp>\n
+ int main() { boost::thread t (); }\n
+ """,
+ msg='Checking for boost threading library',
+ libpath='/usr/local/lib',
+ lib=[boost_thread, 'boost_system%s' % boost_lib_suffix],
+ uselib_store='BOOST_THREAD')
+
+ conf.check_cxx(fragment="""
+ #include <boost/filesystem.hpp>\n
+ int main() { boost::filesystem::copy_file ("a", "b"); }\n
+ """,
+ msg='Checking for boost filesystem library',
+ libpath='/usr/local/lib',
+ lib=['boost_filesystem%s' % boost_lib_suffix, 'boost_system%s' % boost_lib_suffix],
+ uselib_store='BOOST_FILESYSTEM')
+
+ conf.check_cxx(fragment="""
+ #include <boost/date_time.hpp>\n
+ int main() { boost::gregorian::day_clock::local_day(); }\n
+ """,
+ msg='Checking for boost datetime library',
+ libpath='/usr/local/lib',
+ lib=['boost_date_time%s' % boost_lib_suffix, 'boost_system%s' % boost_lib_suffix],
+ uselib_store='BOOST_DATETIME')
+
+ conf.check_cxx(fragment="""
+ #include <boost/signals2.hpp>\n
+ int main() { boost::signals2::signal<void (int)> x; }\n
+ """,
+ msg='Checking for boost signals2 library',
+ uselib_store='BOOST_SIGNALS2')
+
+ conf.check_cxx(fragment="""
+ #include <boost/regex.hpp>\n
+ int main() { boost::regex re ("foo"); }\n
+ """,
+ msg='Checking for boost regex library',
+ lib=['boost_regex%s' % boost_lib_suffix],
+ uselib_store='BOOST_REGEX')
+
+ # Other stuff
conf.find_program('msgfmt', var='MSGFMT')
-
+
datadir = conf.env.DATADIR
if not datadir:
datadir = os.path.join(conf.env.PREFIX, 'share')
-
+
conf.define('LOCALEDIR', os.path.join(datadir, 'locale'))
conf.define('DATADIR', datadir)
if not conf.env.DISABLE_TESTS:
conf.recurse('test')
+ Logs.pprint('YELLOW', '')
+ if conf.env.TARGET_WINDOWS:
+ Logs.pprint('YELLOW', '\t' + 'Target'.ljust(25) + ': Windows')
+ elif conf.env.TARGET_LINUX:
+ Logs.pprint('YELLOW', '\t' + 'Target'.ljust(25) + ': Linux')
+ elif conf.env.TARGET_OSX:
+ Logs.pprint('YELLOW', '\t' + 'Target'.ljust(25) + ': OS X')
+
+ def report(name, variable):
+ linkage = ''
+ if variable:
+ linkage = 'static'
+ else:
+ linkage = 'dynamic'
+ Logs.pprint('YELLOW', '\t%s: %s' % (name.ljust(25), linkage))
+
+ report('DCP-o-matic libraries', conf.options.static_dcpomatic)
+ report('Boost', conf.options.static_boost)
+ report('OpenJPEG', conf.options.static_openjpeg)
+ report('wxWidgets', conf.options.static_wxwidgets)
+ report('FFmpeg', conf.options.static_ffmpeg)
+ report('libxml++', conf.options.static_xmlpp)
+ report('xmlsec', conf.options.static_xmlsec)
+ report('libssh', conf.options.static_ssh)
+ report('libcxml', conf.options.static_cxml)
+ report('libdcp', conf.options.static_dcp)
+ report('libcurl', conf.options.static_curl)
+
+ Logs.pprint('YELLOW', '')
+
def build(bld):
create_version_cc(VERSION, bld.env.CXXFLAGS)
if not bld.env.TARGET_WINDOWS:
bld.install_files('${PREFIX}/share/dcpomatic2', 'icons/taskbar_icon.png')
+ bld.install_files('${PREFIX}/share/dcpomatic2', 'LiberationSans-Regular.ttf')
bld.add_post_fun(post)
GRSYMS GRTAGS GSYMS GTAGS
"""
-
def create_version_cc(version, cxx_flags):
commit = git_revision()
if commit is None and os.path.exists('.git_revision'):
f = open('.git_revision', 'r')
commit = f.readline().strip()
-
+
if commit is None:
commit = 'release'
except IOError:
print('Could not open src/lib/version.cc for writing\n')
sys.exit(-1)
-
+
def post(ctx):
if ctx.cmd == 'install':
ctx.exec_command('/sbin/ldconfig')
bld.recurse('src')
def tags(bld):
- os.system('etags src/lib/*.cc src/lib/*.h src/wx/*.cc src/wx/*.h src/tools/*.cc src/tools/*.h test/*.cc')
+ os.system('etags src/lib/*.cc src/lib/*.h src/wx/*.cc src/wx/*.h src/tools/*.cc src/tools/*.h')
+
+def zanata_pull(bld):
+ os.system('zanata-cli -B -q pull -t .')
+ for f in glob.glob('src/lib/po/*.po'):
+ l = os.path.basename(f)
+ os.rename('dcpomatic_%s' % l, 'src/tools/po/%s' % l)
+ os.rename('libdcpomatic_%s' % l, 'src/lib/po/%s' % l)
+ os.rename('libdcpomatic-wx_%s' % l, 'src/wx/po/%s' % l)
+
+def cppcheck(bld):
+ os.system('cppcheck --enable=all --quiet .')