X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=wscript;h=4604b1d4bf3f6cbe1077ceaecc8463303a5cbd7b;hb=b087721d8aaf9470833414d01a72d826162946ab;hp=237c077868df90d8ee99448738cd870219fa0642;hpb=d2b796bf081e7bb5883c5ed2c137ff9100ab9bd5;p=ardour.git diff --git a/wscript b/wscript index 237c077868..4604b1d4bf 100644 --- a/wscript +++ b/wscript @@ -1,20 +1,19 @@ #!/usr/bin/env python -import autowaf -import Options +from waflib.extras import autowaf as autowaf +from waflib import Options import os import re import string import subprocess import sys -import glob # Variables for 'waf dist' -VERSION = '3.0alpha10' -APPNAME = 'Ardour' +VERSION = '3.0beta2' +APPNAME = 'Ardour3' # Mandatory variables -srcdir = '.' -blddir = 'build' +top = '.' +out = 'build' children = [ 'libs/pbd', @@ -32,13 +31,11 @@ children = [ 'libs/gtkmm2ext', 'libs/clearlooks-newer', 'libs/audiographer', - 'libs/gnomecanvas', 'gtk2_ardour', 'templates', 'export', -# this needs to be conditional at some point, since -# we will not build it or use it on OS X - 'tools/sanity_check' + 'midi_maps', + 'manual' ] i18n_children = [ @@ -47,6 +44,13 @@ i18n_children = [ 'libs/gtkmm2ext', ] +if sys.platform != 'darwin': + children += [ 'tools/sanity_check' ] + lxvst_default = True +else: + children += [ 'libs/appleutility' ] + lxvst_default = False + # Version stuff def fetch_svn_revision (path): @@ -139,22 +143,22 @@ def set_compiler_flags (conf,opt): if config[config_arch] == 'apple': # The [.] matches to the dot after the major version, "." would match any character if re.search ("darwin[0-7][.]", config[config_kernel]) != None: - conf.define ('build_target', 'panther') + conf.env['build_target'] = 'panther' elif re.search ("darwin8[.]", config[config_kernel]) != None: - conf.define ('build_target', 'tiger') + conf.env['build_target'] = 'tiger' else: - conf.define ('build_target', 'leopard') + conf.env['build_target'] = 'leopard' else: if re.search ("x86_64", config[config_cpu]) != None: - conf.define ('build_target', 'x86_64') + conf.env['build_target'] = 'x86_64' elif re.search("i[0-5]86", config[config_cpu]) != None: - conf.define ('build_target', 'i386') + conf.env['build_target'] = 'i386' elif re.search("powerpc", config[config_cpu]) != None: - conf.define ('build_target', 'powerpc') + conf.env['build_target'] = 'powerpc' else: - conf.define ('build_target', 'i686') + conf.env['build_target'] = 'i686' else: - conf.define ('build_target', opt.dist_target) + conf.env['build_target'] = opt.dist_target if config[config_cpu] == 'powerpc' and conf.env['build_target'] != 'none': # @@ -179,7 +183,8 @@ def set_compiler_flags (conf,opt): # # ARCH_X86 means anything in the x86 family from i386 to x86_64 - # USE_X86_64_ASM is used to distingush 32 and 64 bit assembler + # the compile-time presence of the macro _LP64 is used to + # distingush 32 and 64 bit assembler # if (re.search ("(i[0-9]86|x86_64)", config[config_cpu]) != None): @@ -224,15 +229,13 @@ def set_compiler_flags (conf,opt): elif conf.env['build_target'] == 'i686' or conf.env['build_target'] == 'x86_64': optimization_flags.append ("-DBUILD_SSE_OPTIMIZATIONS") debug_flags.append ("-DBUILD_SSE_OPTIMIZATIONS") - elif conf.env['build_target'] == 'x86_64': - optimization_flags.append ("-DUSE_X86_64_ASM") - debug_flags.append ("-DUSE_X86_64_ASM") if not build_host_supports_sse: print("\nWarning: you are building Ardour with SSE support even though your system does not support these instructions. (This may not be an error, especially if you are a package maintainer)") # check this even if we aren't using FPU optimization - if not conf.env['HAVE_POSIX_MEMALIGN']: + if not conf.is_defined('HAVE_POSIX_MEMALIGN'): optimization_flags.append("-DNO_POSIX_MEMALIGN") + debug_flags.append("-DNO_POSIX_MEMALIGN") # end optimization section @@ -240,13 +243,19 @@ def set_compiler_flags (conf,opt): # no VST on x86_64 # - if conf.env['build_target'] == 'x86_64' and opt.vst: + if conf.env['build_target'] == 'x86_64' and opt.windows_vst: print("\n\n==================================================") - print("You cannot use VST plugins with a 64 bit host. Please run waf with --vst=0") + print("You cannot use VST plugins with a 64 bit host. Please run waf with --windows-vst=0") print("\nIt is theoretically possible to build a 32 bit host on a 64 bit system.") print("However, this is tricky and not recommended for beginners.") sys.exit (-1) + if opt.lxvst: + if conf.env['build_target'] == 'x86_64': + conf.env.append_value('CXXFLAGS', "-DLXVST_64BIT") + else: + conf.env.append_value('CXXFLAGS', "-DLXVST_32BIT") + # # a single way to test if we're on OS X # @@ -255,7 +264,7 @@ def set_compiler_flags (conf,opt): conf.define ('IS_OSX', 1) # force tiger or later, to avoid issues on PPC which defaults # back to 10.1 if we don't tell it otherwise. - conf.env.append_value('CCFLAGS', "-DMAC_OS_X_VERSION_MIN_REQUIRED=1040") + conf.env.append_value('CFLAGS', "-DMAC_OS_X_VERSION_MIN_REQUIRED=1040") else: conf.define ('IS_OSX', 0) @@ -285,11 +294,11 @@ def set_compiler_flags (conf,opt): ] if opt.debug: - conf.env.append_value('CCFLAGS', debug_flags) + conf.env.append_value('CFLAGS', debug_flags) conf.env.append_value('CXXFLAGS', debug_flags) conf.env.append_value('LINKFLAGS', debug_flags) else: - conf.env.append_value('CCFLAGS', optimization_flags) + conf.env.append_value('CFLAGS', optimization_flags) conf.env.append_value('CXXFLAGS', optimization_flags) conf.env.append_value('LINKFLAGS', optimization_flags) @@ -297,34 +306,38 @@ def set_compiler_flags (conf,opt): conf.env.append_value('CXXFLAGS', "-D_GLIBCXX_DEBUG") if conf.env['DEBUG_RT_ALLOC']: - conf.env.append_value('CCFLAGS', '-DDEBUG_RT_ALLOC') + conf.env.append_value('CFLAGS', '-DDEBUG_RT_ALLOC') conf.env.append_value('CXXFLAGS', '-DDEBUG_RT_ALLOC') conf.env.append_value('LINKFLAGS', '-ldl') + if conf.env['DEBUG_DENORMAL_EXCEPTION']: + conf.env.append_value('CFLAGS', '-DDEBUG_DENORMAL_EXCEPTION') + conf.env.append_value('CXXFLAGS', '-DDEBUG_DENORMAL_EXCEPTION') + if opt.universal: - conf.env.append_value('CCFLAGS', "-arch i386 -arch ppc") - conf.env.append_value('CXXFLAGS', "-arch i386 -arch ppc") - conf.env.append_value('LINKFLAGS', "-arch i386 -arch ppc") + if not Options.options.nocarbon: + conf.env.append_value('CFLAGS', ["-arch", "i386", "-arch", "ppc"]) + conf.env.append_value('CXXFLAGS', ["-arch", "i386", "-arch", "ppc"]) + conf.env.append_value('LINKFLAGS', ["-arch", "i386", "-arch", "ppc"]) + else: + conf.env.append_value('CFLAGS', ["-arch", "x86_64", "-arch", "i386", "-arch", "ppc"]) + conf.env.append_value('CXXFLAGS', ["-arch", "x86_64", "-arch", "i386", "-arch", "ppc"]) + conf.env.append_value('LINKFLAGS', ["-arch", "x86_64", "-arch", "i386", "-arch", "ppc"]) # # warnings flags # - conf.env.append_value('CCFLAGS', "-Wall") + conf.env.append_value('CFLAGS', "-Wall") conf.env.append_value('CXXFLAGS', [ '-Wall', '-Woverloaded-virtual']) - if opt.extra_warn: - flags = [ '-Wextra' ] - conf.env.append_value('CCFLAGS', flags ) - conf.env.append_value('CXXFLAGS', flags ) - # # more boilerplate # - conf.env.append_value('CCFLAGS', '-D_LARGEFILE64_SOURCE') - conf.env.append_value('CCFLAGS', '-D_FILE_OFFSET_BITS=64') + conf.env.append_value('CFLAGS', '-D_LARGEFILE64_SOURCE') + conf.env.append_value('CFLAGS', '-D_FILE_OFFSET_BITS=64') conf.env.append_value('CXXFLAGS', '-D_LARGEFILE64_SOURCE') conf.env.append_value('CXXFLAGS', '-D_FILE_OFFSET_BITS=64') @@ -333,43 +346,55 @@ def set_compiler_flags (conf,opt): if opt.nls: conf.env.append_value('CXXFLAGS', '-DENABLE_NLS') - conf.env.append_value('CCFLAGS', '-DENABLE_NLS') + conf.env.append_value('CFLAGS', '-DENABLE_NLS') #---------------------------------------------------------------- # Waf stages -def set_options(opt): - autowaf.set_options(opt) +def options(opt): + opt.load('compiler_c') + opt.load('compiler_cxx') + autowaf.set_options(opt, debug_by_default=True) opt.add_option('--program-name', type='string', action='store', default='Ardour', dest='program_name', help='The user-visible name of the program being built') opt.add_option('--arch', type='string', action='store', dest='arch', help='Architecture-specific compiler flags') + opt.add_option('--no-carbon', action='store_true', default=False, dest='nocarbon', + help='Compile without support for AU Plugins with only CARBON UI (needed for 64bit)') opt.add_option('--boost-sp-debug', action='store_true', default=False, dest='boost_sp_debug', help='Compile with Boost shared pointer debugging') opt.add_option('--dist-target', type='string', default='auto', dest='dist_target', help='Specify the target for cross-compiling [auto,none,x86,i386,i686,x86_64,powerpc,tiger,leopard]') - opt.add_option('--extra-warn', action='store_true', default=False, dest='extra_warn', - help='Build with even more compiler warning flags') opt.add_option('--fpu-optimization', action='store_true', default=True, dest='fpu_optimization', help='Build runtime checked assembler code (default)') opt.add_option('--no-fpu-optimization', action='store_false', dest='fpu_optimization') opt.add_option('--freedesktop', action='store_true', default=False, dest='freedesktop', help='Install MIME type, icons and .desktop file as per freedesktop.org standards') - opt.add_option('--freesound', action='store_true', default=False, dest='freesound', - help='Include Freesound database lookup') + opt.add_option('--freebie', action='store_true', default=False, dest='freebie', + help='Build a version suitable for distribution as a zero-cost binary') + opt.add_option('--no-freesound', action='store_false', default=True, dest='freesound', + help='Do not build with Freesound database support') opt.add_option('--gprofile', action='store_true', default=False, dest='gprofile', help='Compile for use with gprofile') - opt.add_option('--lv2', action='store_true', default=False, dest='lv2', - help='Compile with support for LV2 (if SLV2 or Lilv+Suil is available)') + opt.add_option('--lv2', action='store_true', default=True, dest='lv2', + help='Compile with support for LV2 (if Lilv+Suil is available)') + opt.add_option('--no-lv2', action='store_false', dest='lv2', + help='Do not compile with support for LV2') + opt.add_option('--lxvst', action='store_true', default=lxvst_default, dest='lxvst', + help='Compile with support for linuxVST plugins') opt.add_option('--nls', action='store_true', default=True, dest='nls', help='Enable i18n (native language support) (default)') opt.add_option('--no-nls', action='store_false', dest='nls') - opt.add_option('--phone-home', action='store_false', default=True, dest='phone_home') + opt.add_option('--phone-home', action='store_false', default=False, dest='phone_home') opt.add_option('--stl-debug', action='store_true', default=False, dest='stl_debug', help='Build with debugging for the STL') opt.add_option('--rt-alloc-debug', action='store_true', default=False, dest='rt_alloc_debug', help='Build with debugging for memory allocation in the real-time thread') + opt.add_option('--pt-timing', action='store_true', default=False, dest='pt_timing', + help='Build with logging of timing in the process thread(s)') + opt.add_option('--denormal-exception', action='store_true', default=False, dest='denormal_exception', + help='Raise a floating point exception if a denormal is detected') opt.add_option('--test', action='store_true', default=False, dest='build_tests', help="Build unit tests") opt.add_option('--tranzport', action='store_true', default=False, dest='tranzport', @@ -378,8 +403,8 @@ def set_options(opt): help='Compile as universal binary (requires that external libraries are universal)') opt.add_option('--versioned', action='store_true', default=False, dest='versioned', help='Add revision information to executable name inside the build directory') - opt.add_option('--vst', action='store_true', default=False, dest='vst', - help='Compile with support for VST') + opt.add_option('--windows-vst', action='store_true', default=False, dest='windows_vst', + help='Compile with support for Windows VST') opt.add_option('--wiimote', action='store_true', default=False, dest='wiimote', help='Build the wiimote control surface') opt.add_option('--windows-key', type='string', action='store', dest='windows_key', default='Mod4><\'') opt.add_option('--boost-include', type='string', action='store', dest='boost_include', default='', help='directory where Boost header files can be found') + opt.add_option('--also-include', type='string', action='store', dest='also_include', default='', + help='additional include directory where header files can be found') opt.add_option('--wine-include', type='string', action='store', dest='wine_include', default='/usr/include/wine/windows', help='directory where Wine\'s Windows header files can be found') opt.add_option('--noconfirm', action='store_true', default=False, dest='noconfirm', help='Do not ask questions that require confirmation during the build') for i in children: - opt.sub_options(i) + opt.recurse(i) def sub_config_and_use(conf, name, has_objects = True): - conf.sub_config(name) + conf.recurse(name) autowaf.set_local_lib(conf, name, has_objects) def configure(conf): + conf.load('compiler_c') + conf.load('compiler_cxx') if not Options.options.noconfirm: - print ('\n\nThis is an alpha version of Ardour 3.0.\n\n' + + print ('\n\nThis is a beta version of Ardour 3.0.\n\n' + 'You are respectfully requested NOT to ask for assistance with build issues\n' + 'and not to report issues with Ardour 3.0 on the forums at ardour.org.\n\n' + 'Please use IRC, the bug tracker and/or the ardour mailing lists (-dev or -user)\n\n' + @@ -422,9 +451,16 @@ def configure(conf): if sys.platform == 'darwin': - conf.define ('AUDIOUNITS', 1) - conf.define ('AU_STATE_SUPPORT', 1) - conf.define ('COREAUDIO', 1) + # this is required, potentially, for anything we link and then relocate into a bundle + conf.env.append_value('LINKFLAGS', [ '-Xlinker', '-headerpad', '-Xlinker', '2048']) + + conf.define ('HAVE_COREAUDIO', 1) + conf.define ('AUDIOUNIT_SUPPORT', 1) + if not Options.options.nocarbon: + conf.define ('WITH_CARBON', 1) + if not Options.options.freebie: + conf.define ('AU_STATE_SUPPORT', 1) + conf.define ('GTKOSX', 1) conf.define ('TOP_MENUBAR',1) conf.define ('GTKOSX',1) @@ -435,20 +471,20 @@ def configure(conf): # on Darwin to add all applicable flags at once # conf.env.append_value('CXXFLAGS_OSX', '-DMAC_OS_X_VERSION_MIN_REQUIRED=1040') - conf.env.append_value('CCFLAGS_OSX', '-DMAC_OS_X_VERSION_MIN_REQUIRED=1040') + conf.env.append_value('CFLAGS_OSX', '-DMAC_OS_X_VERSION_MIN_REQUIRED=1040') conf.env.append_value('CXXFLAGS_OSX', '-mmacosx-version-min=10.4') - conf.env.append_value('CCFLAGS_OSX', '-mmacosx-version-min=10.4') + conf.env.append_value('CFLAGS_OSX', '-mmacosx-version-min=10.4') #conf.env.append_value('CXXFLAGS_OSX', "-isysroot /Developer/SDKs/MacOSX10.4u.sdk") - #conf.env.append_value('CCFLAGS_OSX', "-isysroot /Developer/SDKs/MacOSX10.4u.sdk") + #conf.env.append_value('CFLAGS_OSX', "-isysroot /Developer/SDKs/MacOSX10.4u.sdk") #conf.env.append_value('LINKFLAGS_OSX', "-isysroot /Developer/SDKs/MacOSX10.4u.sdk") #conf.env.append_value('LINKFLAGS_OSX', "-sysroot /Developer/SDKs/MacOSX10.4u.sdk") conf.env.append_value('CXXFLAGS_OSX', "-msse") - conf.env.append_value('CCFLAGS_OSX', "-msse") + conf.env.append_value('CFLAGS_OSX', "-msse") conf.env.append_value('CXXFLAGS_OSX', "-msse2") - conf.env.append_value('CCFLAGS_OSX', "-msse2") + conf.env.append_value('CFLAGS_OSX', "-msse2") # # TODO: The previous sse flags NEED to be based # off processor type. Need to add in a check @@ -459,30 +495,38 @@ def configure(conf): conf.env.append_value('LINKFLAGS_OSX', ['-framework', 'AppKit']) conf.env.append_value('LINKFLAGS_OSX', ['-framework', 'CoreAudio']) + conf.env.append_value('LINKFLAGS_OSX', ['-framework', 'CoreAudioKit']) conf.env.append_value('LINKFLAGS_OSX', ['-framework', 'CoreFoundation']) conf.env.append_value('LINKFLAGS_OSX', ['-framework', 'CoreServices']) - conf.env.append_value('LINKFLAGS_OSX', ['-undefined', 'suppress' ]) - conf.env.append_value('LINKFLAGS_OSX', '-flat_namespace') + conf.env.append_value('LINKFLAGS_OSX', ['-undefined', 'dynamic_lookup' ]) + conf.env.append_value('LINKFLAGS_OSX', ['-flat_namespace']) - conf.env.append_value('LINKFLAGS_GTKOSX', [ '-Xlinker', '-headerpad']) - conf.env.append_value('LINKFLAGS_GTKOSX', ['-Xlinker', '2048']) - conf.env.append_value('CPPPATH_GTKOSX', "/System/Library/Frameworks/CoreServices.framework/Frameworks/CarbonCore.framework/Headers/") - - conf.env.append_value('CXXFLAGS_AUDIOUNITS', "-DHAVE_AUDIOUNITS") + conf.env.append_value('CXXFLAGS_AUDIOUNITS', "-DAUDIOUNIT_SUPPORT") conf.env.append_value('LINKFLAGS_AUDIOUNITS', ['-framework', 'Audiotoolbox', '-framework', 'AudioUnit']) + conf.env.append_value('LINKFLAGS_AUDIOUNITS', ['-framework', 'Cocoa']) + + if not Options.options.freebie: + conf.env.append_value('CXXFLAGS_AUDIOUNITS', "-DAU_STATE_SUPPORT") + if not Options.options.nocarbon: + conf.env.append_value('CXXFLAGS_AUDIOUNITS', "-DWITH_CARBON") + conf.env.append_value('LINKFLAGS_AUDIOUNITS', ['-framework', 'Carbon']) if Options.options.boost_include != '': - conf.env.append_value('CPPPATH', Options.options.boost_include) + conf.env.append_value('CXXFLAGS', '-I' + Options.options.boost_include) - autowaf.check_header(conf, 'boost/signals2.hpp', mandatory = True) + if Options.options.also_include != '': + conf.env.append_value('CXXFLAGS', '-I' + Options.options.also_include) + conf.env.append_value('CFLAGS', '-I' + Options.options.also_include) + + autowaf.check_header(conf, 'cxx', 'boost/signals2.hpp', mandatory = True) if Options.options.boost_sp_debug: conf.env.append_value('CXXFLAGS', '-DBOOST_SP_ENABLE_DEBUG_HOOKS') - autowaf.check_header(conf, 'jack/session.h', define="JACK_SESSION", mandatory = False) + autowaf.check_header(conf, 'cxx', 'jack/session.h', define="JACK_SESSION", mandatory = False) - conf.check_cc(fragment = "#include \nint main(void) { return (BOOST_VERSION >= 103900 ? 0 : 1); }\n", + conf.check_cxx(fragment = "#include \nint main(void) { return (BOOST_VERSION >= 103900 ? 0 : 1); }\n", execute = "1", mandatory = True, msg = 'Checking for boost library >= 1.39', @@ -494,52 +538,66 @@ def configure(conf): autowaf.check_pkg(conf, 'gthread-2.0', uselib_store='GTHREAD', atleast_version='2.2') autowaf.check_pkg(conf, 'glibmm-2.4', uselib_store='GLIBMM', atleast_version='2.14.0') autowaf.check_pkg(conf, 'sndfile', uselib_store='SNDFILE', atleast_version='1.0.18') + autowaf.check_pkg(conf, 'giomm-2.4', uselib_store='GIOMM', atleast_version='2.2') - if sys.platform == 'darwin': - sub_config_and_use(conf, 'libs/appleutility') for i in children: sub_config_and_use(conf, i) # Fix utterly braindead FLAC include path to not smash assert.h - conf.env['CPPPATH_FLAC'] = [] + conf.env['INCLUDES_FLAC'] = [] conf.check_cc(function_name='dlopen', header_name='dlfcn.h', linkflags='-ldl', uselib_store='DL') conf.check_cc(function_name='curl_global_init', header_name='curl/curl.h', linkflags='-lcurl', uselib_store='CURL') # Tell everyone that this is a waf build - conf.env.append_value('CCFLAGS', '-DWAF_BUILD') + conf.env.append_value('CFLAGS', '-DWAF_BUILD') conf.env.append_value('CXXFLAGS', '-DWAF_BUILD') - # Set up waf environment + # Set up waf environment and C defines opts = Options.options if opts.debug: opts.phone_home = False; # debug builds should not call home if opts.phone_home: conf.env['PHONE_HOME'] = opts.phone_home if opts.fpu_optimization: - conf.define('FPU_OPTIMIZATION', 1) + conf.env['FPU_OPTIMIZATION'] = True if opts.freesound: conf.define('FREESOUND',1) + conf.env['FREESOUND'] = True if opts.nls: - conf.define ('ENABLE_NLS', 1) + conf.define('ENABLE_NLS', 1) + conf.env['ENABLE_NLS'] = True if opts.build_tests: conf.env['BUILD_TESTS'] = opts.build_tests if opts.tranzport: - conf.define('TRANZPORT', 1) - if opts.vst: - conf.define('VST_SUPPORT', 1) - conf.env.append_value('CPPPATH', Options.options.wine_include) - autowaf.check_header(conf, 'windows.h', mandatory = True) + conf.env['TRANZPORT'] = 1 + if opts.windows_vst: + conf.define('WINDOWS_VST_SUPPORT', 1) + conf.env['WINDOWS_VST_SUPPORT'] = True + conf.env.append_value('CFLAGS', '-I' + Options.options.wine_include) + conf.env.append_value('CXXFLAGS', '-I' + Options.options.wine_include) + autowaf.check_header(conf, 'cxx', 'windows.h', mandatory = True) + if opts.lxvst: + conf.define('LXVST_SUPPORT', 1) + conf.env['LXVST_SUPPORT'] = True if bool(conf.env['JACK_SESSION']): - conf.define ('HAVE_JACK_SESSION', 1) + conf.define('HAVE_JACK_SESSION', 1) if opts.wiimote: - conf.define('WIIMOTE',1) + conf.define('WIIMOTE', 1) + conf.env['WIIMOTE'] = True conf.define('WINDOWS_KEY', opts.windows_key) conf.env['PROGRAM_NAME'] = opts.program_name if opts.rt_alloc_debug: conf.define('DEBUG_RT_ALLOC', 1) - if not conf.env['HAVE_CPPUNIT']: + conf.env['DEBUG_RT_ALLOC'] = True + if opts.pt_timing: + conf.define('PT_TIMING', 1) + conf.env['PT_TIMING'] = True + if opts.denormal_exception: + conf.define('DEBUG_DENORMAL_EXCEPTION', 1) + conf.env['DEBUG_DENORMAL_EXCEPTION'] = True + if not conf.is_defined('HAVE_CPPUNIT'): conf.env['BUILD_TESTS'] = False set_compiler_flags (conf, Options.options) @@ -562,31 +620,37 @@ const char* const ardour_config_info = "\\n\\ write_config_text('Strict compiler flags', conf.env['STRICT']) write_config_text('Architecture flags', opts.arch) - write_config_text('Aubio', bool(conf.env['HAVE_AUBIO'])) + write_config_text('Aubio', conf.is_defined('HAVE_AUBIO')) + write_config_text('AudioUnits', conf.is_defined('AUDIOUNIT_SUPPORT')) + write_config_text('AU state support', conf.is_defined('AU_STATE_SUPPORT')) write_config_text('Build target', conf.env['build_target']) - write_config_text('CoreAudio', bool(conf.env['HAVE_COREAUDIO'])) - write_config_text('FLAC', bool(conf.env['HAVE_FLAC'])) + write_config_text('CoreAudio', conf.is_defined('HAVE_COREAUDIO')) + write_config_text('Debug RT allocations', conf.is_defined('DEBUG_RT_ALLOC')) + write_config_text('Process thread timing', conf.is_defined('PT_TIMING')) + write_config_text('Denormal exceptions', conf.is_defined('DEBUG_DENORMAL_EXCEPTION')) + write_config_text('FLAC', conf.is_defined('HAVE_FLAC')) write_config_text('FPU optimization', opts.fpu_optimization) write_config_text('Freedesktop files', opts.freedesktop) write_config_text('Freesound', opts.freesound) - write_config_text('JACK session support', bool(conf.env['JACK_SESSION'])) - write_config_text('LV2 UI embedding', bool(conf.env['HAVE_SUIL'])) - write_config_text('LV2 support', bool(conf.env['LV2_SUPPORT'])) - write_config_text('OGG', bool(conf.env['HAVE_OGG'])) - write_config_text('Phone home', bool(conf.env['PHONE_HOME'])) + write_config_text('JACK session support', conf.is_defined('JACK_SESSION')) + write_config_text('LV2 UI embedding', conf.is_defined('HAVE_SUIL')) + write_config_text('LV2 support', conf.is_defined('LV2_SUPPORT')) + write_config_text('LXVST support', conf.is_defined('LXVST_SUPPORT')) + write_config_text('OGG', conf.is_defined('HAVE_OGG')) + write_config_text('Phone home', conf.is_defined('PHONE_HOME')) write_config_text('Program name', opts.program_name) - write_config_text('Rubberband', bool(conf.env['HAVE_RUBBERBAND'])) - write_config_text('Samplerate', bool(conf.env['HAVE_SAMPLERATE'])) - write_config_text('Soundtouch', bool(conf.env['HAVE_SOUNDTOUCH'])) + write_config_text('Rubberband', conf.is_defined('HAVE_RUBBERBAND')) + write_config_text('Samplerate', conf.is_defined('HAVE_SAMPLERATE')) +# write_config_text('Soundtouch', conf.is_defined('HAVE_SOUNDTOUCH')) write_config_text('Translation', opts.nls) write_config_text('Tranzport', opts.tranzport) - write_config_text('Unit tests', bool(conf.env['BUILD_TESTS'])) + write_config_text('Unit tests', conf.env['BUILD_TESTS']) write_config_text('Universal binary', opts.universal) - write_config_text('VST support', opts.vst) + write_config_text('Windows VST support', opts.windows_vst) write_config_text('Wiimote support', opts.wiimote) write_config_text('Windows key', opts.windows_key) - write_config_text('C compiler flags', conf.env['CCFLAGS']) + write_config_text('C compiler flags', conf.env['CFLAGS']) write_config_text('C++ compiler flags', conf.env['CXXFLAGS']) config_text.write ('";\n}\n') @@ -607,10 +671,9 @@ def build(bld): bld.path.find_dir ('libs/pbd/pbd') autowaf.set_recursive() - if sys.platform == 'darwin': - bld.add_subdirs('libs/appleutility') + for i in children: - bld.add_subdirs(i) + bld.recurse(i) # ideally, we'd like to use the OS-provided MIDI API # for default ports. that doesn't work on at least @@ -629,11 +692,20 @@ def build(bld): 'JACK_INPUT' : 'auditioner' } - obj = bld.new_task_gen('subst') + obj = bld(features = 'subst') obj.source = 'ardour.rc.in' obj.target = 'ardour_system.rc' obj.dict = rc_subst_dict - obj.install_path = '${CONFIGDIR}/ardour3' + obj.install_path = '${SYSCONFDIR}/ardour3' def i18n(bld): bld.recurse (i18n_children) + +def i18n_pot(bld): + bld.recurse (i18n_children) + +def i18n_po(bld): + bld.recurse (i18n_children) + +def i18n_mo(bld): + bld.recurse (i18n_children)