1 /* 2 * Copyright (C) 2012 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 #ifndef __AUDIO_UTIL_SNDFILE_H 18 #define __AUDIO_UTIL_SNDFILE_H 19 20 // This is a C library for reading and writing PCM .wav files. It is 21 // influenced by other libraries such as libsndfile and audiofile, except is 22 // much smaller and has an Apache 2.0 license. 23 // The API should be familiar to clients of similar libraries, but there is 24 // no guarantee that it will stay exactly source-code compatible with other libraries. 25 26 #include <stdio.h> 27 #include <sys/cdefs.h> 28 29 /** \cond */ 30 __BEGIN_DECLS 31 /** \endcond */ 32 33 // visible to clients 34 typedef int sf_count_t; 35 36 typedef struct { 37 sf_count_t frames; 38 int samplerate; 39 int channels; 40 int format; 41 } SF_INFO; 42 43 // opaque to clients 44 typedef struct SNDFILE_ SNDFILE; 45 46 // Access modes 47 #define SFM_READ 1 48 #define SFM_WRITE 2 49 50 // Format 51 #define SF_FORMAT_TYPEMASK 1 52 #define SF_FORMAT_WAV 1 53 #define SF_FORMAT_SUBMASK 14 54 #define SF_FORMAT_PCM_16 2 55 #define SF_FORMAT_PCM_U8 4 56 #define SF_FORMAT_FLOAT 6 57 #define SF_FORMAT_PCM_32 8 58 #define SF_FORMAT_PCM_24 10 59 60 /** Open stream */ 61 SNDFILE *sf_open(const char *path, int mode, SF_INFO *info); 62 63 /** Close stream */ 64 void sf_close(SNDFILE *handle); 65 66 /** 67 * Read interleaved frames 68 * \return actual number of frames read 69 */ 70 sf_count_t sf_readf_short(SNDFILE *handle, short *ptr, sf_count_t desired); 71 sf_count_t sf_readf_float(SNDFILE *handle, float *ptr, sf_count_t desired); 72 sf_count_t sf_readf_int(SNDFILE *handle, int *ptr, sf_count_t desired); 73 74 /** 75 * Write interleaved frames 76 * \return actual number of frames written 77 */ 78 sf_count_t sf_writef_short(SNDFILE *handle, const short *ptr, sf_count_t desired); 79 sf_count_t sf_writef_float(SNDFILE *handle, const float *ptr, sf_count_t desired); 80 sf_count_t sf_writef_int(SNDFILE *handle, const int *ptr, sf_count_t desired); 81 82 /** \cond */ 83 __END_DECLS 84 /** \endcond */ 85 86 #endif /* __AUDIO_UTIL_SNDFILE_H */ 87