# HG changeset patch # User vitor # Date 1220569940 0 # Node ID 315d2a6c6a1ed956616529fa194beaef8ac1a338 # Parent 0253472b1f2503db3f3f881466bc21621e86b908 Simplify mace_decode_frame() diff -r 0253472b1f25 -r 315d2a6c6a1e mace.c --- a/mace.c Thu Sep 04 23:02:08 2008 +0000 +++ b/mace.c Thu Sep 04 23:12:20 2008 +0000 @@ -395,23 +395,26 @@ void *data, int *data_size, const uint8_t *buf, int buf_size) { - short *samples; + short *samples = data; MACEContext *c = avctx->priv_data; + int i; - samples = (short *)data; switch (avctx->codec->id) { case CODEC_ID_MACE3: dprintf(avctx, "mace_decode_frame[3]()"); - Exp1to3(c, buf, samples, buf_size / 2 / avctx->channels, avctx->channels, 1); - if (avctx->channels == 2) - Exp1to3(c, buf, samples+1, buf_size / 2 / 2, 2, 2); + for(i = 0; i < avctx->channels; i++) + Exp1to3(c, buf, samples + i, buf_size / 2 / avctx->channels, + avctx->channels, i + 1); + *data_size = 2 * 3 * buf_size; break; case CODEC_ID_MACE6: dprintf(avctx, "mace_decode_frame[6]()"); - Exp1to6(c, buf, samples, buf_size / avctx->channels, avctx->channels, 1); - if (avctx->channels == 2) - Exp1to6(c, buf, samples+1, buf_size / 2, 2, 2); + + for(i = 0; i < avctx->channels; i++) + Exp1to6(c, buf, samples + i, buf_size / avctx->channels, + avctx->channels, i + 1); + *data_size = 2 * 6 * buf_size; break; default: