aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec/audioconvert.c
diff options
context:
space:
mode:
authorPeter Ross <pross@xvid.org>2008-07-31 12:55:06 +0000
committerPeter Ross <pross@xvid.org>2008-07-31 12:55:06 +0000
commitc2b28bb9756403d54b8be8c4556354f378c815b4 (patch)
tree17e1e92195cdb2dd939c20110ae79af28c694773 /libavcodec/audioconvert.c
parentbbdf87285aa16092e089d0205fb8a542f20cfe49 (diff)
downloadffmpeg-c2b28bb9756403d54b8be8c4556354f378c815b4.tar.gz
Add sample format support functions: avcodec_get_sample_fmt_name(), avcodec_get_sample_fmt(), avcodec_sample_fmt_string()
Originally committed as revision 14484 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/audioconvert.c')
-rw-r--r--libavcodec/audioconvert.c44
1 files changed, 43 insertions, 1 deletions
diff --git a/libavcodec/audioconvert.c b/libavcodec/audioconvert.c
index 4c021219f0..6f00af49f9 100644
--- a/libavcodec/audioconvert.c
+++ b/libavcodec/audioconvert.c
@@ -25,7 +25,49 @@
* @author Michael Niedermayer <michaelni@gmx.at>
*/
-#include "avcodec.h"
+#include "audioconvert.h"
+
+typedef struct SampleFmtInfo {
+ const char *name;
+ int bits;
+} SampleFmtInfo;
+
+/** this table gives more information about formats */
+static const SampleFmtInfo sample_fmt_info[SAMPLE_FMT_NB] = {
+ [SAMPLE_FMT_U8] = { .name = "u8", .bits = 8 },
+ [SAMPLE_FMT_S16] = { .name = "s16", .bits = 16 },
+ [SAMPLE_FMT_S24] = { .name = "s24", .bits = 24 },
+ [SAMPLE_FMT_S32] = { .name = "s32", .bits = 32 },
+ [SAMPLE_FMT_FLT] = { .name = "flt", .bits = 32 }
+};
+
+const char *avcodec_get_sample_fmt_name(int sample_fmt)
+{
+ if (sample_fmt < 0 || sample_fmt >= SAMPLE_FMT_NB)
+ return NULL;
+ return sample_fmt_info[sample_fmt].name;
+}
+
+enum SampleFormat avcodec_get_sample_fmt(const char* name)
+{
+ int i;
+
+ for (i=0; i < SAMPLE_FMT_NB; i++)
+ if (!strcmp(sample_fmt_info[i].name, name))
+ return i;
+ return SAMPLE_FMT_NONE;
+}
+
+void avcodec_sample_fmt_string (char *buf, int buf_size, int sample_fmt)
+{
+ /* print header */
+ if (sample_fmt < 0)
+ snprintf (buf, buf_size, "name " " depth");
+ else if (sample_fmt < SAMPLE_FMT_NB) {
+ SampleFmtInfo info= sample_fmt_info[sample_fmt];
+ snprintf (buf, buf_size, "%-6s" " %2d ", info.name, info.bits);
+ }
+}
int av_audio_convert(void *maybe_dspcontext_or_something_av_convert_specific,
void *out[6], int out_stride[6], enum SampleFormat out_fmt,