7 # $ ./waf distclean configure build
9 # Note: aubio uses the waf build system, which relies on Python. Provided you
10 # have Python installed, you do *not* need to install anything to build aubio.
11 # For more info about waf, see http://code.google.com/p/waf/ .
17 from this_version import *
19 VERSION = get_aubio_version()
20 LIB_VERSION = get_libaubio_version()
25 def add_option_enable_disable(ctx, name, default = None,
26 help_str = None, help_disable_str = None):
28 help_str = 'enable ' + name + ' support'
29 if help_disable_str == None:
30 help_disable_str = 'do not ' + help_str
31 ctx.add_option('--enable-' + name, action = 'store_true',
33 dest = 'enable_' + name.replace('-','_'),
35 ctx.add_option('--disable-' + name, action = 'store_false',
37 dest = 'enable_' + name.replace('-','_'),
38 help = help_disable_str )
41 ctx.add_option('--build-type', action = 'store',
43 choices = ('debug', 'release'),
45 help = 'whether to compile with (--build-type=release) or without (--build-type=debug) '\
46 ' compiler opimizations [default: release]')
47 add_option_enable_disable(ctx, 'fftw3f', default = False,
48 help_str = 'compile with fftw3f instead of ooura (recommended)',
49 help_disable_str = 'do not compile with fftw3f')
50 add_option_enable_disable(ctx, 'fftw3', default = False,
51 help_str = 'compile with fftw3 instead of ooura',
52 help_disable_str = 'do not compile with fftw3')
53 add_option_enable_disable(ctx, 'intelipp', default = None,
54 help_str = 'use Intel IPP libraries (auto)',
55 help_disable_str = 'do not use Intel IPP libraries')
56 add_option_enable_disable(ctx, 'complex', default = False,
57 help_str ='compile with C99 complex',
58 help_disable_str = 'do not use C99 complex (default)' )
59 add_option_enable_disable(ctx, 'jack', default = None,
60 help_str = 'compile with jack (auto)',
61 help_disable_str = 'disable jack support')
62 add_option_enable_disable(ctx, 'sndfile', default = None,
63 help_str = 'compile with sndfile (auto)',
64 help_disable_str = 'disable sndfile')
65 add_option_enable_disable(ctx, 'avcodec', default = None,
66 help_str = 'compile with libavcodec (auto)',
67 help_disable_str = 'disable libavcodec')
68 add_option_enable_disable(ctx, 'samplerate', default = None,
69 help_str = 'compile with samplerate (auto)',
70 help_disable_str = 'disable samplerate')
71 add_option_enable_disable(ctx, 'memcpy', default = True,
72 help_str = 'use memcpy hacks (default)',
73 help_disable_str = 'do not use memcpy hacks')
74 add_option_enable_disable(ctx, 'double', default = False,
75 help_str = 'compile in double precision mode',
76 help_disable_str = 'compile in single precision mode (default)')
77 add_option_enable_disable(ctx, 'fat', default = False,
78 help_str = 'build fat binaries (darwin only)',
79 help_disable_str = 'do not build fat binaries (default)')
80 add_option_enable_disable(ctx, 'accelerate', default = None,
81 help_str = 'use Accelerate framework (darwin only) (auto)',
82 help_disable_str = 'do not use Accelerate framework')
83 add_option_enable_disable(ctx, 'apple-audio', default = None,
84 help_str = 'use CoreFoundation (darwin only) (auto)',
85 help_disable_str = 'do not use CoreFoundation framework')
86 add_option_enable_disable(ctx, 'atlas', default = False,
87 help_str = 'use Atlas library (no)',
88 help_disable_str = 'do not use Atlas library')
89 add_option_enable_disable(ctx, 'wavread', default = True,
90 help_str = 'compile with source_wavread (default)',
91 help_disable_str = 'do not compile source_wavread')
92 add_option_enable_disable(ctx, 'wavwrite', default = True,
93 help_str = 'compile with source_wavwrite (default)',
94 help_disable_str = 'do not compile source_wavwrite')
96 add_option_enable_disable(ctx, 'docs', default = None,
97 help_str = 'build documentation (auto)',
98 help_disable_str = 'do not build documentation')
100 ctx.add_option('--with-target-platform', type='string',
101 help='set target platform for cross-compilation', dest='target_platform')
103 ctx.load('compiler_c')
104 ctx.load('waf_unit_test')
108 from waflib import Options
109 ctx.load('compiler_c')
110 ctx.load('waf_unit_test')
113 target_platform = sys.platform
114 if ctx.options.target_platform:
115 target_platform = ctx.options.target_platform
118 if target_platform=='emscripten':
119 # need to force spaces between flag -o and path
121 # https://github.com/waf-project/waf/blob/master/waflib/extras/c_emscripten.py (#1885)
122 # (OSX /emscripten 1.37.9)
123 ctx.env.CC_TGT_F = ['-c', '-o', '']
124 ctx.env.CCLNK_TGT_F = ['-o', '']
125 # check for common headers
126 ctx.check(header_name='stdlib.h')
127 ctx.check(header_name='stdio.h')
128 ctx.check(header_name='math.h')
129 ctx.check(header_name='string.h')
130 ctx.check(header_name='limits.h')
131 ctx.check(header_name='stdarg.h')
132 ctx.check(header_name='getopt.h', mandatory = False)
133 ctx.check(header_name='unistd.h', mandatory = False)
135 ctx.env['DEST_OS'] = target_platform
137 if ctx.options.build_type == "debug":
138 ctx.define('DEBUG', 1)
140 ctx.define('NDEBUG', 1)
142 if ctx.env.CC_NAME != 'msvc':
143 if ctx.options.build_type == "debug":
144 # no optimization in debug mode
145 ctx.env.prepend_value('CFLAGS', ['-O0'])
147 if target_platform == 'emscripten':
148 # -Oz for small js file generation
149 ctx.env.prepend_value('CFLAGS', ['-Oz'])
151 # default to -O2 in release mode
152 ctx.env.prepend_value('CFLAGS', ['-O2'])
153 # enable debug symbols and configure warnings
154 ctx.env.prepend_value('CFLAGS', ['-g', '-Wall', '-Wextra'])
156 # enable debug symbols
157 ctx.env.CFLAGS += ['/Z7', '/FS']
158 ctx.env.LINKFLAGS += ['/DEBUG', '/INCREMENTAL:NO']
160 ctx.env.CFLAGS += ['/W4', '/D_CRT_SECURE_NO_WARNINGS']
161 # ignore "possible loss of data" warnings
162 ctx.env.CFLAGS += ['/wd4305', '/wd4244', '/wd4245', '/wd4267']
163 # ignore "unreferenced formal parameter" warnings
164 ctx.env.CFLAGS += ['/wd4100']
165 # set optimization level and runtime libs
166 if (ctx.options.build_type == "release"):
167 ctx.env.CFLAGS += ['/Ox']
168 ctx.env.CFLAGS += ['/MD']
170 assert(ctx.options.build_type == "debug")
171 ctx.env.CFLAGS += ['/MDd']
173 ctx.check_cc(lib='m', uselib_store='M', mandatory=False)
175 if target_platform not in ['win32', 'win64']:
176 ctx.env.CFLAGS += ['-fPIC']
178 ctx.define('HAVE_WIN_HACKS', 1)
179 ctx.env['cshlib_PATTERN'] = 'lib%s.dll'
181 if target_platform == 'darwin' and ctx.options.enable_fat:
182 ctx.env.CFLAGS += ['-arch', 'i386', '-arch', 'x86_64']
183 ctx.env.LINKFLAGS += ['-arch', 'i386', '-arch', 'x86_64']
185 ctx.env.CFLAGS += [ '-mmacosx-version-min=' + MINSDKVER ]
186 ctx.env.LINKFLAGS += [ '-mmacosx-version-min=' + MINSDKVER ]
188 if target_platform in [ 'darwin', 'ios', 'iosimulator']:
189 if (ctx.options.enable_apple_audio != False):
190 ctx.env.FRAMEWORK += ['CoreFoundation', 'AudioToolbox']
191 ctx.define('HAVE_SOURCE_APPLE_AUDIO', 1)
192 ctx.define('HAVE_SINK_APPLE_AUDIO', 1)
193 ctx.msg('Checking for AudioToolbox.framework', 'yes')
195 ctx.msg('Checking for AudioToolbox.framework', 'no (disabled)', color = 'YELLOW')
196 if (ctx.options.enable_accelerate != False):
197 ctx.define('HAVE_ACCELERATE', 1)
198 ctx.env.FRAMEWORK += ['Accelerate']
199 ctx.msg('Checking for Accelerate framework', 'yes')
201 ctx.msg('Checking for Accelerate framework', 'no (disabled)', color = 'YELLOW')
203 if target_platform in [ 'ios', 'iosimulator' ]:
205 ctx.env.CFLAGS += ['-std=c99']
206 if (ctx.options.enable_apple_audio != False):
207 ctx.define('HAVE_AUDIO_UNIT', 1)
208 #ctx.env.FRAMEWORK += ['CoreFoundation', 'AudioToolbox']
209 if target_platform == 'ios':
210 DEVROOT = "/Applications/Xcode.app/Contents"
211 DEVROOT += "/Developer/Platforms/iPhoneOS.platform/Developer"
212 SDKROOT = "%(DEVROOT)s/SDKs/iPhoneOS.sdk" % locals()
213 ctx.env.CFLAGS += [ '-fembed-bitcode' ]
214 ctx.env.CFLAGS += [ '-arch', 'arm64' ]
215 ctx.env.CFLAGS += [ '-arch', 'armv7' ]
216 ctx.env.CFLAGS += [ '-arch', 'armv7s' ]
217 ctx.env.LINKFLAGS += [ '-arch', 'arm64' ]
218 ctx.env.LINKFLAGS += ['-arch', 'armv7']
219 ctx.env.LINKFLAGS += ['-arch', 'armv7s']
220 ctx.env.CFLAGS += [ '-miphoneos-version-min=' + MINSDKVER ]
221 ctx.env.LINKFLAGS += [ '-miphoneos-version-min=' + MINSDKVER ]
223 DEVROOT = "/Applications/Xcode.app/Contents"
224 DEVROOT += "/Developer/Platforms/iPhoneSimulator.platform/Developer"
225 SDKROOT = "%(DEVROOT)s/SDKs/iPhoneSimulator.sdk" % locals()
226 ctx.env.CFLAGS += [ '-arch', 'i386' ]
227 ctx.env.CFLAGS += [ '-arch', 'x86_64' ]
228 ctx.env.LINKFLAGS += ['-arch', 'i386']
229 ctx.env.LINKFLAGS += ['-arch', 'x86_64']
230 ctx.env.CFLAGS += [ '-mios-simulator-version-min=' + MINSDKVER ]
231 ctx.env.LINKFLAGS += [ '-mios-simulator-version-min=' + MINSDKVER ]
232 ctx.env.CFLAGS += [ '-isysroot' , SDKROOT]
233 ctx.env.LINKFLAGS += [ '-isysroot' , SDKROOT]
235 if target_platform == 'emscripten':
237 ctx.env.CFLAGS += [ '-I' + os.path.join(os.environ['EMSCRIPTEN'], 'system', 'include') ]
239 if ctx.options.build_type == "debug":
240 ctx.env.cshlib_PATTERN = '%s.js'
241 ctx.env.LINKFLAGS += ['-s','ASSERTIONS=2']
242 ctx.env.LINKFLAGS += ['-s','SAFE_HEAP=1']
243 ctx.env.LINKFLAGS += ['-s','ALIASING_FUNCTION_POINTERS=0']
244 ctx.env.LINKFLAGS += ['-O0']
246 ctx.env.LINKFLAGS += ['-Oz']
247 ctx.env.cshlib_PATTERN = '%s.min.js'
249 # doesnt ship file system support in lib
250 ctx.env.LINKFLAGS_cshlib += ['-s', 'NO_FILESYSTEM=1']
251 # put memory file inside generated js files for easier portability
252 ctx.env.LINKFLAGS += ['--memory-init-file', '0']
253 ctx.env.cprogram_PATTERN = "%s.js"
254 ctx.env.cstlib_PATTERN = '%s.a'
256 # tell emscripten functions we want to expose
257 from python.lib.gen_external import get_c_declarations, get_cpp_objects_from_c_declarations, get_all_func_names_from_lib, generate_lib_from_c_declarations
258 c_decls = get_c_declarations(usedouble=False) # emscripten can't use double
259 objects = get_cpp_objects_from_c_declarations(c_decls)
260 # ensure that aubio structs are exported
261 objects += ['fvec_t', 'cvec_t', 'fmat_t']
262 lib = generate_lib_from_c_declarations(objects, c_decls)
263 exported_funcnames = get_all_func_names_from_lib(lib)
264 c_mangled_names = ['_' + s for s in exported_funcnames]
265 ctx.env.LINKFLAGS_cshlib += ['-s', 'EXPORTED_FUNCTIONS=%s' % c_mangled_names]
267 if (ctx.options.enable_atlas != True):
268 ctx.options.enable_atlas = False
270 # check support for C99 __VA_ARGS__ macros
271 check_c99_varargs = '''
273 #define AUBIO_ERR(...) fprintf(stderr, __VA_ARGS__)
276 if ctx.check_cc(fragment = check_c99_varargs,
278 msg = 'Checking for C99 __VA_ARGS__ macro',
280 ctx.define('HAVE_C99_VARARGS_MACROS', 1)
282 # show a message about enable_double status
283 if (ctx.options.enable_double == True):
284 ctx.msg('Checking for size of smpl_t', 'double')
285 ctx.msg('Checking for size of lsmp_t', 'long double')
287 ctx.msg('Checking for size of smpl_t', 'float')
288 ctx.msg('Checking for size of lsmp_t', 'double')
290 # optionally use complex.h
291 if (ctx.options.enable_complex == True):
292 ctx.check(header_name='complex.h')
294 ctx.msg('Checking if complex.h is enabled', 'no')
296 # check for Intel IPP
297 if (ctx.options.enable_intelipp != False):
298 if (ctx.check(header_name=['ippcore.h', 'ippvm.h', 'ipps.h'], mandatory = False) and
299 ctx.check(lib=['ippcore', 'ippvm', 'ipps'], uselib_store='INTEL_IPP', mandatory = False)):
300 ctx.msg('Checking if Intel IPP is available', 'yes')
301 ctx.define('HAVE_INTEL_IPP', 1)
302 if ctx.env.CC_NAME == 'msvc':
303 # force linking multi-threaded static IPP libraries on Windows with msvc
304 ctx.define('_IPP_SEQUENTIAL_STATIC', 1)
306 ctx.msg('Checking if Intel IPP is available', 'no')
309 if (ctx.options.enable_fftw3 != False or ctx.options.enable_fftw3f != False):
310 # one of fftwf or fftw3f
311 if (ctx.options.enable_fftw3f != False):
312 ctx.check_cfg(package = 'fftw3f',
313 args = '--cflags --libs fftw3f >= 3.0.0',
314 mandatory = ctx.options.enable_fftw3f)
315 if (ctx.options.enable_double == True):
317 'fftw3f enabled, but compiling in double precision!')
319 # fftw3f disabled, take most sensible one according to
321 if (ctx.options.enable_double == True):
322 ctx.check_cfg(package = 'fftw3',
323 args = '--cflags --libs fftw3 >= 3.0.0.',
324 mandatory = ctx.options.enable_fftw3)
326 ctx.check_cfg(package = 'fftw3f',
327 args = '--cflags --libs fftw3f >= 3.0.0',
328 mandatory = ctx.options.enable_fftw3)
329 ctx.define('HAVE_FFTW3', 1)
331 # fftw not enabled, use vDSP, intelIPP or ooura
332 if 'HAVE_FFTW3F' in ctx.env.define_key:
333 ctx.msg('Checking for FFT implementation', 'fftw3f')
334 elif 'HAVE_FFTW3' in ctx.env.define_key:
335 ctx.msg('Checking for FFT implementation', 'fftw3')
336 elif 'HAVE_ACCELERATE' in ctx.env.define_key:
337 ctx.msg('Checking for FFT implementation', 'vDSP')
338 elif 'HAVE_INTEL_IPP' in ctx.env.define_key:
339 ctx.msg('Checking for FFT implementation', 'Intel IPP')
341 ctx.msg('Checking for FFT implementation', 'ooura')
343 # check for libsndfile
344 if (ctx.options.enable_sndfile != False):
345 ctx.check_cfg(package = 'sndfile',
346 args = '--cflags --libs sndfile >= 1.0.4',
347 mandatory = ctx.options.enable_sndfile)
349 # check for libsamplerate
350 if (ctx.options.enable_double):
351 if (ctx.options.enable_samplerate):
352 ctx.fatal("Could not compile aubio in double precision mode with libsamplerate")
354 ctx.options.enable_samplerate = False
355 ctx.msg('Checking if using samplerate', 'no (disabled in double precision mode)',
357 if (ctx.options.enable_samplerate != False):
358 ctx.check_cfg(package = 'samplerate',
359 args = '--cflags --libs samplerate >= 0.0.15',
360 mandatory = ctx.options.enable_samplerate)
363 if (ctx.options.enable_jack != False):
364 ctx.check_cfg(package = 'jack',
365 args = '--cflags --libs',
366 mandatory = ctx.options.enable_jack)
369 if (ctx.options.enable_avcodec != False):
370 ctx.check_cfg(package = 'libavcodec',
371 args = '--cflags --libs libavcodec >= 54.35.0',
372 uselib_store = 'AVCODEC',
373 mandatory = ctx.options.enable_avcodec)
374 ctx.check_cfg(package = 'libavformat',
375 args = '--cflags --libs libavformat >= 52.3.0',
376 uselib_store = 'AVFORMAT',
377 mandatory = ctx.options.enable_avcodec)
378 ctx.check_cfg(package = 'libavutil',
379 args = '--cflags --libs libavutil >= 52.3.0',
380 uselib_store = 'AVUTIL',
381 mandatory = ctx.options.enable_avcodec)
382 ctx.check_cfg(package = 'libswresample',
383 args = '--cflags --libs libswresample >= 1.2.0',
384 uselib_store = 'SWRESAMPLE',
386 if 'HAVE_SWRESAMPLE' not in ctx.env:
387 ctx.check_cfg(package = 'libavresample',
388 args = '--cflags --libs libavresample >= 1.0.1',
389 uselib_store = 'AVRESAMPLE',
392 msg_check = 'Checking for all libav libraries'
393 if 'HAVE_AVCODEC' not in ctx.env:
394 ctx.msg(msg_check, 'not found (missing avcodec)', color = 'YELLOW')
395 elif 'HAVE_AVFORMAT' not in ctx.env:
396 ctx.msg(msg_check, 'not found (missing avformat)', color = 'YELLOW')
397 elif 'HAVE_AVUTIL' not in ctx.env:
398 ctx.msg(msg_check, 'not found (missing avutil)', color = 'YELLOW')
399 elif 'HAVE_SWRESAMPLE' not in ctx.env and 'HAVE_AVRESAMPLE' not in ctx.env:
400 resample_missing = 'not found (avresample or swresample required)'
401 ctx.msg(msg_check, resample_missing, color = 'YELLOW')
403 ctx.msg(msg_check, 'yes')
404 if 'HAVE_SWRESAMPLE' in ctx.env:
405 ctx.define('HAVE_SWRESAMPLE', 1)
406 elif 'HAVE_AVRESAMPLE' in ctx.env:
407 ctx.define('HAVE_AVRESAMPLE', 1)
408 ctx.define('HAVE_LIBAV', 1)
410 if (ctx.options.enable_wavread != False):
411 ctx.define('HAVE_WAVREAD', 1)
412 ctx.msg('Checking if using source_wavread', ctx.options.enable_wavread and 'yes' or 'no')
413 if (ctx.options.enable_wavwrite!= False):
414 ctx.define('HAVE_WAVWRITE', 1)
415 ctx.msg('Checking if using sink_wavwrite', ctx.options.enable_wavwrite and 'yes' or 'no')
418 if (ctx.options.enable_atlas != False):
419 ctx.check(header_name = 'atlas/cblas.h', mandatory = ctx.options.enable_atlas)
420 #ctx.check(lib = 'lapack', uselib_store = 'LAPACK', mandatory = ctx.options.enable_atlas)
421 ctx.check(lib = 'cblas', uselib_store = 'BLAS', mandatory = ctx.options.enable_atlas)
424 if (ctx.options.enable_memcpy == True):
425 ctx.define('HAVE_MEMCPY_HACKS', 1)
427 # write configuration header
428 ctx.write_config_header('src/config.h')
430 # the following defines will be passed as arguments to the compiler
431 # instead of being written to src/config.h
432 ctx.define('HAVE_CONFIG_H', 1)
434 # add some defines used in examples
435 ctx.define('AUBIO_PREFIX', ctx.env['PREFIX'])
436 ctx.define('PACKAGE', APPNAME)
438 # double precision mode
439 if (ctx.options.enable_double == True):
440 ctx.define('HAVE_AUBIO_DOUBLE', 1)
442 if (ctx.options.enable_docs != False):
443 # check if txt2man is installed, optional
445 ctx.find_program('txt2man', var='TXT2MAN')
446 except ctx.errors.ConfigurationError:
447 ctx.to_log('txt2man was not found (ignoring)')
449 # check if doxygen is installed, optional
451 ctx.find_program('doxygen', var='DOXYGEN')
452 except ctx.errors.ConfigurationError:
453 ctx.to_log('doxygen was not found (ignoring)')
455 # check if sphinx-build is installed, optional
457 ctx.find_program('sphinx-build', var='SPHINX')
458 except ctx.errors.ConfigurationError:
459 ctx.to_log('sphinx-build was not found (ignoring)')
462 bld.env['VERSION'] = VERSION
463 bld.env['LIB_VERSION'] = LIB_VERSION
468 # add sub directories
469 if bld.env['DEST_OS'] not in ['ios', 'iosimulator', 'android']:
470 bld.recurse('examples')
473 # pkg-config template
474 bld( source = 'aubio.pc.in' )
482 # build manpages from txt files using txt2man
483 if bld.env['TXT2MAN']:
484 from waflib import TaskGen
485 if 'MANDIR' not in bld.env:
486 bld.env['MANDIR'] = bld.env['DATAROOTDIR'] + '/man'
487 bld.env.VERSION = VERSION
488 rule_str = '${TXT2MAN} -t `basename ${TGT} | cut -f 1 -d . | tr a-z A-Z`'
489 rule_str += ' -r ${PACKAGE}\\ ${VERSION} -P ${PACKAGE}'
490 rule_str += ' -v ${PACKAGE}\\ User\\\'s\\ manual'
491 rule_str += ' -s 1 ${SRC} > ${TGT}'
492 TaskGen.declare_chain(
498 install_path = '${MANDIR}/man1',
500 bld( source = bld.path.ant_glob('doc/*.txt') )
503 # build documentation from source files using doxygen
504 if bld.env['DOXYGEN']:
505 bld.env.VERSION = VERSION
506 rule = '( cat ${SRC} && echo PROJECT_NUMBER=${VERSION}; )'
507 rule += ' | doxygen - > /dev/null'
508 bld( name = 'doxygen', rule = rule,
509 source = 'doc/web.cfg',
510 target = '../doc/web/html/index.html',
512 bld.install_files( '${DATAROOTDIR}' + '/doc/libaubio-doc',
513 bld.path.ant_glob('doc/web/html/**'),
514 cwd = bld.path.find_dir ('doc/web'),
515 relative_trick = True)
518 # build documentation from source files using sphinx-build
519 # note: build in ../doc/_build/html, otherwise waf wont install unsigned files
520 if bld.env['SPHINX']:
521 bld.env.VERSION = VERSION
522 bld( name = 'sphinx',
523 rule = '${SPHINX} -b html -D release=${VERSION} -D version=${VERSION} -a -q `dirname ${SRC}` `dirname ${TGT}`',
524 source = 'doc/conf.py',
525 target = '../doc/_build/html/index.html')
526 bld.install_files( '${DATAROOTDIR}' + '/doc/libaubio-doc/sphinx',
527 bld.path.ant_glob('doc/_build/html/**'),
528 cwd = bld.path.find_dir('doc/_build/html'),
529 relative_trick = True)
531 # register the previous rules as build rules
532 from waflib.Build import BuildContext
534 class build_txt2man(BuildContext):
538 class build_manpages(BuildContext):
542 class build_sphinx(BuildContext):
546 class build_doxygen(BuildContext):
551 from waflib import Logs
552 if bld.options.target_platform in ['ios', 'iosimulator']:
553 msg ='building for %s, contact the author for a commercial license' % bld.options.target_platform
554 Logs.pprint('RED', msg)
555 msg =' Paul Brossier <piem@aubio.org>'
556 Logs.pprint('RED', msg)
559 ctx.excl = ' **/.waf* **/*~ **/*.pyc **/*.swp **/*.swo **/*.swn **/.lock-w* **/.git*'
560 ctx.excl += ' **/build/*'
561 ctx.excl += ' doc/_build'
562 ctx.excl += ' python/demos_*'
563 ctx.excl += ' **/python/gen **/python/build **/python/dist'
564 ctx.excl += ' **/python/ext/config.h'
565 ctx.excl += ' **/python/lib/aubio/_aubio.so'
566 ctx.excl += ' **.egg-info'
567 ctx.excl += ' **/**.zip **/**.tar.bz2'
568 ctx.excl += ' **.tar.bz2'
569 ctx.excl += ' **/doc/full/* **/doc/web/*'
570 ctx.excl += ' **/doc/full.cfg'
571 ctx.excl += ' **/python/*.db'
572 ctx.excl += ' **/python.old/*'
573 ctx.excl += ' **/python/*/*.old'
574 ctx.excl += ' **/python/tests/sounds'
575 ctx.excl += ' **/**.asc'
576 ctx.excl += ' **/dist*'
577 ctx.excl += ' **/.DS_Store'
578 ctx.excl += ' **/.travis.yml'
579 ctx.excl += ' **/.landscape.yml'
580 ctx.excl += ' **/.appveyor.yml'