Mercurial > libavcodec.hg
changeset 3812:52ff3a5d161e libavcodec
Original Commit: r6 | ods15 | 2006-09-16 20:36:31 +0300 (Sat, 16 Sep 2006) | 2 lines
add correct and working put_float ...
author | ods15 |
---|---|
date | Mon, 02 Oct 2006 05:55:20 +0000 |
parents | 9f6acced986e |
children | 95b70f8bc29e |
files | vorbis_enc.c |
diffstat | 1 files changed, 7 insertions(+), 1 deletions(-) [+] |
line wrap: on
line diff
--- a/vorbis_enc.c Mon Oct 02 05:55:18 2006 +0000 +++ b/vorbis_enc.c Mon Oct 02 05:55:20 2006 +0000 @@ -67,7 +67,13 @@ } static void put_float(PutBitContext * pb, float f) { - put_bits(pb, 32, *(uint32_t*)&f); + int exp, mant; + uint32_t res = 0; + mant = (int)ldexp(frexp(f, &exp), 20); + exp += 788 - 20; + if (mant < 0) { res |= (1 << 31); mant = -mant; } + res |= mant | (exp << 21); + put_bits(pb, 32, res); } static void put_codebook_header(PutBitContext * pb, codebook_t * cb) {