X-Git-Url: http://git.tremily.us/?a=blobdiff_plain;f=wscript;h=4667fb909e4cd1c7e7fc192742ff5e8986bb88f4;hb=aa9e6df149c79d53ed8a5f2c1910cada8bae325e;hp=d0850c00f6044a64675ea2f7eb2ab68226a5ad47;hpb=e3cf37aee4ad3635485a94d81745bf31d787c4ea;p=aubio.git diff --git a/wscript b/wscript index d0850c00..4667fb90 100644 --- a/wscript +++ b/wscript @@ -1,146 +1,202 @@ #! /usr/bin/python -# +# +# waf build script, 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 +# +# TODO # - doc: add doxygen -# - tests: move to new unit test system +# - tests: move to new unit test system APPNAME = 'aubio' -VERSION = '0.3.3' -LIB_VERSION = '2.1.1' -srcdir = '.' -blddir = 'build' -def init(opt): - pass +# read from VERSION +for l in open('VERSION').readlines(): exec (l.strip()) -def set_options(opt): - opt.add_option('--enable-double', action='store_true', default=False, +VERSION = '.'.join \ + ([str(x) for x in [AUBIO_MAJOR_VERSION, AUBIO_MINOR_VERSION, AUBIO_PATCH_VERSION]]) \ + + AUBIO_VERSION_STATUS +LIB_VERSION = '.'.join \ + ([str(x) for x in [LIBAUBIO_LT_CUR, LIBAUBIO_LT_REV, LIBAUBIO_LT_AGE]]) + +import os.path, sys +if os.path.exists('src/config.h') or os.path.exists('Makefile'): + print "Please run 'make distclean' to clean-up autotools files before using waf" + sys.exit(1) + +top = '.' +out = 'build' + +def options(ctx): + ctx.add_option('--enable-double', action='store_true', default=False, help='compile aubio in double precision mode') - opt.add_option('--disable-fftw3f', action='store_true', default=False, - help='compile with fftw3 instead of fftw3f') - opt.add_option('--enable-complex', action='store_true', default=False, + ctx.add_option('--disable-double', dest='enable_double', + action='store_false', + help='compile aubio in single precision mode') + ctx.add_option('--enable-fftw3', action='store_true', default=False, + help='compile with fftw3 instead of ooura (recommended)') + ctx.add_option('--disable-fftw3', dest='enable_fftw3', + action='store_false', + help='compile with ooura instead of fftw3') + ctx.add_option('--enable-complex', action='store_true', default=False, help='compile with C99 complex') - opt.add_option('--disable-jack', action='store_true', default=False, + ctx.add_option('--disable-complex', dest='enable_complex', + action='store_false', + help='compile without C99 complex') + ctx.add_option('--enable-jack', action='store_true', default=None, + help='compile with jack support') + ctx.add_option('--disable-jack', dest='enable_jack', action='store_false', help='compile without jack support') - opt.add_option('--disable-lash', action='store_true', default=False, + ctx.add_option('--enable-lash', action='store_true', default=None, + help='compile with lash support') + ctx.add_option('--disable-lash', dest='enable_lash', action='store_false', help='compile without lash support') - opt.add_option('--disable-libsamplerate', action='store_true', default=False, + ctx.add_option('--enable-sndfile', action='store_true', default=None, + help='compile with libsndfile support') + ctx.add_option('--disable-sndfile', dest='enable_sndfile', + action='store_false', + help='compile without libsndfile support') + ctx.add_option('--enable-samplerate', action='store_true', default=None, + help='compile with libsamplerate support') + ctx.add_option('--disable-samplerate', dest='enable_samplerate', + action='store_false', help='compile without libsamplerate support') - opt.add_option('--with-target-platform', type='string', + ctx.add_option('--with-target-platform', type='string', help='set target platform for cross-compilation', dest='target_platform') - opt.tool_options('compiler_cc') - opt.tool_options('compiler_cxx') - opt.tool_options('gnu_dirs') - opt.tool_options('UnitTest') - -def configure(conf): - import Options - conf.check_tool('compiler_cc') - conf.check_tool('compiler_cxx') - conf.check_tool('gnu_dirs') # helpful for autotools transition and .pc generation - conf.check_tool('misc') # needed for subst + ctx.load('compiler_c') + ctx.load('waf_unit_test') + +def configure(ctx): + from waflib import Options + ctx.load('compiler_c') + ctx.load('waf_unit_test') + ctx.env.CFLAGS += ['-g', '-Wall', '-Wextra'] if Options.options.target_platform: Options.platform = Options.options.target_platform if Options.platform == 'win32': - conf.env['shlib_PATTERN'] = 'lib%s.dll' + ctx.env['shlib_PATTERN'] = 'lib%s.dll' + + if Options.platform == 'darwin': + ctx.env.CFLAGS += ['-arch', 'i386', '-arch', 'x86_64'] + ctx.env.LINKFLAGS += ['-arch', 'i386', '-arch', 'x86_64'] + ctx.env.CC = 'llvm-gcc-4.2' + ctx.env.LINK_CC = 'llvm-gcc-4.2' + ctx.env.FRAMEWORK = ['CoreFoundation', 'AudioToolbox', 'Accelerate'] + ctx.define('HAVE_ACCELERATE', 1) + + if Options.platform == 'ios': + ctx.env.CC = 'clang' + ctx.env.LD = 'clang' + ctx.env.LINK_CC = 'clang' + SDKVER="6.1" + DEVROOT="/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer" + SDKROOT="%(DEVROOT)s/SDKs/iPhoneOS%(SDKVER)s.sdk" % locals() + ctx.env.FRAMEWORK = ['CoreFoundation', 'AudioToolbox', 'Accelerate'] + ctx.define('HAVE_ACCELERATE', 1) + ctx.env.CFLAGS += [ '-miphoneos-version-min=6.1', '-arch', 'armv7', + '--sysroot=%s' % SDKROOT] + ctx.env.LINKFLAGS += ['-std=c99', '-arch', 'armv7', '--sysroot=%s' % + SDKROOT] # check for required headers - conf.check(header_name='stdlib.h') - conf.check(header_name='stdio.h') - conf.check(header_name='math.h') - conf.check(header_name='string.h') - conf.check(header_name='limits.h') + 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 = ''' +#include +#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 (Options.options.enable_complex == True): - conf.check(header_name='complex.h') + ctx.check(header_name='complex.h') # check dependencies - conf.check_cfg(package = 'sndfile', atleast_version = '1.0.4', - args = '--cflags --libs') - if (Options.options.disable_libsamplerate == False): - conf.check_cfg(package = 'libsamplerate', atleast_version = '0.0.15', - args = '--cflags --libs') + if (Options.options.enable_sndfile != False): + ctx.check_cfg(package = 'sndfile', atleast_version = '1.0.4', + args = '--cflags --libs', mandatory = False) + if (Options.options.enable_samplerate != False): + ctx.check_cfg(package = 'samplerate', atleast_version = '0.0.15', + args = '--cflags --libs', mandatory = False) # double precision mode if (Options.options.enable_double == True): - conf.define('HAVE_AUBIO_DOUBLE', 1) + ctx.define('HAVE_AUBIO_DOUBLE', 1) else: - conf.define('HAVE_AUBIO_DOUBLE', 0) - - # one of fftwf or fftw3f - if (Options.options.disable_fftw3f == True): - conf.check_cfg(package = 'fftw3', atleast_version = '3.0.0', - args = '--cflags --libs') + ctx.define('HAVE_AUBIO_DOUBLE', 0) + + # optional dependancies using pkg-config + if (Options.options.enable_fftw3 != False): + # fftw3f not enabled, take most sensible one according to enable_double + package = 'fftw3' + if not Options.options.enable_double: + package = 'fftw3f' + ctx.check_cfg(package = package, atleast_version = '3.0.0', + args = '--cflags --libs', mandatory = False) + ctx.define('HAVE_FFTW3', 1) else: - # fftw3f not disabled, take most sensible one according to enable_double - if (Options.options.enable_double == True): - conf.check_cfg(package = 'fftw3', atleast_version = '3.0.0', - args = '--cflags --libs') + # fftw disabled, use ooura + if 'HAVE_ACCELERATE' in ctx.env.define_key: + ctx.msg('Checking for FFT implementation', 'vDSP') else: - conf.check_cfg(package = 'fftw3f', atleast_version = '3.0.0', - args = '--cflags --libs') - - # optional dependancies - if (Options.options.disable_jack == False): - conf.check_cfg(package = 'jack', atleast_version = '0.15.0', - args = '--cflags --libs') - if (Options.options.disable_lash == False): - conf.check_cfg(package = 'lash-1.0', atleast_version = '0.5.0', - args = '--cflags --libs', uselib_store = 'LASH') - - # swig - if conf.find_program('swig', var='SWIG', mandatory = False): - conf.check_tool('swig', tooldir='swig') - conf.check_swig_version('1.3.27') - - # python - if conf.find_program('python', mandatory = False): - conf.check_tool('python') - conf.check_python_version((2,4,2)) - conf.check_python_headers() + ctx.msg('Checking for FFT implementation', 'ooura') + pass - # check support for C99 __VA_ARGS__ macros - check_c99_varargs = ''' -#include -#define AUBIO_ERR(...) fprintf(stderr, __VA_ARGS__) -''' - if conf.check_cc(fragment = check_c99_varargs, - type='cstaticlib', - msg = 'Checking for C99 __VA_ARGS__ macro'): - conf.define('HAVE_C99_VARARGS_MACROS', 1) + if (Options.options.enable_jack != False): + ctx.check_cfg(package = 'jack', atleast_version = '0.15.0', + args = '--cflags --libs', mandatory = False) + + if (Options.options.enable_lash != False): + ctx.check_cfg(package = 'lash-1.0', atleast_version = '0.5.0', + args = '--cflags --libs', uselib_store = 'LASH', mandatory = False) # write configuration header - conf.write_config_header('src/config.h') + ctx.write_config_header('src/config.h') - # add some defines used in examples - conf.define('AUBIO_PREFIX', conf.env['PREFIX']) - conf.define('PACKAGE', APPNAME) + # add some defines used in examples + ctx.define('AUBIO_PREFIX', ctx.env['PREFIX']) + ctx.define('PACKAGE', APPNAME) # check if docbook-to-man is installed, optional - conf.find_program('docbook-to-man', var='DOCBOOKTOMAN', mandatory=False) + try: + ctx.find_program('docbook-to-man', var='DOCBOOKTOMAN') + except ctx.errors.ConfigurationError: + ctx.to_log('docbook-to-man was not found (ignoring)') def build(bld): - bld.env['VERSION'] = VERSION - bld.env['LIB_VERSION'] = LIB_VERSION - - build_extras(bld) + bld.env['VERSION'] = VERSION + bld.env['LIB_VERSION'] = LIB_VERSION # add sub directories - bld.add_subdirs('src examples') - if bld.env['SWIG']: - if bld.env['PYTHON']: - bld.add_subdirs('python/aubio python') + bld.recurse('src') + from waflib import Options + if Options.platform != 'ios': + bld.recurse('examples') + bld.recurse('tests') + """ # create the aubio.pc file for pkg-config - aubiopc = bld.new_task_gen('subst') - aubiopc.source = 'aubio.pc.in' - aubiopc.target = 'aubio.pc' - aubiopc.install_path = '${PREFIX}/lib/pkgconfig' + if ctx.env['TARGET_PLATFORM'] == 'linux': + aubiopc = ctx.new_task_gen('subst') + aubiopc.source = 'aubio.pc.in' + aubiopc.target = 'aubio.pc' + aubiopc.install_path = '${PREFIX}/lib/pkgconfig' # build manpages from sgml files - if bld.env['DOCBOOKTOMAN']: + if ctx.env['DOCBOOKTOMAN']: import TaskGen TaskGen.declare_chain( name = 'docbooktoman', @@ -149,54 +205,19 @@ def build(bld): ext_out = '.1', reentrant = 0, ) - manpages = bld.new_task_gen(name = 'docbooktoman', - source=bld.path.ant_glob('doc/*.sgml')) - bld.install_files('${MANDIR}/man1', bld.path.ant_glob('doc/*.1')) + manpages = ctx.new_task_gen(name = 'docbooktoman', + source=ctx.path.ant_glob('doc/*.sgml')) + ctx.install_files('${MANDIR}/man1', ctx.path.ant_glob('doc/*.1')) # install woodblock sound - bld.install_files('${PREFIX}/share/sounds/aubio/', + bld.install_files('${PREFIX}/share/sounds/aubio/', 'sounds/woodblock.aiff') - - # build and run the unit tests - build_tests(bld) - import UnitTest - bld.add_post_fun(UnitTest.summary) + """ def shutdown(bld): - pass - -# loop over all *.c filenames in tests/src to build them all -# target name is filename.c without the .c -def build_tests(bld): - for target_name in bld.path.ant_glob('tests/src/**/*.c').split(): - this_target = bld.new_task_gen( - features = 'cc cprogram test', - source = target_name, - target = target_name.split('.')[0], - includes = 'src', - defines = 'AUBIO_UNSTABLE_API=1', - uselib_local = 'aubio') - # phasevoc-jack also needs jack - if target_name.endswith('test-phasevoc-jack.c'): - this_target.includes = ['src', 'examples'] - this_target.uselib_local = ['aubio'] - this_target.uselib = ['JACK'] - this_target.source += ' examples/jackio.c' - -def build_extras(bld): - # corner cases to build these ones only once - sndfileio = bld.new_task_gen(features = 'cc', - includes = 'examples src', - source = ['examples/sndfileio.c'], - target = 'sndfileio') - - defines = ['AUBIO_PREFIX="' + bld.env['AUBIO_PREFIX'] + '"'] - defines += ['PACKAGE="' + bld.env['PACKAGE'] + '"'] - - utilsio = bld.new_task_gen(features = 'cc', - includes = 'examples src', - add_objects = 'sndfileio', - source = ['examples/utils.c', 'examples/jackio.c'], - uselib = ['LASH', 'JACK', 'SNDFILE'], - defines = defines, - target = 'utilsio') + from waflib import Options, Logs + if Options.platform == 'ios': + msg ='aubio built for ios, contact the author for a commercial license' + Logs.pprint('RED', msg) + msg =' Paul Brossier ' + Logs.pprint('RED', msg)