ref: a93dab375dc53ce539d187fb22a0a18cba8de66d
parent: 6b1435146ce5b7358e5ea0bbe303e5adc9c9a3dc
	author: Paul Brossier <piem@piem.org>
	date: Sat Dec  7 18:14:12 EST 2013
	
wscript: indent and minor cosmetics
--- a/wscript
+++ b/wscript
@@ -1,11 +1,9 @@
#! /usr/bin/python
#
-# waf build script, see http://code.google.com/p/waf/
+# waf build system, see http://code.google.com/p/waf/
+#
# usage:
-# $ waf distclean configure build
-# get it:
-# $ svn co http://waf.googlecode.com/svn/trunk /path/to/waf
-# $ alias waf=/path/to/waf/waf-light
+# $ ./waf distclean configure build
#
# TODO
# - doc: add doxygen
@@ -32,203 +30,209 @@
def add_option_enable_disable(ctx, name, default = None,
help_str = None, help_disable_str = None):
- if help_str == None:
- help_str = 'enable ' + name + ' support'
- if help_disable_str == None:
- help_disable_str = 'do not ' + help_str
-  ctx.add_option('--enable-' + name, action = 'store_true'- default = default,
-          dest = 'enable_' + name.replace('-','_'),- help = help_str)
-  ctx.add_option('--disable-' + name, action = 'store_false',- #default = default,
-          dest = 'enable_' + name.replace('-','_'),- help = help_disable_str )
+ if help_str == None:
+ help_str = 'enable ' + name + ' support'
+ if help_disable_str == None:
+ help_disable_str = 'do not ' + help_str
+    ctx.add_option('--enable-' + name, action = 'store_true',+ default = default,
+            dest = 'enable_' + name.replace('-','_'),+ help = help_str)
+    ctx.add_option('--disable-' + name, action = 'store_false',+ #default = default,
+            dest = 'enable_' + name.replace('-','_'),+ help = help_disable_str )
def options(ctx):
- add_option_enable_disable(ctx, 'fftw3f', default = False,
- help_str = 'compile with fftw3f instead of ooura (recommended)',
- help_disable_str = 'do not compile with fftw3f')
- add_option_enable_disable(ctx, 'fftw3', default = False,
- help_str = 'compile with fftw3 instead of ooura',
- help_disable_str = 'do not compile with fftw3')
- add_option_enable_disable(ctx, 'complex', default = False,
- help_str ='compile with C99 complex',
- help_disable_str = 'do not use C99 complex (default)' )
- add_option_enable_disable(ctx, 'jack', default = None,
- help_str = 'compile with jack (auto)',
- help_disable_str = 'disable jack support')
- add_option_enable_disable(ctx, 'sndfile', default = None,
- help_str = 'compile with sndfile (auto)',
- help_disable_str = 'disable sndfile')
- add_option_enable_disable(ctx, 'avcodec', default = None,
- help_str = 'compile with libavcodec (auto)',
- help_disable_str = 'disable libavcodec')
- add_option_enable_disable(ctx, 'samplerate', default = None,
- help_str = 'compile with samplerate (auto)',
- help_disable_str = 'disable samplerate')
- add_option_enable_disable(ctx, 'memcpy', default = True,
- help_str = 'use memcpy hacks (default)',
- help_disable_str = 'do not use memcpy hacks')
- add_option_enable_disable(ctx, 'double', default = False,
- help_str = 'compile aubio in double precision mode',
- help_disable_str = 'compile aubio in single precision mode (default)')
+ add_option_enable_disable(ctx, 'fftw3f', default = False,
+ help_str = 'compile with fftw3f instead of ooura (recommended)',
+ help_disable_str = 'do not compile with fftw3f')
+ add_option_enable_disable(ctx, 'fftw3', default = False,
+ help_str = 'compile with fftw3 instead of ooura',
+ help_disable_str = 'do not compile with fftw3')
+ add_option_enable_disable(ctx, 'complex', default = False,
+ help_str ='compile with C99 complex',
+ help_disable_str = 'do not use C99 complex (default)' )
+ add_option_enable_disable(ctx, 'jack', default = None,
+ help_str = 'compile with jack (auto)',
+ help_disable_str = 'disable jack support')
+ add_option_enable_disable(ctx, 'sndfile', default = None,
+ help_str = 'compile with sndfile (auto)',
+ help_disable_str = 'disable sndfile')
+ add_option_enable_disable(ctx, 'avcodec', default = None,
+ help_str = 'compile with libavcodec (auto)',
+ help_disable_str = 'disable libavcodec')
+ add_option_enable_disable(ctx, 'samplerate', default = None,
+ help_str = 'compile with samplerate (auto)',
+ help_disable_str = 'disable samplerate')
+ add_option_enable_disable(ctx, 'memcpy', default = True,
+ help_str = 'use memcpy hacks (default)',
+ help_disable_str = 'do not use memcpy hacks')
+ add_option_enable_disable(ctx, 'double', default = False,
+ help_str = 'compile in double precision mode',
+ help_disable_str = 'compile in single precision mode (default)')
-  ctx.add_option('--with-target-platform', type='string',- help='set target platform for cross-compilation', dest='target_platform')
-  ctx.load('compiler_c')-  ctx.load('waf_unit_test')-  ctx.load('gnu_dirs')+    ctx.add_option('--with-target-platform', type='string',+ help='set target platform for cross-compilation', dest='target_platform')
+    ctx.load('compiler_c')+    ctx.load('waf_unit_test')+    ctx.load('gnu_dirs')+
def configure(ctx):
- from waflib import Options
-  ctx.load('compiler_c')-  ctx.load('waf_unit_test')-  ctx.load('gnu_dirs')- ctx.env.CFLAGS += ['-g', '-Wall', '-Wextra', '-fPIC']
+ from waflib import Options
+    ctx.load('compiler_c')+    ctx.load('waf_unit_test')+    ctx.load('gnu_dirs')+ ctx.env.CFLAGS += ['-g', '-Wall', '-Wextra', '-fPIC']
- target_platform = Options.platform
- if ctx.options.target_platform:
- target_platform = ctx.options.target_platform
- ctx.env['DEST_OS'] = target_platform
+ target_platform = Options.platform
+ if ctx.options.target_platform:
+ target_platform = ctx.options.target_platform
+ ctx.env['DEST_OS'] = target_platform
- if target_platform == 'win32':
- ctx.env['shlib_PATTERN'] = 'lib%s.dll'
+ if target_platform == 'win32':
+ ctx.env['shlib_PATTERN'] = 'lib%s.dll'
- if target_platform == 'darwin':
- ctx.env.CFLAGS += ['-arch', 'i386', '-arch', 'x86_64']
- ctx.env.LINKFLAGS += ['-arch', 'i386', '-arch', 'x86_64']
- ctx.env.FRAMEWORK = ['CoreFoundation', 'AudioToolbox', 'Accelerate']
-    ctx.define('HAVE_ACCELERATE', 1)+ if target_platform == 'darwin':
+ ctx.env.CFLAGS += ['-arch', 'i386', '-arch', 'x86_64']
+ ctx.env.LINKFLAGS += ['-arch', 'i386', '-arch', 'x86_64']
+ ctx.env.FRAMEWORK = ['CoreFoundation', 'AudioToolbox', 'Accelerate']
+        ctx.define('HAVE_ACCELERATE', 1)- if target_platform in [ 'ios', 'iosimulator' ]:
-    ctx.define('HAVE_ACCELERATE', 1)-    ctx.define('TARGET_OS_IPHONE', 1)- ctx.env.FRAMEWORK = ['CoreFoundation', 'AudioToolbox', 'Accelerate']
- SDKVER="7.0"
- MINSDKVER="6.1"
- ctx.env.CFLAGS += ['-std=c99']
- if target_platform == 'ios':
- DEVROOT = "/Applications/Xcode.app/Contents"
- DEVROOT += "/Developer/Platforms/iPhoneOS.platform/Developer"
- SDKROOT = "%(DEVROOT)s/SDKs/iPhoneOS%(SDKVER)s.sdk" % locals()
- ctx.env.CFLAGS += [ '-arch', 'arm64' ]
- ctx.env.CFLAGS += [ '-arch', 'armv7' ]
- ctx.env.CFLAGS += [ '-arch', 'armv7s' ]
- ctx.env.LINKFLAGS += [ '-arch', 'arm64' ]
- ctx.env.LINKFLAGS += ['-arch', 'armv7']
- ctx.env.LINKFLAGS += ['-arch', 'armv7s']
- ctx.env.CFLAGS += [ '-miphoneos-version-min=' + MINSDKVER ]
- ctx.env.LINKFLAGS += [ '-miphoneos-version-min=' + MINSDKVER ]
- else:
- DEVROOT = "/Applications/Xcode.app/Contents"
- DEVROOT += "/Developer/Platforms/iPhoneSimulator.platform/Developer"
- SDKROOT = "%(DEVROOT)s/SDKs/iPhoneSimulator%(SDKVER)s.sdk" % locals()
- ctx.env.CFLAGS += [ '-arch', 'i386' ]
- ctx.env.CFLAGS += [ '-arch', 'x86_64' ]
- ctx.env.LINKFLAGS += ['-arch', 'i386']
- ctx.env.LINKFLAGS += ['-arch', 'x86_64']
- ctx.env.CFLAGS += [ '-mios-simulator-version-min=' + MINSDKVER ]
- ctx.env.LINKFLAGS += [ '-mios-simulator-version-min=' + MINSDKVER ]
- ctx.env.CFLAGS += [ '-isysroot' , SDKROOT]
- ctx.env.LINKFLAGS += [ '-isysroot' , SDKROOT]
+ if target_platform in [ 'ios', 'iosimulator' ]:
+        ctx.define('HAVE_ACCELERATE', 1)+        ctx.define('TARGET_OS_IPHONE', 1)+ ctx.env.FRAMEWORK = ['CoreFoundation', 'AudioToolbox', 'Accelerate']
+ SDKVER="7.0"
+ MINSDKVER="6.1"
+ ctx.env.CFLAGS += ['-std=c99']
+ if target_platform == 'ios':
+ DEVROOT = "/Applications/Xcode.app/Contents"
+ DEVROOT += "/Developer/Platforms/iPhoneOS.platform/Developer"
+ SDKROOT = "%(DEVROOT)s/SDKs/iPhoneOS%(SDKVER)s.sdk" % locals()
+ ctx.env.CFLAGS += [ '-arch', 'arm64' ]
+ ctx.env.CFLAGS += [ '-arch', 'armv7' ]
+ ctx.env.CFLAGS += [ '-arch', 'armv7s' ]
+ ctx.env.LINKFLAGS += [ '-arch', 'arm64' ]
+ ctx.env.LINKFLAGS += ['-arch', 'armv7']
+ ctx.env.LINKFLAGS += ['-arch', 'armv7s']
+ ctx.env.CFLAGS += [ '-miphoneos-version-min=' + MINSDKVER ]
+ ctx.env.LINKFLAGS += [ '-miphoneos-version-min=' + MINSDKVER ]
+ else:
+ DEVROOT = "/Applications/Xcode.app/Contents"
+ DEVROOT += "/Developer/Platforms/iPhoneSimulator.platform/Developer"
+ SDKROOT = "%(DEVROOT)s/SDKs/iPhoneSimulator%(SDKVER)s.sdk" % locals()
+ ctx.env.CFLAGS += [ '-arch', 'i386' ]
+ ctx.env.CFLAGS += [ '-arch', 'x86_64' ]
+ ctx.env.LINKFLAGS += ['-arch', 'i386']
+ ctx.env.LINKFLAGS += ['-arch', 'x86_64']
+ ctx.env.CFLAGS += [ '-mios-simulator-version-min=' + MINSDKVER ]
+ ctx.env.LINKFLAGS += [ '-mios-simulator-version-min=' + MINSDKVER ]
+ ctx.env.CFLAGS += [ '-isysroot' , SDKROOT]
+ ctx.env.LINKFLAGS += [ '-isysroot' , SDKROOT]
- # check for required headers
- ctx.check(header_name='stdlib.h')
- ctx.check(header_name='stdio.h')
- ctx.check(header_name='math.h')
- ctx.check(header_name='string.h')
- ctx.check(header_name='limits.h')
+ # check for required headers
+ ctx.check(header_name='stdlib.h')
+ ctx.check(header_name='stdio.h')
+ ctx.check(header_name='math.h')
+ ctx.check(header_name='string.h')
+ ctx.check(header_name='limits.h')
- # check support for C99 __VA_ARGS__ macros
- check_c99_varargs = '''
+ # check support for C99 __VA_ARGS__ macros
+ check_c99_varargs = '''
#include <stdio.h>
#define AUBIO_ERR(...) fprintf(stderr, __VA_ARGS__)
'''
- if ctx.check_cc(fragment = check_c99_varargs,
- type='cstlib',
- msg = 'Checking for C99 __VA_ARGS__ macro'):
-    ctx.define('HAVE_C99_VARARGS_MACROS', 1)- # optionally use complex.h
- if (ctx.options.enable_complex == True):
- ctx.check(header_name='complex.h')
+ if ctx.check_cc(fragment = check_c99_varargs,
+ type='cstlib',
+ msg = 'Checking for C99 __VA_ARGS__ macro'):
+        ctx.define('HAVE_C99_VARARGS_MACROS', 1)- # check dependencies
- if (ctx.options.enable_sndfile != False):
- ctx.check_cfg(package = 'sndfile', atleast_version = '1.0.4',
- args = '--cflags --libs', mandatory = False)
- if (ctx.options.enable_samplerate != False):
- ctx.check_cfg(package = 'samplerate', atleast_version = '0.0.15',
- args = '--cflags --libs', mandatory = False)
+ # double precision mode
+ if (ctx.options.enable_double == True):
+        ctx.define('HAVE_AUBIO_DOUBLE', 1)+ else:
+        ctx.define('HAVE_AUBIO_DOUBLE', 0)+
+ # optionally use complex.h
+ if (ctx.options.enable_complex == True):
+ ctx.check(header_name='complex.h')
+
+ # check for fftw3
+ if (ctx.options.enable_fftw3 != False or ctx.options.enable_fftw3f != False):
+ # one of fftwf or fftw3f
+ if (ctx.options.enable_fftw3f != False):
+ ctx.check_cfg(package = 'fftw3f', atleast_version = '3.0.0',
+ args = '--cflags --libs', mandatory = False)
+ if (ctx.options.enable_double == True):
+                ctx.msg('Warning', 'fftw3f enabled, but compiling in double precision!')+ else:
+ # fftw3f not enabled, take most sensible one according to enable_double
+ if (ctx.options.enable_double == True):
+ ctx.check_cfg(package = 'fftw3', atleast_version = '3.0.0',
+ args = '--cflags --libs', mandatory = False)
+ else:
+ ctx.check_cfg(package = 'fftw3f', atleast_version = '3.0.0',
+ args = '--cflags --libs', mandatory = False)
+        ctx.define('HAVE_FFTW3', 1)- # double precision mode
- if (ctx.options.enable_double == True):
-    ctx.define('HAVE_AUBIO_DOUBLE', 1)- else:
-    ctx.define('HAVE_AUBIO_DOUBLE', 0)-
- # optional dependancies using pkg-config
- if (ctx.options.enable_fftw3 != False or ctx.options.enable_fftw3f != False):
- # one of fftwf or fftw3f
- if (ctx.options.enable_fftw3f != False):
- ctx.check_cfg(package = 'fftw3f', atleast_version = '3.0.0',
- args = '--cflags --libs', mandatory = False)
- if (ctx.options.enable_double == True):
-        ctx.msg('Warning', 'fftw3f enabled, but compiling in double precision!')+ # fftw not enabled, use vDSP or ooura
+ if 'HAVE_FFTW3F' in ctx.env.define_key:
+        ctx.msg('Checking for FFT implementation', 'fftw3f')+ elif 'HAVE_FFTW3' in ctx.env.define_key:
+        ctx.msg('Checking for FFT implementation', 'fftw3')+ elif 'HAVE_ACCELERATE' in ctx.env.define_key:
+        ctx.msg('Checking for FFT implementation', 'vDSP')else:
- # fftw3f not enabled, take most sensible one according to enable_double
- if (ctx.options.enable_double == True):
- ctx.check_cfg(package = 'fftw3', atleast_version = '3.0.0',
- args = '--cflags --libs', mandatory = False)
- else:
- ctx.check_cfg(package = 'fftw3f', atleast_version = '3.0.0',
- args = '--cflags --libs', mandatory = False)
-    ctx.define('HAVE_FFTW3', 1)+        ctx.msg('Checking for FFT implementation', 'ooura')- # fftw disabled, use ooura
- if 'HAVE_FFTW3F' in ctx.env.define_key:
-    ctx.msg('Checking for FFT implementation', 'fftw3f')- elif 'HAVE_FFTW3' in ctx.env.define_key:
-    ctx.msg('Checking for FFT implementation', 'fftw3')- elif 'HAVE_ACCELERATE' in ctx.env.define_key:
-    ctx.msg('Checking for FFT implementation', 'vDSP')- else:
-    ctx.msg('Checking for FFT implementation', 'ooura')+ # check for libsndfile
+ if (ctx.options.enable_sndfile != False):
+ ctx.check_cfg(package = 'sndfile', atleast_version = '1.0.4',
+ args = '--cflags --libs', mandatory = False)
- # use memcpy hacks
- if (ctx.options.enable_memcpy == True):
-    ctx.define('HAVE_MEMCPY_HACKS', 1)- else:
-    ctx.define('HAVE_MEMCPY_HACKS', 0)+ # check for libsamplerate
+ if (ctx.options.enable_samplerate != False):
+ ctx.check_cfg(package = 'samplerate', atleast_version = '0.0.15',
+ args = '--cflags --libs', mandatory = False)
- if (ctx.options.enable_jack != False):
- ctx.check_cfg(package = 'jack', atleast_version = '0.15.0',
- args = '--cflags --libs', mandatory = False)
+ # check for jack
+ if (ctx.options.enable_jack != False):
+ ctx.check_cfg(package = 'jack', atleast_version = '0.15.0',
+ args = '--cflags --libs', mandatory = False)
- if (ctx.options.enable_avcodec != False):
- ctx.check_cfg(package = 'libavcodec', atleast_version = '54.35.0',
- args = '--cflags --libs', uselib_store = 'AVCODEC', mandatory = False)
- ctx.check_cfg(package = 'libavformat', atleast_version = '52.3.0',
- args = '--cflags --libs', uselib_store = 'AVFORMAT', mandatory = False)
- ctx.check_cfg(package = 'libavutil', atleast_version = '52.3.0',
- args = '--cflags --libs', uselib_store = 'AVUTIL', mandatory = False)
- ctx.check_cfg(package = 'libavresample', atleast_version = '1.0.1',
- args = '--cflags --libs', uselib_store = 'AVRESAMPLE', mandatory = False)
+ # check for libav
+ if (ctx.options.enable_avcodec != False):
+ ctx.check_cfg(package = 'libavcodec', atleast_version = '54.35.0',
+ args = '--cflags --libs', uselib_store = 'AVCODEC', mandatory = False)
+ ctx.check_cfg(package = 'libavformat', atleast_version = '52.3.0',
+ args = '--cflags --libs', uselib_store = 'AVFORMAT', mandatory = False)
+ ctx.check_cfg(package = 'libavutil', atleast_version = '52.3.0',
+ args = '--cflags --libs', uselib_store = 'AVUTIL', mandatory = False)
+ ctx.check_cfg(package = 'libavresample', atleast_version = '1.0.1',
+ args = '--cflags --libs', uselib_store = 'AVRESAMPLE', mandatory = False)
- # write configuration header
-  ctx.write_config_header('src/config.h')+ # use memcpy hacks
+ if (ctx.options.enable_memcpy == True):
+        ctx.define('HAVE_MEMCPY_HACKS', 1)+ else:
+        ctx.define('HAVE_MEMCPY_HACKS', 0)- # add some defines used in examples
-  ctx.define('AUBIO_PREFIX', ctx.env['PREFIX'])-  ctx.define('PACKAGE', APPNAME)+ # write configuration header
+    ctx.write_config_header('src/config.h')- # check if txt2man is installed, optional
- try:
-    ctx.find_program('txt2man', var='TXT2MAN')- except ctx.errors.ConfigurationError:
-    ctx.to_log('txt2man was not found (ignoring)')+ # add some defines used in examples
+    ctx.define('AUBIO_PREFIX', ctx.env['PREFIX'])+    ctx.define('PACKAGE', APPNAME)+ # check if txt2man is installed, optional
+ try:
+      ctx.find_program('txt2man', var='TXT2MAN')+ except ctx.errors.ConfigurationError:
+      ctx.to_log('txt2man was not found (ignoring)')+
def build(bld):
bld.env['VERSION'] = VERSION
bld.env['LIB_VERSION'] = LIB_VERSION
@@ -255,7 +259,6 @@
TaskGen.declare_chain(
name = 'txt2man',
rule = rule_str,
-                #rule      = '${TXT2MAN} -p -P aubio -s 1 -r aubio-0.4.0 ${SRC} > ${TGT}',ext_in = '.txt',
ext_out = '.1',
reentrant = False,
@@ -281,6 +284,6 @@
ctx.excl += ' **/build/*'
ctx.excl += ' **/python/gen **/python/build **/python/dist'
ctx.excl += ' **/**.zip **/**.tar.bz2'
- ctx.excl += ' **/doc/full/*'
+ ctx.excl += ' **/doc/full/* **/doc/web/*'
ctx.excl += ' **/python/*.db'
ctx.excl += ' **/python.old/*'
--
⑨