X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=wscript;h=48f189073772ef10179a2e38cc4fd1a48fc943b4;hb=4f7385a149361a9fd174c4ad8af7f8666864aff6;hp=c2db55e7eb2cbeb860e75ccc64858915f8119577;hpb=29166b5a777134922e8ed1bcaec7124b2b16b6d0;p=dcpomatic.git diff --git a/wscript b/wscript index c2db55e7e..48f189073 100644 --- a/wscript +++ b/wscript @@ -1,56 +1,67 @@ import subprocess import os +import sys APPNAME = 'dvdomatic' -VERSION = '0.30pre' +VERSION = '0.43pre' def options(opt): opt.load('compiler_cxx') + opt.load('winres') + opt.add_option('--debug-hash', action='store_true', default = False, help = 'print hashes of data at various points') 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-player', action='store_true', default = False, help = 'disable building of the player components') - opt.add_option('--ffmpeg-083', action='store_true', default = False, help = 'Use FFmpeg version in Ubuntu 12.04') opt.add_option('--target-windows', action='store_true', default = False, help = 'set up to do a cross-compile to Windows') def configure(conf): conf.load('compiler_cxx') + if conf.options.target_windows: + conf.load('winres') conf.env.append_value('CXXFLAGS', ['-D__STDC_CONSTANT_MACROS', '-msse', '-mfpmath=sse', '-ffast-math', '-fno-strict-aliasing', '-Wall', '-Wno-attributes']) conf.env.append_value('CXXFLAGS', ['-DDVDOMATIC_VERSION="%s"' % VERSION]) + # Turn off player for now + conf.options.disable_player = True + if conf.options.target_windows: - conf.env.append_value('CXXFLAGS', '-DDVDOMATIC_WINDOWS') + conf.env.append_value('CXXFLAGS', ['-DDVDOMATIC_WINDOWS', '-DWIN32_LEAN_AND_MEAN']) conf.options.disable_player = True conf.check(lib = 'ws2_32', uselib_store = 'WINSOCK2', msg = "Checking for library winsock2") + boost_lib_suffix = '-mt' + boost_thread = 'boost_thread_win32-mt' else: conf.env.append_value('CXXFLAGS', '-DDVDOMATIC_POSIX') + boost_lib_suffix = '' + boost_thread = 'boost_thread' conf.env.DEBUG_HASH = conf.options.debug_hash conf.env.TARGET_WINDOWS = conf.options.target_windows conf.env.DISABLE_GUI = conf.options.disable_gui conf.env.DISABLE_PLAYER = conf.options.disable_player + conf.env.VERSION = VERSION if conf.options.disable_player: conf.env.append_value('CXXFLAGS', '-DDVDOMATIC_DISABLE_PLAYER') if conf.options.enable_debug: - conf.env.append_value('CXXFLAGS', '-g') + conf.env.append_value('CXXFLAGS', ['-g', '-DDVDOMATIC_DEBUG']) else: conf.env.append_value('CXXFLAGS', '-O3') - if conf.options.ffmpeg_083: - conf.env.append_value('CXXFLAGS', '-DDVDOMATIC_FFMPEG_0_8_3') - conf.check_cfg(package = 'sigc++-2.0', args = '--cflags --libs', uselib_store = 'SIGC++', mandatory = True) 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) conf.check_cfg(package = 'sndfile', args = '--cflags --libs', uselib_store = 'SNDFILE', mandatory = True) - conf.check_cfg(package = 'libdcp', args = '--cflags --libs', uselib_store = 'DCP', mandatory = True) + conf.check_cfg(package = 'libdcp', atleast_version = '0.07', args = '--cflags --libs', uselib_store = 'DCP', mandatory = True) + conf.check_cfg(package = 'glib-2.0', args = '--cflags --libs', uselib_store = 'GLIB', mandatory = True) conf.check_cfg(package = '', path = 'Magick++-config', args = '--cppflags --cxxflags --libs', uselib_store = 'MAGICK', mandatory = True) conf.check_cc(msg = 'Checking for library libtiff', function_name = 'TIFFOpen', header_name = 'tiffio.h', lib = 'tiff', uselib_store = 'TIFF') conf.check_cc(fragment = """ @@ -69,23 +80,27 @@ def configure(conf): return 0;\n } """, msg = 'Checking for library libssh', mandatory = False, lib = 'ssh', uselib_store = 'SSH') - + conf.check_cxx(fragment = """ #include \n int main() { boost::thread t (); }\n """, msg = 'Checking for boost threading library', - lib = ['boost_thread_win32-mt', 'boost_system-mt'], uselib_store = 'BOOST_THREAD') + lib = [boost_thread, 'boost_system%s' % boost_lib_suffix], + uselib_store = 'BOOST_THREAD') + conf.check_cxx(fragment = """ #include \n int main() { boost::filesystem::copy_file ("a", "b"); }\n """, msg = 'Checking for boost filesystem library', - libpath = '/usr/local/lib', lib = ['boost_filesystem-mt', 'boost_system-mt'], uselib_store = 'BOOST_FILESYSTEM') + libpath = '/usr/local/lib', + lib = ['boost_filesystem%s' % boost_lib_suffix, 'boost_system%s' % boost_lib_suffix], + uselib_store = 'BOOST_FILESYSTEM') conf.check_cc(fragment = """ #include int main() { g_format_size (1); } """, msg = 'Checking for g_format_size ()', - lib = 'glib', + uselib = 'GLIB', define_name = 'HAVE_G_FORMAT_SIZE', mandatory = False) @@ -97,6 +112,8 @@ def build(bld): bld.recurse('src') bld.recurse('test') + if bld.env.TARGET_WINDOWS: + bld.recurse('windows') d = { 'PREFIX' : '${PREFIX' } @@ -110,7 +127,7 @@ def build(bld): bld.install_files('${PREFIX}/share/icons/hicolor/%s/apps' % r, 'icons/%s/dvdomatic.png' % r) def dist(ctx): - ctx.excl = 'TODO core *~ src/gtk/*~ src/lib/*~ .waf* build .git' + ctx.excl = 'TODO core *~ src/wx/*~ src/lib/*~ .waf* build .git deps alignment hacks sync *.tar.bz2 *.exe .lock* *build-windows doc/manual/pdf doc/manual/html' def create_version_cc(version): if os.path.exists('.git'): @@ -132,3 +149,4 @@ def create_version_cc(version): except IOError: print('Could not open src/lib/version.cc for writing\n') sys.exit(-1) +