tests/src/io/test-source*.c: always get samplerate
[aubio.git] / tests / src / io / test-source_sndfile.c
1 #define AUBIO_UNSTABLE 1
2 #include <aubio.h>
3 #include "utils_tests.h"
4 #include "config.h"
5
6 // this file uses the unstable aubio api, please use aubio_source instead
7 // see src/io/source.h and tests/src/source/test-source.c
8
9 int main (int argc, char **argv)
10 {
11   uint_t err = 0;
12   if (argc < 2) {
13     err = 2;
14     PRINT_ERR("not enough arguments\n");
15     PRINT_MSG("read a wave file as a mono vector\n");
16     PRINT_MSG("usage: %s <source_path> [samplerate] [hop_size]\n", argv[0]);
17     PRINT_MSG("examples:\n");
18     PRINT_MSG(" - read file.wav at original samplerate\n");
19     PRINT_MSG("       %s file.wav\n", argv[0]);
20     PRINT_MSG(" - read file.wav at 32000Hz\n");
21     PRINT_MSG("       %s file.aif 32000\n", argv[0]);
22     PRINT_MSG(" - read file.wav at original samplerate with 4096 blocks\n");
23     PRINT_MSG("       %s file.wav 0 4096 \n", argv[0]);
24     return err;
25   }
26
27 #ifdef HAVE_SNDFILE
28   uint_t samplerate = 0;
29   uint_t hop_size = 256;
30   uint_t n_frames = 0, read = 0;
31   if ( argc == 3 ) samplerate = atoi(argv[2]);
32   if ( argc == 4 ) hop_size = atoi(argv[3]);
33
34   char_t *source_path = argv[1];
35
36
37   aubio_source_sndfile_t * s =
38     new_aubio_source_sndfile(source_path, samplerate, hop_size);
39   if (!s) { err = 1; goto beach; }
40   fvec_t *vec = new_fvec(hop_size);
41
42   samplerate = aubio_source_sndfile_get_samplerate(s);
43
44   do {
45     aubio_source_sndfile_do(s, vec, &read);
46     fvec_print (vec);
47     n_frames += read;
48   } while ( read == hop_size );
49
50   PRINT_MSG("read %d frames at %dHz (%d blocks) from %s\n", n_frames, samplerate,
51     n_frames / hop_size, source_path);
52
53   del_fvec (vec);
54   del_aubio_source_sndfile (s);
55 beach:
56 #else
57   err = 3;
58   PRINT_ERR("aubio was not compiled with aubio_source_sndfile\n");
59 #endif /* HAVE_SNDFILE */
60   return err;
61 }