source: wscript @ 2f02d51

feature/autosinkfeature/cnnfeature/cnn_orgfeature/constantqfeature/crepefeature/crepe_orgfeature/pitchshiftfeature/pydocstringsfeature/timestretchfix/ffmpeg5
Last change on this file since 2f02d51 was 342eb13e, checked in by Martin Hermant <martin.hermant@gmail.com>, 8 years ago

wscript : emscripten clarify comments on added flags

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