source: wscript @ 41b985f

sampler
Last change on this file since 41b985f was 41b985f, checked in by Paul Brossier <piem@piem.org>, 7 years ago

Merge 'origin/master' into sampler

Conflicts:

.travis.yml
Makefile
examples/aubionotes.c
examples/parse_args.h
python/demos/demo_timestretch_online.py
python/lib/moresetuptools.py
python/tests/test_source.py
setup.py
src/io/source.c

  • Property mode set to 100644
File size: 20.9 KB
Line 
1#! /usr/bin/python
2#
3# usage:
4#   $ python waf --help
5#
6# example:
7#   $ ./waf distclean configure build
8#
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/ .
12
13import sys
14
15APPNAME = 'aubio'
16
17# source VERSION
18for l in open('VERSION').readlines(): exec (l.strip())
19
20VERSION = '.'.join ([str(x) for x in [
21    AUBIO_MAJOR_VERSION,
22    AUBIO_MINOR_VERSION,
23    AUBIO_PATCH_VERSION
24    ]]) + AUBIO_VERSION_STATUS
25
26LIB_VERSION = '.'.join ([str(x) for x in [
27    LIBAUBIO_LT_CUR,
28    LIBAUBIO_LT_REV,
29    LIBAUBIO_LT_AGE]])
30
31top = '.'
32out = 'build'
33
34def add_option_enable_disable(ctx, name, default = None,
35        help_str = None, help_disable_str = None):
36    if help_str == None:
37        help_str = 'enable ' + name + ' support'
38    if help_disable_str == None:
39        help_disable_str = 'do not ' + help_str
40    ctx.add_option('--enable-' + name, action = 'store_true',
41            default = default,
42            dest = 'enable_' + name.replace('-','_'),
43            help = help_str)
44    ctx.add_option('--disable-' + name, action = 'store_false',
45            #default = default,
46            dest = 'enable_' + name.replace('-','_'),
47            help = help_disable_str )
48
49def options(ctx):
50    ctx.add_option('--build-type', action = 'store',
51            default = "release",
52            choices = ('debug', 'release'),
53            dest = 'build_type',
54            help = 'whether to compile with (--build-type=release) or without (--build-type=debug) '\
55              ' compiler opimizations [default: release]')
56    add_option_enable_disable(ctx, 'fftw3f', default = False,
57            help_str = 'compile with fftw3f instead of ooura (recommended)',
58            help_disable_str = 'do not compile with fftw3f')
59    add_option_enable_disable(ctx, 'fftw3', default = False,
60            help_str = 'compile with fftw3 instead of ooura',
61            help_disable_str = 'do not compile with fftw3')
62    add_option_enable_disable(ctx, 'complex', default = False,
63            help_str ='compile with C99 complex',
64            help_disable_str = 'do not use C99 complex (default)' )
65    add_option_enable_disable(ctx, 'jack', default = None,
66            help_str = 'compile with jack (auto)',
67            help_disable_str = 'disable jack support')
68    add_option_enable_disable(ctx, 'sndfile', default = None,
69            help_str = 'compile with sndfile (auto)',
70            help_disable_str = 'disable sndfile')
71    add_option_enable_disable(ctx, 'avcodec', default = None,
72            help_str = 'compile with libavcodec (auto)',
73            help_disable_str = 'disable libavcodec')
74    add_option_enable_disable(ctx, 'samplerate', default = None,
75            help_str = 'compile with samplerate (auto)',
76            help_disable_str = 'disable samplerate')
77    add_option_enable_disable(ctx, 'rubberband', default = None,
78            help_str = 'compile with rubberband (auto)',
79            help_disable_str = 'disable rubberband')
80    add_option_enable_disable(ctx, 'memcpy', default = True,
81            help_str = 'use memcpy hacks (default)',
82            help_disable_str = 'do not use memcpy hacks')
83    add_option_enable_disable(ctx, 'double', default = False,
84            help_str = 'compile in double precision mode',
85            help_disable_str = 'compile in single precision mode (default)')
86    add_option_enable_disable(ctx, 'fat', default = False,
87            help_str = 'build fat binaries (darwin only)',
88            help_disable_str = 'do not build fat binaries (default)')
89    add_option_enable_disable(ctx, 'accelerate', default = None,
90            help_str = 'use Accelerate framework (darwin only) (auto)',
91            help_disable_str = 'do not use Accelerate framework')
92    add_option_enable_disable(ctx, 'apple-audio', default = None,
93            help_str = 'use CoreFoundation (darwin only) (auto)',
94            help_disable_str = 'do not use CoreFoundation framework')
95    add_option_enable_disable(ctx, 'atlas', default = False,
96            help_str = 'use Atlas library (no)',
97            help_disable_str = 'do not use Atlas library')
98    add_option_enable_disable(ctx, 'wavread', default = True,
99            help_str = 'compile with source_wavread (default)',
100            help_disable_str = 'do not compile source_wavread')
101    add_option_enable_disable(ctx, 'wavwrite', default = True,
102            help_str = 'compile with source_wavwrite (default)',
103            help_disable_str = 'do not compile source_wavwrite')
104
105    add_option_enable_disable(ctx, 'docs', default = None,
106            help_str = 'build documentation (auto)',
107            help_disable_str = 'do not build documentation')
108
109    ctx.add_option('--with-target-platform', type='string',
110            help='set target platform for cross-compilation', dest='target_platform')
111
112    ctx.load('compiler_c')
113    ctx.load('waf_unit_test')
114    ctx.load('gnu_dirs')
115
116def configure(ctx):
117    from waflib import Options
118    ctx.load('compiler_c')
119    ctx.load('waf_unit_test')
120    ctx.load('gnu_dirs')
121
122    # check for common headers
123    ctx.check(header_name='stdlib.h')
124    ctx.check(header_name='stdio.h')
125    ctx.check(header_name='math.h')
126    ctx.check(header_name='string.h')
127    ctx.check(header_name='limits.h')
128    ctx.check(header_name='stdarg.h')
129    ctx.check(header_name='getopt.h', mandatory = False)
130    ctx.check(header_name='unistd.h', mandatory = False)
131
132    ctx.check(header_name='pthread.h', mandatory = False)
133    needs_pthread = ctx.get_define("HAVE_PTHREAD_H") is not None
134    if needs_pthread:
135        ctx.check_cc(lib="pthread", uselib_store="PTHREAD", mandatory=needs_pthread)
136
137    target_platform = sys.platform
138    if ctx.options.target_platform:
139        target_platform = ctx.options.target_platform
140    ctx.env['DEST_OS'] = target_platform
141
142    if ctx.options.build_type == "debug":
143        ctx.define('DEBUG', 1)
144    else:
145        ctx.define('NDEBUG', 1)
146
147    if ctx.env.CC_NAME != 'msvc':
148        if ctx.options.build_type == "debug":
149            # no optimization in debug mode
150            ctx.env.prepend_value('CFLAGS', ['-O0'])
151        else:
152            # default to -O2 in release mode
153            ctx.env.prepend_value('CFLAGS', ['-O2'])
154        # enable debug symbols and configure warnings
155        ctx.env.prepend_value('CFLAGS', ['-g', '-Wall', '-Wextra'])
156    else:
157        # enable debug symbols
158        ctx.env.CFLAGS += ['/Z7', '/FS']
159        ctx.env.LINKFLAGS += ['/DEBUG', '/INCREMENTAL:NO']
160        # configure warnings
161        ctx.env.CFLAGS += ['/W4', '/D_CRT_SECURE_NO_WARNINGS']
162        # set optimization level and runtime libs
163        if (ctx.options.build_type == "release"):
164            ctx.env.CFLAGS += ['/Ox']
165            ctx.env.CFLAGS += ['/MD']
166        else:
167            assert(ctx.options.build_type == "debug")
168            ctx.env.CFLAGS += ['/MDd']
169
170    ctx.check_cc(lib='m', uselib_store='M', mandatory=False)
171
172    if target_platform not in ['win32', 'win64']:
173        ctx.env.CFLAGS += ['-fPIC']
174    else:
175        ctx.define('HAVE_WIN_HACKS', 1)
176        ctx.env['cshlib_PATTERN'] = 'lib%s.dll'
177
178    if target_platform == 'darwin' and ctx.options.enable_fat:
179        ctx.env.CFLAGS += ['-arch', 'i386', '-arch', 'x86_64']
180        ctx.env.LINKFLAGS += ['-arch', 'i386', '-arch', 'x86_64']
181        MINSDKVER="10.4"
182        ctx.env.CFLAGS += [ '-mmacosx-version-min=' + MINSDKVER ]
183        ctx.env.LINKFLAGS += [ '-mmacosx-version-min=' + MINSDKVER ]
184
185    if target_platform in [ 'darwin', 'ios', 'iosimulator']:
186        if (ctx.options.enable_apple_audio != False):
187            ctx.env.FRAMEWORK += ['CoreFoundation', 'AudioToolbox']
188            ctx.define('HAVE_SOURCE_APPLE_AUDIO', 1)
189            ctx.define('HAVE_SINK_APPLE_AUDIO', 1)
190            ctx.msg('Checking for AudioToolbox.framework', 'yes')
191        else:
192            ctx.msg('Checking for AudioToolbox.framework', 'no (disabled)', color = 'YELLOW')
193        if (ctx.options.enable_accelerate != False):
194            ctx.define('HAVE_ACCELERATE', 1)
195            ctx.env.FRAMEWORK += ['Accelerate']
196            ctx.msg('Checking for Accelerate framework', 'yes')
197        else:
198            ctx.msg('Checking for Accelerate framework', 'no (disabled)', color = 'YELLOW')
199
200    if target_platform in [ 'ios', 'iosimulator' ]:
201        MINSDKVER="6.1"
202        ctx.env.CFLAGS += ['-std=c99']
203        if (ctx.options.enable_apple_audio != False):
204            ctx.define('HAVE_AUDIO_UNIT', 1)
205            #ctx.env.FRAMEWORK += ['CoreFoundation', 'AudioToolbox']
206        if target_platform == 'ios':
207            DEVROOT = "/Applications/Xcode.app/Contents"
208            DEVROOT += "/Developer/Platforms/iPhoneOS.platform/Developer"
209            SDKROOT = "%(DEVROOT)s/SDKs/iPhoneOS.sdk" % locals()
210            ctx.env.CFLAGS += [ '-fembed-bitcode' ]
211            ctx.env.CFLAGS += [ '-arch', 'arm64' ]
212            ctx.env.CFLAGS += [ '-arch', 'armv7' ]
213            ctx.env.CFLAGS += [ '-arch', 'armv7s' ]
214            ctx.env.LINKFLAGS += [ '-arch', 'arm64' ]
215            ctx.env.LINKFLAGS += ['-arch', 'armv7']
216            ctx.env.LINKFLAGS += ['-arch', 'armv7s']
217            ctx.env.CFLAGS += [ '-miphoneos-version-min=' + MINSDKVER ]
218            ctx.env.LINKFLAGS += [ '-miphoneos-version-min=' + MINSDKVER ]
219        else:
220            DEVROOT = "/Applications/Xcode.app/Contents"
221            DEVROOT += "/Developer/Platforms/iPhoneSimulator.platform/Developer"
222            SDKROOT = "%(DEVROOT)s/SDKs/iPhoneSimulator.sdk" % locals()
223            ctx.env.CFLAGS += [ '-arch', 'i386' ]
224            ctx.env.CFLAGS += [ '-arch', 'x86_64' ]
225            ctx.env.LINKFLAGS += ['-arch', 'i386']
226            ctx.env.LINKFLAGS += ['-arch', 'x86_64']
227            ctx.env.CFLAGS += [ '-mios-simulator-version-min=' + MINSDKVER ]
228            ctx.env.LINKFLAGS += [ '-mios-simulator-version-min=' + MINSDKVER ]
229        ctx.env.CFLAGS += [ '-isysroot' , SDKROOT]
230        ctx.env.LINKFLAGS += [ '-isysroot' , SDKROOT]
231
232    if target_platform == 'emscripten':
233        import os.path
234        ctx.env.CFLAGS += [ '-I' + os.path.join(os.environ['EMSCRIPTEN'], 'system', 'include') ]
235        ctx.env.CFLAGS += ['-Oz']
236        ctx.env.cprogram_PATTERN = "%s.js"
237        if (ctx.options.enable_atlas != True):
238            ctx.options.enable_atlas = False
239
240    # check support for C99 __VA_ARGS__ macros
241    check_c99_varargs = '''
242#include <stdio.h>
243#define AUBIO_ERR(...) fprintf(stderr, __VA_ARGS__)
244'''
245
246    if ctx.check_cc(fragment = check_c99_varargs,
247            type='cstlib',
248            msg = 'Checking for C99 __VA_ARGS__ macro',
249            mandatory = False):
250        ctx.define('HAVE_C99_VARARGS_MACROS', 1)
251
252    # show a message about enable_double status
253    if (ctx.options.enable_double == True):
254        ctx.msg('Checking for size of smpl_t', 'double')
255        ctx.msg('Checking for size of lsmp_t', 'long double')
256    else:
257        ctx.msg('Checking for size of smpl_t', 'float')
258        ctx.msg('Checking for size of lsmp_t', 'double')
259
260    # optionally use complex.h
261    if (ctx.options.enable_complex == True):
262        ctx.check(header_name='complex.h')
263    else:
264        ctx.msg('Checking if complex.h is enabled', 'no')
265
266    # check for fftw3
267    if (ctx.options.enable_fftw3 != False or ctx.options.enable_fftw3f != False):
268        # one of fftwf or fftw3f
269        if (ctx.options.enable_fftw3f != False):
270            ctx.check_cfg(package = 'fftw3f', atleast_version = '3.0.0',
271                    args = '--cflags --libs',
272                    mandatory = ctx.options.enable_fftw3f)
273            if (ctx.options.enable_double == True):
274                ctx.msg('Warning',
275                        'fftw3f enabled, but compiling in double precision!')
276        else:
277            # fftw3f disabled, take most sensible one according to
278            # enable_double
279            if (ctx.options.enable_double == True):
280                ctx.check_cfg(package = 'fftw3', atleast_version = '3.0.0',
281                        args = '--cflags --libs', mandatory =
282                        ctx.options.enable_fftw3)
283            else:
284                ctx.check_cfg(package = 'fftw3f', atleast_version = '3.0.0',
285                        args = '--cflags --libs',
286                        mandatory = ctx.options.enable_fftw3)
287        ctx.define('HAVE_FFTW3', 1)
288
289    # fftw not enabled, use vDSP or ooura
290    if 'HAVE_FFTW3F' in ctx.env.define_key:
291        ctx.msg('Checking for FFT implementation', 'fftw3f')
292    elif 'HAVE_FFTW3' in ctx.env.define_key:
293        ctx.msg('Checking for FFT implementation', 'fftw3')
294    elif 'HAVE_ACCELERATE' in ctx.env.define_key:
295        ctx.msg('Checking for FFT implementation', 'vDSP')
296    else:
297        ctx.msg('Checking for FFT implementation', 'ooura')
298
299    # check for libsndfile
300    if (ctx.options.enable_sndfile != False):
301        ctx.check_cfg(package = 'sndfile', atleast_version = '1.0.4',
302                args = '--cflags --libs',
303                mandatory = ctx.options.enable_sndfile)
304
305    # check for libsamplerate
306    if (ctx.options.enable_double):
307        if (ctx.options.enable_samplerate):
308            ctx.fatal("Could not compile aubio in double precision mode with libsamplerate")
309        else:
310            ctx.options.enable_samplerate = False
311            ctx.msg('Checking if using samplerate', 'no (disabled in double precision mode)',
312                    color = 'YELLOW')
313    if (ctx.options.enable_samplerate != False):
314        ctx.check_cfg(package = 'samplerate', atleast_version = '0.0.15',
315                args = '--cflags --libs',
316                mandatory = ctx.options.enable_samplerate)
317
318    # check for librubberband
319    if (ctx.options.enable_rubberband != False):
320        ctx.check_cfg(package = 'rubberband', atleast_version = '1.3',
321                args = '--cflags --libs',
322                mandatory = ctx.options.enable_rubberband)
323
324    # check for jack
325    if (ctx.options.enable_jack != False):
326        ctx.check_cfg(package = 'jack',
327                args = '--cflags --libs',
328                mandatory = ctx.options.enable_jack)
329
330    # check for libav
331    if (ctx.options.enable_avcodec != False):
332        ctx.check_cfg(package = 'libavcodec', atleast_version = '54.35.0',
333                args = '--cflags --libs', uselib_store = 'AVCODEC',
334                mandatory = ctx.options.enable_avcodec)
335        ctx.check_cfg(package = 'libavformat', atleast_version = '52.3.0',
336                args = '--cflags --libs', uselib_store = 'AVFORMAT',
337                mandatory = ctx.options.enable_avcodec)
338        ctx.check_cfg(package = 'libavutil', atleast_version = '52.3.0',
339                args = '--cflags --libs', uselib_store = 'AVUTIL',
340                mandatory = ctx.options.enable_avcodec)
341        ctx.check_cfg(package = 'libavresample', atleast_version = '1.0.1',
342                args = '--cflags --libs', uselib_store = 'AVRESAMPLE',
343                mandatory = ctx.options.enable_avcodec)
344        if all ( 'HAVE_' + i in ctx.env
345                for i in ['AVCODEC', 'AVFORMAT', 'AVUTIL', 'AVRESAMPLE'] ):
346            ctx.define('HAVE_LIBAV', 1)
347            ctx.msg('Checking for all libav libraries', 'yes')
348        else:
349            ctx.msg('Checking for all libav libraries', 'not found', color = 'YELLOW')
350
351    if (ctx.options.enable_wavread != False):
352        ctx.define('HAVE_WAVREAD', 1)
353    ctx.msg('Checking if using source_wavread', ctx.options.enable_wavread and 'yes' or 'no')
354    if (ctx.options.enable_wavwrite!= False):
355        ctx.define('HAVE_WAVWRITE', 1)
356    ctx.msg('Checking if using sink_wavwrite', ctx.options.enable_wavwrite and 'yes' or 'no')
357
358    # use ATLAS
359    if (ctx.options.enable_atlas != False):
360        ctx.check(header_name = 'atlas/cblas.h', mandatory = ctx.options.enable_atlas)
361        #ctx.check(lib = 'lapack', uselib_store = 'LAPACK', mandatory = ctx.options.enable_atlas)
362        ctx.check(lib = 'cblas', uselib_store = 'BLAS', mandatory = ctx.options.enable_atlas)
363
364    # use memcpy hacks
365    if (ctx.options.enable_memcpy == True):
366        ctx.define('HAVE_MEMCPY_HACKS', 1)
367
368    # write configuration header
369    ctx.write_config_header('src/config.h')
370
371    # the following defines will be passed as arguments to the compiler
372    # instead of being written to src/config.h
373    ctx.define('HAVE_CONFIG_H', 1)
374
375    # add some defines used in examples
376    ctx.define('AUBIO_PREFIX', ctx.env['PREFIX'])
377    ctx.define('PACKAGE', APPNAME)
378
379    # double precision mode
380    if (ctx.options.enable_double == True):
381        ctx.define('HAVE_AUBIO_DOUBLE', 1)
382
383    if (ctx.options.enable_docs != False):
384        # check if txt2man is installed, optional
385        try:
386          ctx.find_program('txt2man', var='TXT2MAN')
387        except ctx.errors.ConfigurationError:
388          ctx.to_log('txt2man was not found (ignoring)')
389
390        # check if doxygen is installed, optional
391        try:
392          ctx.find_program('doxygen', var='DOXYGEN')
393        except ctx.errors.ConfigurationError:
394          ctx.to_log('doxygen was not found (ignoring)')
395
396        # check if sphinx-build is installed, optional
397        try:
398          ctx.find_program('sphinx-build', var='SPHINX')
399        except ctx.errors.ConfigurationError:
400          ctx.to_log('sphinx-build was not found (ignoring)')
401
402def build(bld):
403    bld.env['VERSION'] = VERSION
404    bld.env['LIB_VERSION'] = LIB_VERSION
405
406    # main source
407    bld.recurse('src')
408
409    # add sub directories
410    if bld.env['DEST_OS'] not in ['ios', 'iosimulator', 'android']:
411        bld.recurse('examples')
412        bld.recurse('tests')
413
414    # pkg-config template
415    bld( source = 'aubio.pc.in' )
416
417    # documentation
418    txt2man(bld)
419    doxygen(bld)
420    sphinx(bld)
421
422def txt2man(bld):
423    # build manpages from txt files using txt2man
424    if bld.env['TXT2MAN']:
425        from waflib import TaskGen
426        if 'MANDIR' not in bld.env:
427            bld.env['MANDIR'] = bld.env['DATAROOTDIR'] + '/man'
428        bld.env.VERSION = VERSION
429        rule_str = '${TXT2MAN} -t `basename ${TGT} | cut -f 1 -d . | tr a-z A-Z`'
430        rule_str += ' -r ${PACKAGE}\\ ${VERSION} -P ${PACKAGE}'
431        rule_str += ' -v ${PACKAGE}\\ User\\\'s\\ manual'
432        rule_str += ' -s 1 ${SRC} > ${TGT}'
433        TaskGen.declare_chain(
434                name      = 'txt2man',
435                rule      = rule_str,
436                ext_in    = '.txt',
437                ext_out   = '.1',
438                reentrant = False,
439                install_path =  '${MANDIR}/man1',
440                )
441        bld( source = bld.path.ant_glob('doc/*.txt') )
442
443def doxygen(bld):
444    # build documentation from source files using doxygen
445    if bld.env['DOXYGEN']:
446        bld( name = 'doxygen', rule = 'doxygen ${SRC} > /dev/null',
447                source = 'doc/web.cfg',
448                target = '../doc/web/html/index.html',
449                cwd = 'doc')
450        bld.install_files( '${DATAROOTDIR}' + '/doc/libaubio-doc',
451                bld.path.ant_glob('doc/web/html/**'),
452                cwd = bld.path.find_dir ('doc/web'),
453                relative_trick = True)
454
455def sphinx(bld):
456    # build documentation from source files using sphinx-build
457    # note: build in ../doc/_build/html, otherwise waf wont install unsigned files
458    if bld.env['SPHINX']:
459        bld.env.VERSION = VERSION
460        bld( name = 'sphinx',
461                rule = '${SPHINX} -b html -D release=${VERSION} -D version=${VERSION} -a -q `dirname ${SRC}` `dirname ${TGT}`',
462                source = 'doc/conf.py',
463                target = '../doc/_build/html/index.html')
464        bld.install_files( '${DATAROOTDIR}' + '/doc/libaubio-doc/sphinx',
465                bld.path.ant_glob('doc/_build/html/**'),
466                cwd = bld.path.find_dir('doc/_build/html'),
467                relative_trick = True)
468
469# register the previous rules as build rules
470from waflib.Build import BuildContext
471
472class build_txt2man(BuildContext):
473    cmd = 'txt2man'
474    fun = 'txt2man'
475
476class build_manpages(BuildContext):
477    cmd = 'manpages'
478    fun = 'txt2man'
479
480class build_sphinx(BuildContext):
481    cmd = 'sphinx'
482    fun = 'sphinx'
483
484class build_doxygen(BuildContext):
485    cmd = 'doxygen'
486    fun = 'doxygen'
487
488def shutdown(bld):
489    from waflib import Logs
490    if bld.options.target_platform in ['ios', 'iosimulator']:
491        msg ='building for %s, contact the author for a commercial license' % bld.options.target_platform
492        Logs.pprint('RED', msg)
493        msg ='   Paul Brossier <piem@aubio.org>'
494        Logs.pprint('RED', msg)
495
496def dist(ctx):
497    ctx.excl  = ' **/.waf* **/*~ **/*.pyc **/*.swp **/*.swo **/*.swn **/.lock-w* **/.git*'
498    ctx.excl += ' **/build/*'
499    ctx.excl += ' doc/_build'
500    ctx.excl += ' python/demos_*'
501    ctx.excl += ' **/python/gen **/python/build **/python/dist'
502    ctx.excl += ' **/python/ext/config.h'
503    ctx.excl += ' **/python/lib/aubio/_aubio.so'
504    ctx.excl += ' **.egg-info'
505    ctx.excl += ' **/**.zip **/**.tar.bz2'
506    ctx.excl += ' **.tar.bz2'
507    ctx.excl += ' **/doc/full/* **/doc/web/*'
508    ctx.excl += ' **/doc/full.cfg'
509    ctx.excl += ' **/python/*.db'
510    ctx.excl += ' **/python.old/*'
511    ctx.excl += ' **/python/*/*.old'
512    ctx.excl += ' **/python/tests/sounds'
513    ctx.excl += ' **/**.asc'
514    ctx.excl += ' **/dist*'
515    ctx.excl += ' **/.DS_Store'
516    ctx.excl += ' **/.travis.yml'
517    ctx.excl += ' **/.landscape.yml'
518    ctx.excl += ' **/.appveyor.yml'
Note: See TracBrowser for help on using the repository browser.