source: src/io/sink.c @ 1a30c43

feature/autosinkfeature/cnnfeature/crepefix/ffmpeg5
Last change on this file since 1a30c43 was 1a30c43, checked in by Paul Brossier <piem@piem.org>, 5 years ago

[io] sink opens sink_flac if file ends with .flac

  • Property mode set to 100644
File size: 9.3 KB
Line 
1/*
2  Copyright (C) 2012-2014 Paul Brossier <piem@aubio.org>
3
4  This file is part of aubio.
5
6  aubio is free software: you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation, either version 3 of the License, or
9  (at your option) any later version.
10
11  aubio is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  GNU General Public License for more details.
15
16  You should have received a copy of the GNU General Public License
17  along with aubio.  If not, see <http://www.gnu.org/licenses/>.
18
19*/
20
21#include "aubio_priv.h"
22#include "fvec.h"
23#include "fmat.h"
24#include "io/sink.h"
25#ifdef HAVE_SINK_APPLE_AUDIO
26#include "io/sink_apple_audio.h"
27#endif /* HAVE_SINK_APPLE_AUDIO */
28#ifdef HAVE_SNDFILE
29#include "io/sink_sndfile.h"
30#endif
31#ifdef HAVE_WAVWRITE
32#include "io/sink_wavwrite.h"
33#endif
34
35typedef void (*aubio_sink_do_t)(aubio_sink_t * s, fvec_t * data, uint_t write);
36typedef void (*aubio_sink_do_multi_t)(aubio_sink_t * s, fmat_t * data, uint_t write);
37typedef uint_t (*aubio_sink_preset_samplerate_t)(aubio_sink_t * s, uint_t samplerate);
38typedef uint_t (*aubio_sink_preset_channels_t)(aubio_sink_t * s, uint_t channels);
39typedef uint_t (*aubio_sink_get_samplerate_t)(aubio_sink_t * s);
40typedef uint_t (*aubio_sink_get_channels_t)(aubio_sink_t * s);
41typedef uint_t (*aubio_sink_close_t)(aubio_sink_t * s);
42typedef void (*del_aubio_sink_t)(aubio_sink_t * s);
43
44struct _aubio_sink_t { 
45  void *sink;
46  aubio_sink_do_t s_do;
47  aubio_sink_do_multi_t s_do_multi;
48  aubio_sink_preset_samplerate_t s_preset_samplerate;
49  aubio_sink_preset_channels_t s_preset_channels;
50  aubio_sink_get_samplerate_t s_get_samplerate;
51  aubio_sink_get_channels_t s_get_channels;
52  aubio_sink_close_t s_close;
53  del_aubio_sink_t s_del;
54};
55
56#ifdef HAVE_VORBISENC
57typedef struct _aubio_sink_vorbis_t aubio_sink_vorbis_t;
58extern aubio_sink_vorbis_t * new_aubio_sink_vorbis(const char_t *uri,
59    uint_t samplerate);
60extern void del_aubio_sink_vorbis (aubio_sink_vorbis_t *s);
61extern uint_t aubio_sink_vorbis_open(aubio_sink_vorbis_t *s);
62extern uint_t aubio_sink_vorbis_close(aubio_sink_vorbis_t *s);
63extern uint_t aubio_sink_vorbis_preset_channels(aubio_sink_vorbis_t *s,
64    uint_t channels);
65extern uint_t aubio_sink_vorbis_preset_samplerate(aubio_sink_vorbis_t *s,
66    uint_t samplerate);
67extern uint_t aubio_sink_vorbis_get_channels(aubio_sink_vorbis_t *s);
68extern uint_t aubio_sink_vorbis_get_samplerate(aubio_sink_vorbis_t *s);
69extern void aubio_sink_vorbis_do(aubio_sink_vorbis_t *s, fvec_t*
70    write_data, uint_t write);
71extern void aubio_sink_vorbis_do_multi(aubio_sink_vorbis_t *s, fmat_t*
72    write_data, uint_t write);
73#endif /* HAVE_VORBISENC */
74
75#ifdef HAVE_FLAC
76typedef struct _aubio_sink_flac_t aubio_sink_flac_t;
77extern aubio_sink_flac_t * new_aubio_sink_flac(const char_t *uri,
78    uint_t samplerate);
79extern void del_aubio_sink_flac (aubio_sink_flac_t *s);
80extern uint_t aubio_sink_flac_open(aubio_sink_flac_t *s);
81extern uint_t aubio_sink_flac_close(aubio_sink_flac_t *s);
82extern uint_t aubio_sink_flac_preset_channels(aubio_sink_flac_t *s,
83    uint_t channels);
84extern uint_t aubio_sink_flac_preset_samplerate(aubio_sink_flac_t *s,
85    uint_t samplerate);
86extern uint_t aubio_sink_flac_get_channels(aubio_sink_flac_t *s);
87extern uint_t aubio_sink_flac_get_samplerate(aubio_sink_flac_t *s);
88extern void aubio_sink_flac_do(aubio_sink_flac_t *s, fvec_t*
89    write_data, uint_t write);
90extern void aubio_sink_flac_do_multi(aubio_sink_flac_t *s, fmat_t*
91    write_data, uint_t write);
92#endif /* HAVE_FLAC */
93
94static const char_t *aubio_get_extension(const char_t *filename)
95{
96  // find last occurence of dot character
97  const char_t *ext = strrchr(filename, '.');
98  if (!ext || ext == filename) return "";
99  else return ext + 1;
100}
101
102aubio_sink_t * new_aubio_sink(const char_t * uri, uint_t samplerate) {
103  aubio_sink_t * s = AUBIO_NEW(aubio_sink_t);
104
105#ifdef HAVE_VORBISENC
106  // check if this uri could be for us
107  uint_t match_oggstream = 0;
108  if (strcmp (aubio_get_extension(uri), "ogg") == 0) match_oggstream = 1;
109  if (match_oggstream) {
110    s->sink = (void *)new_aubio_sink_vorbis(uri, samplerate);
111    if (s->sink) {
112      s->s_do = (aubio_sink_do_t)(aubio_sink_vorbis_do);
113      s->s_do_multi = (aubio_sink_do_multi_t)(aubio_sink_vorbis_do_multi);
114      s->s_preset_samplerate = (aubio_sink_preset_samplerate_t)(aubio_sink_vorbis_preset_samplerate);
115      s->s_preset_channels = (aubio_sink_preset_channels_t)(aubio_sink_vorbis_preset_channels);
116      s->s_get_samplerate = (aubio_sink_get_samplerate_t)(aubio_sink_vorbis_get_samplerate);
117      s->s_get_channels = (aubio_sink_get_channels_t)(aubio_sink_vorbis_get_channels);
118      s->s_close = (aubio_sink_close_t)(aubio_sink_vorbis_close);
119      s->s_del = (del_aubio_sink_t)(del_aubio_sink_vorbis);
120      return s;
121    }
122  }
123#endif /* HAVE_VORBISENC */
124
125#ifdef HAVE_FLAC
126  // check if this uri could be for us
127  uint_t match_flacstream = 0;
128  if (strcmp (aubio_get_extension(uri), "flac") == 0) match_flacstream = 1;
129  if (match_flacstream) {
130    s->sink = (void *)new_aubio_sink_flac(uri, samplerate);
131    if (s->sink) {
132      s->s_do = (aubio_sink_do_t)(aubio_sink_flac_do);
133      s->s_do_multi = (aubio_sink_do_multi_t)(aubio_sink_flac_do_multi);
134      s->s_preset_samplerate = (aubio_sink_preset_samplerate_t)(aubio_sink_flac_preset_samplerate);
135      s->s_preset_channels = (aubio_sink_preset_channels_t)(aubio_sink_flac_preset_channels);
136      s->s_get_samplerate = (aubio_sink_get_samplerate_t)(aubio_sink_flac_get_samplerate);
137      s->s_get_channels = (aubio_sink_get_channels_t)(aubio_sink_flac_get_channels);
138      s->s_close = (aubio_sink_close_t)(aubio_sink_flac_close);
139      s->s_del = (del_aubio_sink_t)(del_aubio_sink_flac);
140      return s;
141    }
142  }
143#endif /* HAVE_FLAC */
144
145#ifdef HAVE_SINK_APPLE_AUDIO
146  s->sink = (void *)new_aubio_sink_apple_audio(uri, samplerate);
147  if (s->sink) {
148    s->s_do = (aubio_sink_do_t)(aubio_sink_apple_audio_do);
149    s->s_do_multi = (aubio_sink_do_multi_t)(aubio_sink_apple_audio_do_multi);
150    s->s_preset_samplerate = (aubio_sink_preset_samplerate_t)(aubio_sink_apple_audio_preset_samplerate);
151    s->s_preset_channels = (aubio_sink_preset_channels_t)(aubio_sink_apple_audio_preset_channels);
152    s->s_get_samplerate = (aubio_sink_get_samplerate_t)(aubio_sink_apple_audio_get_samplerate);
153    s->s_get_channels = (aubio_sink_get_channels_t)(aubio_sink_apple_audio_get_channels);
154    s->s_close = (aubio_sink_close_t)(aubio_sink_apple_audio_close);
155    s->s_del = (del_aubio_sink_t)(del_aubio_sink_apple_audio);
156    return s;
157  }
158#endif /* HAVE_SINK_APPLE_AUDIO */
159#ifdef HAVE_SNDFILE
160  s->sink = (void *)new_aubio_sink_sndfile(uri, samplerate);
161  if (s->sink) {
162    s->s_do = (aubio_sink_do_t)(aubio_sink_sndfile_do);
163    s->s_do_multi = (aubio_sink_do_multi_t)(aubio_sink_sndfile_do_multi);
164    s->s_preset_samplerate = (aubio_sink_preset_samplerate_t)(aubio_sink_sndfile_preset_samplerate);
165    s->s_preset_channels = (aubio_sink_preset_channels_t)(aubio_sink_sndfile_preset_channels);
166    s->s_get_samplerate = (aubio_sink_get_samplerate_t)(aubio_sink_sndfile_get_samplerate);
167    s->s_get_channels = (aubio_sink_get_channels_t)(aubio_sink_sndfile_get_channels);
168    s->s_close = (aubio_sink_close_t)(aubio_sink_sndfile_close);
169    s->s_del = (del_aubio_sink_t)(del_aubio_sink_sndfile);
170    return s;
171  }
172#endif /* HAVE_SNDFILE */
173#ifdef HAVE_WAVWRITE
174  s->sink = (void *)new_aubio_sink_wavwrite(uri, samplerate);
175  if (s->sink) {
176    s->s_do = (aubio_sink_do_t)(aubio_sink_wavwrite_do);
177    s->s_do_multi = (aubio_sink_do_multi_t)(aubio_sink_wavwrite_do_multi);
178    s->s_preset_samplerate = (aubio_sink_preset_samplerate_t)(aubio_sink_wavwrite_preset_samplerate);
179    s->s_preset_channels = (aubio_sink_preset_channels_t)(aubio_sink_wavwrite_preset_channels);
180    s->s_get_samplerate = (aubio_sink_get_samplerate_t)(aubio_sink_wavwrite_get_samplerate);
181    s->s_get_channels = (aubio_sink_get_channels_t)(aubio_sink_wavwrite_get_channels);
182    s->s_close = (aubio_sink_close_t)(aubio_sink_wavwrite_close);
183    s->s_del = (del_aubio_sink_t)(del_aubio_sink_wavwrite);
184    return s;
185  }
186#endif /* HAVE_WAVWRITE */
187#if !defined(HAVE_WAVWRITE) && \
188  !defined(HAVE_SNDFILE) && \
189  !defined(HAVE_SINK_APPLE_AUDIO)
190  AUBIO_ERROR("sink: failed creating '%s' at %dHz (no sink built-in)\n", uri, samplerate);
191#endif
192  AUBIO_FREE(s);
193  return NULL;
194}
195
196void aubio_sink_do(aubio_sink_t * s, fvec_t * write_data, uint_t write) {
197  s->s_do((void *)s->sink, write_data, write);
198}
199
200void aubio_sink_do_multi(aubio_sink_t * s, fmat_t * write_data, uint_t write) {
201  s->s_do_multi((void *)s->sink, write_data, write);
202}
203
204uint_t aubio_sink_preset_samplerate(aubio_sink_t * s, uint_t samplerate) {
205  return s->s_preset_samplerate((void *)s->sink, samplerate);
206}
207
208uint_t aubio_sink_preset_channels(aubio_sink_t * s, uint_t channels) {
209  return s->s_preset_channels((void *)s->sink, channels);
210}
211
212uint_t aubio_sink_get_samplerate(const aubio_sink_t * s) {
213  return s->s_get_samplerate((void *)s->sink);
214}
215
216uint_t aubio_sink_get_channels(const aubio_sink_t * s) {
217  return s->s_get_channels((void *)s->sink);
218}
219
220uint_t aubio_sink_close(aubio_sink_t *s) {
221  return s->s_close((void *)s->sink);
222}
223
224void del_aubio_sink(aubio_sink_t * s) {
225  if (!s) return;
226  s->s_del((void *)s->sink);
227  AUBIO_FREE(s);
228  return;
229}
Note: See TracBrowser for help on using the repository browser.