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) {