Octave/sfread.cc : Tweaks.

This commit is contained in:
Erik de Castro Lopo 2007-08-24 20:20:03 +10:00
parent 210fa2ced1
commit 4996cb91a7

View File

@ -16,12 +16,12 @@
** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
//#include <cstdio>
#include <octave/oct.h>
#include "sndfile.h"
#define FOUR_GIG (0x100000000LL)
#define BUFFER_FRAMES 8192
DEFUN_DLD (sfread, args, nargout , "\
-*- texinfo -*-\n\
@ -30,8 +30,8 @@ Read a sound file from disk using libsndfile.\n\
\n\
@seealso{wavread}\n\
@end deftypefn\n\
") {
SNDFILE * file ;
")
{ SNDFILE * file ;
SF_INFO sfinfo ;
octave_value_list retval ;
@ -54,7 +54,7 @@ Read a sound file from disk using libsndfile.\n\
} ;
if (sfinfo.frames > FOUR_GIG)
printf ("This is a really huge file (%d Meg).\nYou may run out of memory trying to load it.\n", sfinfo.frames / (1024 * 1024)) ;
printf ("This is a really huge file (%lld frames).\nYou may run out of memory trying to load it.\n", sfinfo.frames) ;
dim_vector dim = dim_vector () ;
dim.resize (2) ;
@ -62,12 +62,12 @@ Read a sound file from disk using libsndfile.\n\
dim (1) = sfinfo.channels ;
NDArray out = NDArray (dim, 0.0) ;
float buffer [4096 * sfinfo.channels] ;
float buffer [BUFFER_FRAMES * sfinfo.channels] ;
int readcount ;
sf_count_t total = 0 ;
do
{ readcount = sf_read_float (file, buffer, 4096) ;
{ readcount = sf_read_float (file, buffer, BUFFER_FRAMES) ;
/* Make sure we don't read more frames than we allocated. */
if (total + readcount > sfinfo.frames)