+i18n_children = [
+ 'gtk2_ardour',
+ 'libs/ardour',
+ '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):
+ cmd = "LANG= svn info " + path + " | awk '/^Revision:/ { print $2}'"
+ return subprocess.Popen(cmd, shell=True, stderr=subprocess.STDOUT, stdout=subprocess.PIPE).communicate()[0].splitlines()
+
+def fetch_gcc_version (CC):
+ cmd = "LANG= %s --version" % CC
+ output = subprocess.Popen(cmd, shell=True, stderr=subprocess.STDOUT, stdout=subprocess.PIPE).communicate()[0].splitlines()
+ o = output[0].decode('utf-8')
+ version = o.split(' ')[2].split('.')
+ return version
+
+def fetch_git_revision (path):
+ cmd = "LANG= git log --abbrev HEAD^..HEAD " + path
+ output = subprocess.Popen(cmd, shell=True, stderr=subprocess.STDOUT, stdout=subprocess.PIPE).communicate()[0].splitlines()
+ o = output[0].decode('utf-8')
+ rev = o.replace ("commit", "git")[0:10]
+ for line in output:
+ try:
+ if "git-svn-id" in line:
+ line = line.split('@')[1].split(' ')
+ rev = line[0]
+ except:
+ pass
+ return rev
+
+def fetch_bzr_revision (path):
+ cmd = subprocess.Popen("LANG= bzr log -l 1 " + path, stdout=subprocess.PIPE, shell=True)
+ out = cmd.communicate()[0]
+ svn = re.search('^svn revno: [0-9]*', out, re.MULTILINE)
+ str = svn.group(0)
+ chars = 'svnreio: '
+ return string.lstrip(str, chars)
+
+def create_stored_revision():
+ rev = ""
+ if os.path.exists('.svn'):
+ rev = fetch_svn_revision('.');
+ elif os.path.exists('.git'):
+ rev = fetch_git_revision('.');
+ elif os.path.exists('.bzr'):
+ rev = fetch_bzr_revision('.');
+ print("Revision: %s", rev)
+ elif os.path.exists('libs/ardour/svn_revision.cc'):
+ print("Using packaged svn revision")
+ return
+ else:
+ print("Missing libs/ardour/svn_revision.cc. Blame the packager.")
+ sys.exit(-1)
+
+ try:
+ text = '#include "ardour/svn_revision.h"\n'
+ text += 'namespace ARDOUR { const char* svn_revision = \"%s\"; }\n' % rev
+ print('Writing svn revision info to libs/ardour/svn_revision.cc')
+ o = open('libs/ardour/svn_revision.cc', 'w')
+ o.write(text)
+ o.close()
+ except IOError:
+ print('Could not open libs/ardour/svn_revision.cc for writing\n')
+ sys.exit(-1)
+
+def set_compiler_flags (conf,opt):
+ #
+ # Compiler flags and other system-dependent stuff
+ #
+
+ build_host_supports_sse = False
+ optimization_flags = []
+ debug_flags = []
+
+ # guess at the platform, used to define compiler flags
+
+ config_guess = os.popen("tools/config.guess").read()[:-1]
+
+ config_cpu = 0
+ config_arch = 1
+ config_kernel = 2
+ config_os = 3
+ config = config_guess.split ("-")
+
+ if opt.gprofile:
+ debug_flags = [ '-pg' ]
+ else:
+ if config[config_arch] != 'apple':
+ debug_flags = [ '-rdynamic' ] # waf adds -O0 -g itself. thanks waf!
+
+ # Autodetect
+ if opt.dist_target == 'auto':
+ 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.env['build_target'] = 'panther'
+ elif re.search ("darwin8[.]", config[config_kernel]) != None:
+ conf.env['build_target'] = 'tiger'
+ else:
+ conf.env['build_target'] = 'leopard'
+ else:
+ if re.search ("x86_64", config[config_cpu]) != None:
+ conf.env['build_target'] = 'x86_64'
+ elif re.search("i[0-5]86", config[config_cpu]) != None:
+ conf.env['build_target'] = 'i386'
+ elif re.search("powerpc", config[config_cpu]) != None:
+ conf.env['build_target'] = 'powerpc'
+ else:
+ conf.env['build_target'] = 'i686'
+ else:
+ conf.env['build_target'] = opt.dist_target
+
+ if config[config_cpu] == 'powerpc' and conf.env['build_target'] != 'none':
+ #
+ # Apple/PowerPC optimization options
+ #
+ # -mcpu=7450 does not reliably work with gcc 3.*
+ #
+ if opt.dist_target == 'panther' or opt.dist_target == 'tiger':
+ if config[config_arch] == 'apple':
+ # optimization_flags.extend ([ "-mcpu=7450", "-faltivec"])
+ # to support g3s but still have some optimization for above
+ optimization_flags.extend ([ "-mcpu=G3", "-mtune=7450"])
+ else:
+ optimization_flags.extend ([ "-mcpu=7400", "-maltivec", "-mabi=altivec"])
+ else:
+ optimization_flags.extend([ "-mcpu=750", "-mmultiple" ])
+ optimization_flags.extend (["-mhard-float", "-mpowerpc-gfxopt"])
+ optimization_flags.extend (["-Os"])
+
+ elif ((re.search ("i[0-9]86", config[config_cpu]) != None) or (re.search ("x86_64", config[config_cpu]) != None)) and conf.env['build_target'] != 'none':
+
+
+ #
+ # 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
+ #
+
+ if (re.search ("(i[0-9]86|x86_64)", config[config_cpu]) != None):
+ debug_flags.append ("-DARCH_X86")
+ optimization_flags.append ("-DARCH_X86")
+
+ if config[config_kernel] == 'linux' :
+
+ #
+ # determine processor flags via /proc/cpuinfo
+ #
+
+ if conf.env['build_target'] != 'i386':
+
+ flag_line = os.popen ("cat /proc/cpuinfo | grep '^flags'").read()[:-1]
+ x86_flags = flag_line.split (": ")[1:][0].split ()
+
+ if "mmx" in x86_flags:
+ optimization_flags.append ("-mmmx")
+ if "sse" in x86_flags:
+ build_host_supports_sse = True
+ if "3dnow" in x86_flags:
+ optimization_flags.append ("-m3dnow")
+
+ if config[config_cpu] == "i586":
+ optimization_flags.append ("-march=i586")
+ elif config[config_cpu] == "i686":
+ optimization_flags.append ("-march=i686")
+
+ if ((conf.env['build_target'] == 'i686') or (conf.env['build_target'] == 'x86_64')) and build_host_supports_sse:
+ optimization_flags.extend (["-msse", "-mfpmath=sse", "-DUSE_XMMINTRIN"])
+ debug_flags.extend (["-msse", "-mfpmath=sse", "-DUSE_XMMINTRIN"])
+
+ # end of processor-specific section
+
+ # optimization section
+ if conf.env['FPU_OPTIMIZATION']:
+ if conf.env['build_target'] == 'tiger' or conf.env['build_target'] == 'leopard':
+ optimization_flags.append ("-DBUILD_VECLIB_OPTIMIZATIONS");
+ debug_flags.append ("-DBUILD_VECLIB_OPTIMIZATIONS");
+ conf.env.append_value('LINKFLAGS', "-framework Accelerate")
+ 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:
+ print("\n\n==================================================")
+ print("You cannot use VST plugins with a 64 bit host. Please run waf with --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
+ #
+
+ if conf.env['build_target'] in ['panther', 'tiger', 'leopard' ]:
+ 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('CFLAGS', "-DMAC_OS_X_VERSION_MIN_REQUIRED=1040")
+
+ else:
+ conf.define ('IS_OSX', 0)
+
+ #
+ # save off guessed arch element in an env
+ #
+ conf.define ('CONFIG_ARCH', config[config_arch])
+
+ #
+ # ARCH="..." overrides all
+ #
+
+ if opt.arch != None:
+ optimization_flags = opt.arch.split()
+
+ #
+ # prepend boiler plate optimization flags that work on all architectures
+ #
+
+ optimization_flags[:0] = [
+ "-O3",
+ "-fomit-frame-pointer",
+ "-ffast-math",
+ "-fstrength-reduce",
+ "-pipe"
+ ]
+
+ if opt.debug:
+ 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('CFLAGS', optimization_flags)
+ conf.env.append_value('CXXFLAGS', optimization_flags)
+ conf.env.append_value('LINKFLAGS', optimization_flags)
+
+ if opt.stl_debug:
+ conf.env.append_value('CXXFLAGS', "-D_GLIBCXX_DEBUG")
+
+ if conf.env['DEBUG_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 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")
+
+ #
+ # 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
+ #
+
+ 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')
+
+ conf.env.append_value('CXXFLAGS', '-D__STDC_LIMIT_MACROS')
+ conf.env.append_value('CXXFLAGS', '-D__STDC_FORMAT_MACROS')
+
+ if opt.nls:
+ conf.env.append_value('CXXFLAGS', '-DENABLE_NLS')
+ conf.env.append_value('CFLAGS', '-DENABLE_NLS')
+
+#----------------------------------------------------------------
+
+# Waf stages
+
+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('--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('--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 Lilv+Suil is available)')
+ 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=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('--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)')
+ 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('--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',
+ help='X Modifier(s) (Mod1,Mod2, etc) for the Windows key (X11 builds only). ' +
+ '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',
+ help='Do not ask questions that require confirmation during the build')
+ for i in children:
+ opt.recurse(i)