annotate src/libsndfile-1.0.27/programs/sndfile-concat.c @ 125:cd6cdf86811e

Current libsndfile source
author Chris Cannam <cannam@all-day-breakfast.com>
date Tue, 18 Oct 2016 13:22:47 +0100
parents
children
rev   line source
cannam@125 1 /*
cannam@125 2 ** Copyright (C) 1999-2014 Erik de Castro Lopo <erikd@mega-nerd.com>
cannam@125 3 **
cannam@125 4 ** All rights reserved.
cannam@125 5 **
cannam@125 6 ** Redistribution and use in source and binary forms, with or without
cannam@125 7 ** modification, are permitted provided that the following conditions are
cannam@125 8 ** met:
cannam@125 9 **
cannam@125 10 ** * Redistributions of source code must retain the above copyright
cannam@125 11 ** notice, this list of conditions and the following disclaimer.
cannam@125 12 ** * Redistributions in binary form must reproduce the above copyright
cannam@125 13 ** notice, this list of conditions and the following disclaimer in
cannam@125 14 ** the documentation and/or other materials provided with the
cannam@125 15 ** distribution.
cannam@125 16 ** * Neither the author nor the names of any contributors may be used
cannam@125 17 ** to endorse or promote products derived from this software without
cannam@125 18 ** specific prior written permission.
cannam@125 19 **
cannam@125 20 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
cannam@125 21 ** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
cannam@125 22 ** TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
cannam@125 23 ** PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
cannam@125 24 ** CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
cannam@125 25 ** EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
cannam@125 26 ** PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
cannam@125 27 ** OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
cannam@125 28 ** WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
cannam@125 29 ** OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
cannam@125 30 ** ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
cannam@125 31 */
cannam@125 32
cannam@125 33 #include <stdio.h>
cannam@125 34 #include <stdlib.h>
cannam@125 35 #include <string.h>
cannam@125 36 #include <ctype.h>
cannam@125 37
cannam@125 38 #include <sndfile.h>
cannam@125 39
cannam@125 40 #include "common.h"
cannam@125 41
cannam@125 42 #define BUFFER_LEN (1 << 16)
cannam@125 43
cannam@125 44
cannam@125 45 static void concat_data_fp (SNDFILE *wfile, SNDFILE *rofile, int channels) ;
cannam@125 46 static void concat_data_int (SNDFILE *wfile, SNDFILE *rofile, int channels) ;
cannam@125 47
cannam@125 48 static void
cannam@125 49 usage_exit (const char *progname)
cannam@125 50 {
cannam@125 51 printf ("\nUsage : %s <infile1> <infile2> ... <outfile>\n\n", progname) ;
cannam@125 52 puts (
cannam@125 53 " Create a new output file <outfile> containing the concatenated\n"
cannam@125 54 " audio data from froms <infile1> <infile2> ....\n"
cannam@125 55 "\n"
cannam@125 56 " The joined file will be encoded in the same format as the data\n"
cannam@125 57 " in infile1, with all the data in subsequent files automatically\n"
cannam@125 58 " converted to the correct encoding.\n"
cannam@125 59 "\n"
cannam@125 60 " The only restriction is that the two files must have the same\n"
cannam@125 61 " number of channels.\n"
cannam@125 62 ) ;
cannam@125 63
cannam@125 64 exit (1) ;
cannam@125 65 } /* usage_exit */
cannam@125 66
cannam@125 67 int
cannam@125 68 main (int argc, char *argv [])
cannam@125 69 { const char *progname, *outfilename ;
cannam@125 70 SNDFILE *outfile, **infiles ;
cannam@125 71 SF_INFO sfinfo_out, sfinfo_in ;
cannam@125 72 void (*func) (SNDFILE*, SNDFILE*, int) ;
cannam@125 73 int k ;
cannam@125 74
cannam@125 75 progname = program_name (argv [0]) ;
cannam@125 76
cannam@125 77 if (argc < 4)
cannam@125 78 usage_exit (progname) ;
cannam@125 79
cannam@125 80 argv ++ ;
cannam@125 81 argc -- ;
cannam@125 82
cannam@125 83 argc -- ;
cannam@125 84 outfilename = argv [argc] ;
cannam@125 85
cannam@125 86 if ((infiles = calloc (argc, sizeof (SNDFILE*))) == NULL)
cannam@125 87 { printf ("\nError : Malloc failed.\n\n") ;
cannam@125 88 exit (1) ;
cannam@125 89 } ;
cannam@125 90
cannam@125 91 memset (&sfinfo_in, 0, sizeof (sfinfo_in)) ;
cannam@125 92
cannam@125 93 if ((infiles [0] = sf_open (argv [0], SFM_READ, &sfinfo_in)) == NULL)
cannam@125 94 { printf ("\nError : failed to open file '%s'.\n\n", argv [0]) ;
cannam@125 95 exit (1) ;
cannam@125 96 } ;
cannam@125 97
cannam@125 98 sfinfo_out = sfinfo_in ;
cannam@125 99
cannam@125 100 for (k = 1 ; k < argc ; k++)
cannam@125 101 { if ((infiles [k] = sf_open (argv [k], SFM_READ, &sfinfo_in)) == NULL)
cannam@125 102 { printf ("\nError : failed to open file '%s'.\n\n", argv [k]) ;
cannam@125 103 exit (1) ;
cannam@125 104 } ;
cannam@125 105
cannam@125 106 if (sfinfo_in.channels != sfinfo_out.channels)
cannam@125 107 { printf ("\nError : File '%s' has %d channels (should have %d).\n\n", argv [k], sfinfo_in.channels, sfinfo_out.channels) ;
cannam@125 108 exit (1) ;
cannam@125 109 } ;
cannam@125 110 } ;
cannam@125 111
cannam@125 112 if ((outfile = sf_open (outfilename, SFM_WRITE, &sfinfo_out)) == NULL)
cannam@125 113 { printf ("\nError : Not able to open input file %s.\n", outfilename) ;
cannam@125 114 puts (sf_strerror (NULL)) ;
cannam@125 115 exit (1) ;
cannam@125 116 } ;
cannam@125 117
cannam@125 118 if ((sfinfo_out.format & SF_FORMAT_SUBMASK) == SF_FORMAT_DOUBLE ||
cannam@125 119 (sfinfo_out.format & SF_FORMAT_SUBMASK) == SF_FORMAT_FLOAT)
cannam@125 120 func = concat_data_fp ;
cannam@125 121 else
cannam@125 122 func = concat_data_int ;
cannam@125 123
cannam@125 124 for (k = 0 ; k < argc ; k++)
cannam@125 125 { func (outfile, infiles [k], sfinfo_out.channels) ;
cannam@125 126 sf_close (infiles [k]) ;
cannam@125 127 } ;
cannam@125 128
cannam@125 129 sf_close (outfile) ;
cannam@125 130 free (infiles) ;
cannam@125 131
cannam@125 132 return 0 ;
cannam@125 133 } /* main */
cannam@125 134
cannam@125 135 static void
cannam@125 136 concat_data_fp (SNDFILE *wfile, SNDFILE *rofile, int channels)
cannam@125 137 { static double data [BUFFER_LEN] ;
cannam@125 138 int frames, readcount ;
cannam@125 139
cannam@125 140 frames = BUFFER_LEN / channels ;
cannam@125 141 readcount = frames ;
cannam@125 142
cannam@125 143 sf_seek (wfile, 0, SEEK_END) ;
cannam@125 144
cannam@125 145 while (readcount > 0)
cannam@125 146 { readcount = sf_readf_double (rofile, data, frames) ;
cannam@125 147 sf_writef_double (wfile, data, readcount) ;
cannam@125 148 } ;
cannam@125 149
cannam@125 150 return ;
cannam@125 151 } /* concat_data_fp */
cannam@125 152
cannam@125 153 static void
cannam@125 154 concat_data_int (SNDFILE *wfile, SNDFILE *rofile, int channels)
cannam@125 155 { static int data [BUFFER_LEN] ;
cannam@125 156 int frames, readcount ;
cannam@125 157
cannam@125 158 frames = BUFFER_LEN / channels ;
cannam@125 159 readcount = frames ;
cannam@125 160
cannam@125 161 sf_seek (wfile, 0, SEEK_END) ;
cannam@125 162
cannam@125 163 while (readcount > 0)
cannam@125 164 { readcount = sf_readf_int (rofile, data, frames) ;
cannam@125 165 sf_writef_int (wfile, data, readcount) ;
cannam@125 166 } ;
cannam@125 167
cannam@125 168 return ;
cannam@125 169 } /* concat_data_int */
cannam@125 170