import sys
# Variables for 'waf dist'
-VERSION = '3.0alpha10'
-APPNAME = 'Ardour'
+VERSION = '3.0beta3'
+APPNAME = 'Ardour3'
# Mandatory variables
top = '.'
'libs/gtkmm2ext',
'libs/clearlooks-newer',
'libs/audiographer',
- 'libs/gnomecanvas',
'gtk2_ardour',
'templates',
'export',
+ 'midi_maps',
+ 'manual'
]
-#if config[config_arch] != 'apple':
-# children += [ 'tools/sanity_check' ]
-
i18n_children = [
'gtk2_ardour',
'libs/ardour',
if sys.platform != 'darwin':
children += [ 'tools/sanity_check' ]
+ lxvst_default = True
else:
children += [ 'libs/appleutility' ]
+ lxvst_default = False
# Version stuff
#
# 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):
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.is_defined('HAVE_POSIX_MEMALIGN'):
optimization_flags.append("-DNO_POSIX_MEMALIGN")
+ debug_flags.append("-DNO_POSIX_MEMALIGN")
# end optimization section
# 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':
- print("\n\n********************************************************")
- print("* Building with 64Bit linuxVST support is experimental *")
- print("********************************************************\n\n")
conf.env.append_value('CXXFLAGS', "-DLXVST_64BIT")
else:
conf.env.append_value('CXXFLAGS', "-DLXVST_32BIT")
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('CFLAGS', "-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('CFLAGS', "-Wall")
conf.env.append_value('CXXFLAGS', [ '-Wall', '-Woverloaded-virtual'])
- if opt.extra_warn:
- flags = [ '-Wextra' ]
- conf.env.append_value('CFLAGS', flags)
- conf.env.append_value('CXXFLAGS', flags)
-
#
# more boilerplate
def options(opt):
opt.load('compiler_c')
opt.load('compiler_cxx')
- autowaf.set_options(opt)
+ 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',
+ 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('--lxvst', action='store_true', default=False, dest='lxvst',
+ 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('--optimize', action='store_false', dest='debug')
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',
help='Compile with support for Frontier Designs Tranzport (if libusb is available)')
opt.add_option('--universal', action='store_true', default=False, dest='universal',
- help='Compile as universal binary (requires that external libraries are universal)')
+ help='Compile as universal binary (OS X ONLY, 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><Super',
'Multiple modifiers must be separated by \'><\'')
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',
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' +
'Thanks for your co-operation with our development process.\n\n' +
'Press Enter to continue.\n')
sys.stdin.readline()
- create_stored_revision()
conf.env['VERSION'] = VERSION
conf.line_just = 52
autowaf.set_recursive()
if sys.platform == 'darwin':
- conf.define ('AUDIOUNITS', 1)
- conf.define ('AU_STATE_SUPPORT', 1)
- conf.define ('COREAUDIO', 1)
+ # libintl may or may not be trivially locatable
+ if not os.path.isfile ('/usr/include/libintl.h'):
+ # XXXX hack hack hack
+ prefinclude = ''.join ([ '-I', os.path.expanduser ('~/gtk/inst/include') ])
+ preflib = ''.join ([ '-L', os.path.expanduser ('~/gtk/inst/lib') ])
+ conf.env.append_value('CFLAGS', [ prefinclude ])
+ conf.env.append_value('CXXFLAGS', [prefinclude ])
+ conf.env.append_value('LINKFLAGS', [ preflib ])
+
+ # this is required, potentially, for anything we link and then relocate into a bundle
+ conf.env.append_value('LINKFLAGS', [ '-Xlinker', '-headerpad_max_install_names' ])
+
+ 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)
# off processor type. Need to add in a check
# for that.
#
- conf.env.append_value('CXXFLAGS_OSX', '-F/System/LibraryFrameworks')
+ conf.env.append_value('CXXFLAGS_OSX', '-F/System/Library/Frameworks')
conf.env.append_value('CXXFLAGS_OSX', '-F/Library/Frameworks')
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', "-DAUDIOUNIT_SUPPORT")
+ conf.env.append_value('LINKFLAGS_AUDIOUNITS', ['-framework', 'AudioToolbox', '-framework', 'AudioUnit'])
+ conf.env.append_value('LINKFLAGS_AUDIOUNITS', ['-framework', 'Cocoa'])
- conf.env.append_value('CXXFLAGS_AUDIOUNITS', "-DHAVE_AUDIOUNITS")
- conf.env.append_value('LINKFLAGS_AUDIOUNITS', ['-framework', 'Audiotoolbox', '-framework', 'AudioUnit'])
+ 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)
+
+ 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)
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')
for i in children:
sub_config_and_use(conf, i)
conf.env['BUILD_TESTS'] = opts.build_tests
if opts.tranzport:
conf.env['TRANZPORT'] = 1
- if opts.vst:
- conf.define('VST_SUPPORT', 1)
- conf.env['VST_SUPPORT'] = True
- conf.env.append_value('CPPPATH', Options.options.wine_include)
+ 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['PROGRAM_NAME'] = opts.program_name
if opts.rt_alloc_debug:
conf.define('DEBUG_RT_ALLOC', 1)
+ 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
write_config_text('Architecture flags', opts.arch)
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', 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('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('LV2 state support', conf.is_defined('HAVE_NEW_LILV'))
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', 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('Soundtouch', conf.is_defined('HAVE_SOUNDTOUCH'))
write_config_text('Translation', opts.nls)
write_config_text('Tranzport', opts.tranzport)
- write_config_text('Unit tests', conf.is_defined('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)
print('')
def build(bld):
+ create_stored_revision()
+
# add directories that contain only headers, to workaround an issue with waf
bld.path.find_dir ('libs/evoral/evoral')
obj.source = 'ardour.rc.in'
obj.target = 'ardour_system.rc'
obj.dict = rc_subst_dict
- obj.install_path = '${SYSCONF}/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)