Chris@0: /* Chris@0: ** Copyright (C) 1999-2011 Erik de Castro Lopo Chris@0: ** Chris@0: ** This program is free software; you can redistribute it and/or modify Chris@0: ** it under the terms of the GNU General Public License as published by Chris@0: ** the Free Software Foundation; either version 2 of the License, or Chris@0: ** (at your option) any later version. Chris@0: ** Chris@0: ** This program is distributed in the hope that it will be useful, Chris@0: ** but WITHOUT ANY WARRANTY; without even the implied warranty of Chris@0: ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the Chris@0: ** GNU General Public License for more details. Chris@0: ** Chris@0: ** You should have received a copy of the GNU General Public License Chris@0: ** along with this program; if not, write to the Free Software Chris@0: ** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. Chris@0: */ Chris@0: Chris@0: #include "sfconfig.h" Chris@0: Chris@0: #include Chris@0: #include Chris@0: Chris@0: #if HAVE_UNISTD_H Chris@0: #include Chris@0: #endif Chris@0: Chris@0: #if (HAVE_DECL_S_IRGRP == 0) Chris@0: #include Chris@0: #endif Chris@0: Chris@0: #include Chris@0: #include Chris@0: #include Chris@0: #include Chris@0: #include Chris@0: Chris@0: #include Chris@0: Chris@0: #include "utils.h" Chris@0: Chris@0: #define DATA_LENGTH (512) Chris@0: Chris@0: static void write_file_at_end (int fd, int filetype, int channels, int file_num) ; Chris@0: Chris@0: static void multi_file_test (const char *filename, int *formats, int format_count) ; Chris@0: Chris@0: static short data [DATA_LENGTH] ; Chris@0: Chris@0: static int wav_formats [] = Chris@0: { SF_FORMAT_WAV | SF_FORMAT_PCM_16, Chris@0: SF_FORMAT_WAV | SF_FORMAT_PCM_24, Chris@0: SF_FORMAT_WAV | SF_FORMAT_ULAW, Chris@0: SF_FORMAT_WAV | SF_FORMAT_ALAW, Chris@0: /* Lite remove start */ Chris@0: SF_FORMAT_WAV | SF_FORMAT_IMA_ADPCM, Chris@0: SF_FORMAT_WAV | SF_FORMAT_MS_ADPCM, Chris@0: /* Lite remove end */ Chris@0: /*-SF_FORMAT_WAV | SF_FORMAT_GSM610 Doesn't work yet. -*/ Chris@0: } ; Chris@0: Chris@0: static int aiff_formats [] = Chris@0: { SF_FORMAT_AIFF | SF_FORMAT_PCM_16, Chris@0: SF_FORMAT_AIFF | SF_FORMAT_PCM_24, Chris@0: SF_FORMAT_AIFF | SF_FORMAT_ULAW, Chris@0: SF_FORMAT_AIFF | SF_FORMAT_ALAW Chris@0: } ; Chris@0: Chris@0: static int au_formats [] = Chris@0: { SF_FORMAT_AU | SF_FORMAT_PCM_16, Chris@0: SF_FORMAT_AU | SF_FORMAT_PCM_24, Chris@0: SF_FORMAT_AU | SF_FORMAT_ULAW, Chris@0: SF_FORMAT_AU | SF_FORMAT_ALAW Chris@0: } ; Chris@0: Chris@0: static int verbose = SF_FALSE ; Chris@0: Chris@0: int Chris@0: main (int argc, char **argv) Chris@0: { int do_all = 0 ; Chris@0: int test_count = 0 ; Chris@0: Chris@0: if (argc == 3 && strcmp (argv [2], "-v") == 0) Chris@0: { verbose = SF_TRUE ; Chris@0: argc -- ; Chris@0: } ; Chris@0: Chris@0: if (argc != 2) Chris@0: { printf ("Usage : %s \n", argv [0]) ; Chris@0: printf (" Where is one of the following:\n") ; Chris@0: printf (" wav - test WAV file functions (little endian)\n") ; Chris@0: printf (" aiff - test AIFF file functions (big endian)\n") ; Chris@0: printf (" au - test AU file functions\n") ; Chris@0: #if 0 Chris@0: printf (" svx - test 8SVX/16SV file functions\n") ; Chris@0: printf (" nist - test NIST Sphere file functions\n") ; Chris@0: printf (" ircam - test IRCAM file functions\n") ; Chris@0: printf (" voc - Create Voice file functions\n") ; Chris@0: printf (" w64 - Sonic Foundry's W64 file functions\n") ; Chris@0: #endif Chris@0: printf (" all - perform all tests\n") ; Chris@0: exit (1) ; Chris@0: } ; Chris@0: Chris@0: do_all = !strcmp (argv [1], "all") ; Chris@0: Chris@0: if (do_all || ! strcmp (argv [1], "wav")) Chris@0: { multi_file_test ("multi_wav.dat", wav_formats, ARRAY_LEN (wav_formats)) ; Chris@0: test_count++ ; Chris@0: } ; Chris@0: Chris@0: if (do_all || ! strcmp (argv [1], "aiff")) Chris@0: { multi_file_test ("multi_aiff.dat", aiff_formats, ARRAY_LEN (aiff_formats)) ; Chris@0: test_count++ ; Chris@0: } ; Chris@0: Chris@0: if (do_all || ! strcmp (argv [1], "au")) Chris@0: { multi_file_test ("multi_au.dat", au_formats, ARRAY_LEN (au_formats)) ; Chris@0: test_count++ ; Chris@0: } ; Chris@0: Chris@0: return 0 ; Chris@0: } /* main */ Chris@0: Chris@0: /*====================================================================================== Chris@0: */ Chris@0: Chris@0: static void Chris@0: multi_file_test (const char *filename, int *formats, int format_count) Chris@0: { SNDFILE *sndfile ; Chris@0: SF_INFO sfinfo ; Chris@0: SF_EMBED_FILE_INFO embed_info ; Chris@0: sf_count_t filelen ; Chris@0: int fd, k, file_count = 0 ; Chris@0: Chris@0: print_test_name ("multi_file_test", filename) ; Chris@0: Chris@0: unlink (filename) ; Chris@0: Chris@0: if ((fd = open (filename, O_RDWR | O_CREAT, S_IRUSR | S_IWUSR)) < 0) Chris@0: { printf ("\n\nLine %d: open failed : %s\n", __LINE__, strerror (errno)) ; Chris@0: exit (1) ; Chris@0: } ; Chris@0: Chris@0: k = write (fd, "1234", 4) ; Chris@0: Chris@0: for (k = 0 ; k < format_count ; k++) Chris@0: write_file_at_end (fd, formats [k], 2, k) ; Chris@0: Chris@0: filelen = file_length_fd (fd) ; Chris@0: Chris@0: embed_info.offset = 4 ; Chris@0: embed_info.length = 0 ; Chris@0: Chris@0: Chris@0: for (file_count = 1 ; embed_info.offset + embed_info.length < filelen ; file_count ++) Chris@0: { Chris@0: if (verbose) Chris@0: { puts ("\n------------------------------------") ; Chris@0: printf ("This offset : %ld\n", SF_COUNT_TO_LONG (embed_info.offset + embed_info.length)) ; Chris@0: } ; Chris@0: Chris@0: if (lseek (fd, embed_info.offset + embed_info.length, SEEK_SET) < 0) Chris@0: { printf ("\n\nLine %d: lseek failed : %s\n", __LINE__, strerror (errno)) ; Chris@0: exit (1) ; Chris@0: } ; Chris@0: Chris@0: memset (&sfinfo, 0, sizeof (sfinfo)) ; Chris@0: if ((sndfile = sf_open_fd (fd, SFM_READ, &sfinfo, SF_FALSE)) == NULL) Chris@0: { printf ("\n\nLine %d: sf_open_fd failed\n", __LINE__) ; Chris@0: printf ("Embedded file number : %d offset : %ld\n", file_count, SF_COUNT_TO_LONG (embed_info.offset)) ; Chris@0: puts (sf_strerror (sndfile)) ; Chris@0: dump_log_buffer (sndfile) ; Chris@0: exit (1) ; Chris@0: } ; Chris@0: Chris@0: sf_command (sndfile, SFC_GET_EMBED_FILE_INFO, &embed_info, sizeof (embed_info)) ; Chris@0: Chris@0: sf_close (sndfile) ; Chris@0: Chris@0: if (verbose) Chris@0: printf ("\nNext offset : %ld\nNext length : %ld\n", SF_COUNT_TO_LONG (embed_info.offset), SF_COUNT_TO_LONG (embed_info.length)) ; Chris@0: } ; Chris@0: Chris@0: file_count -- ; Chris@0: Chris@0: if (file_count != format_count) Chris@0: { printf ("\n\nLine %d: file count (%d) not equal to %d.\n\n", __LINE__, file_count, format_count) ; Chris@0: printf ("Embedded file number : %d\n", file_count) ; Chris@0: exit (1) ; Chris@0: } ; Chris@0: Chris@0: close (fd) ; Chris@0: unlink (filename) ; Chris@0: printf ("ok\n") ; Chris@0: Chris@0: return ; Chris@0: } /* multi_file_test */ Chris@0: Chris@0: /*====================================================================================== Chris@0: */ Chris@0: Chris@0: static void Chris@0: write_file_at_end (int fd, int filetype, int channels, int file_num) Chris@0: { SNDFILE *sndfile ; Chris@0: SF_INFO sfinfo ; Chris@0: Chris@0: int frames, k ; Chris@0: Chris@0: lseek (fd, 0, SEEK_END) ; Chris@0: Chris@0: for (k = 0 ; k < DATA_LENGTH ; k++) Chris@0: data [k] = k ; Chris@0: Chris@0: frames = DATA_LENGTH / channels ; Chris@0: Chris@0: sfinfo.format = filetype ; Chris@0: sfinfo.channels = channels ; Chris@0: sfinfo.samplerate = 44100 ; Chris@0: Chris@0: if ((sndfile = sf_open_fd (fd, SFM_WRITE, &sfinfo, SF_FALSE)) == NULL) Chris@0: { printf ("\n\nLine %d: sf_open_fd failed\n", __LINE__) ; Chris@0: printf ("Embedded file number : %d\n", file_num) ; Chris@0: puts (sf_strerror (sndfile)) ; Chris@0: dump_log_buffer (sndfile) ; Chris@0: exit (1) ; Chris@0: } ; Chris@0: Chris@0: if (sf_writef_short (sndfile, data, frames) != frames) Chris@0: { printf ("\n\nLine %d: short write\n", __LINE__) ; Chris@0: printf ("Embedded file number : %d\n", file_num) ; Chris@0: exit (1) ; Chris@0: } ; Chris@0: Chris@0: sf_close (sndfile) ; Chris@0: } /* write_file_at_end */ Chris@0: