From: Paul Brossier Date: Fri, 3 Jan 2014 22:50:36 +0000 (-0400) Subject: src/io/source.c: add source_wavread X-Git-Tag: 0.4.1~97 X-Git-Url: https://git.aubio.org/?a=commitdiff_plain;h=52efae1200ebd8c5acf4d389f165cfac2bd8cceb;p=aubio.git src/io/source.c: add source_wavread --- diff --git a/src/io/source.c b/src/io/source.c index b5e6fe8b..cd3e328c 100644 --- a/src/io/source.c +++ b/src/io/source.c @@ -32,6 +32,9 @@ #ifdef HAVE_SNDFILE #include "io/source_sndfile.h" #endif /* HAVE_SNDFILE */ +#ifdef HAVE_WAVREAD +#include "io/source_wavread.h" +#endif /* HAVE_WAVREAD */ typedef void (*aubio_source_do_t)(aubio_source_t * s, fvec_t * data, uint_t * read); typedef void (*aubio_source_do_multi_t)(aubio_source_t * s, fmat_t * data, uint_t * read); @@ -88,6 +91,18 @@ aubio_source_t * new_aubio_source(char_t * uri, uint_t samplerate, uint_t hop_si return s; } #endif /* HAVE_SNDFILE */ +#if HAVE_WAVREAD + s->source = (void *)new_aubio_source_wavread(uri, samplerate, hop_size); + if (s->source) { + s->s_do = (aubio_source_do_t)(aubio_source_wavread_do); + s->s_do_multi = (aubio_source_do_multi_t)(aubio_source_wavread_do_multi); + s->s_get_channels = (aubio_source_get_channels_t)(aubio_source_wavread_get_channels); + s->s_get_samplerate = (aubio_source_get_samplerate_t)(aubio_source_wavread_get_samplerate); + s->s_seek = (aubio_source_seek_t)(aubio_source_wavread_seek); + s->s_del = (del_aubio_source_t)(del_aubio_source_wavread); + return s; + } +#endif /* HAVE_WAVREAD */ AUBIO_ERROR("failed creating aubio source with %s\n", uri); AUBIO_FREE(s); return NULL;