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 | |
---|
13 | import sys |
---|
14 | |
---|
15 | APPNAME = 'aubio' |
---|
16 | |
---|
17 | from this_version import * |
---|
18 | |
---|
19 | VERSION = get_aubio_version() |
---|
20 | LIB_VERSION = get_libaubio_version() |
---|
21 | |
---|
22 | top = '.' |
---|
23 | out = 'build' |
---|
24 | |
---|
25 | def 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 | |
---|
40 | def 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 | |
---|
104 | def 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 | |
---|
440 | def 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 | |
---|
460 | def 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 | |
---|
481 | def 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 | |
---|
496 | def 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 |
---|
511 | from waflib.Build import BuildContext |
---|
512 | |
---|
513 | class build_txt2man(BuildContext): |
---|
514 | cmd = 'txt2man' |
---|
515 | fun = 'txt2man' |
---|
516 | |
---|
517 | class build_manpages(BuildContext): |
---|
518 | cmd = 'manpages' |
---|
519 | fun = 'txt2man' |
---|
520 | |
---|
521 | class build_sphinx(BuildContext): |
---|
522 | cmd = 'sphinx' |
---|
523 | fun = 'sphinx' |
---|
524 | |
---|
525 | class build_doxygen(BuildContext): |
---|
526 | cmd = 'doxygen' |
---|
527 | fun = 'doxygen' |
---|
528 | |
---|
529 | def 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 | |
---|
537 | def 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' |
---|