simplify
[libav.git] / libavutil / intfloat_readwrite.c
index 6450de1..b429fe9 100644 (file)
@@ -43,7 +43,7 @@ double av_ext2dbl(const AVExtFloat ext){
     int e, i;
 
     for (i = 0; i < 8; i++)
-        m |= (uint64_t)ext.mantissa[i]<<(56-(i<<3));
+        m = (m<<8) + ext.mantissa[i];
     e = (((int)ext.exponent[0]&0x7f)<<8) | ext.exponent[1];
     if (e == 0x7fff && m)
         return 0.0/0.0;
@@ -51,7 +51,7 @@ double av_ext2dbl(const AVExtFloat ext){
                              * mantissa bit is written as opposed to the
                              * single and double precision formats */
     if (ext.exponent[0]&0x80)
-        return ldexp(-m, e);
+        m= -m;
     return ldexp(m, e);
 }
 
@@ -72,7 +72,7 @@ int32_t av_flt2int(float d){
 }
 
 AVExtFloat av_dbl2ext(double d){
-    struct AVExtFloat ext;
+    struct AVExtFloat ext= {{0}};
     int e, i; double f; uint64_t m;
 
     f = fabs(frexp(d, &e));
@@ -83,11 +83,8 @@ AVExtFloat av_dbl2ext(double d){
         m = (uint64_t)ldexp(f, 64);
         for (i=0; i < 8; i++)
             ext.mantissa[i] = m>>(56-(i<<3));
-    } else if (f == 0.0) {
-        memset (&ext, 0, 10);
-    } else {
+    } else if (f != 0.0) {
         ext.exponent[0] = 0x7f; ext.exponent[1] = 0xff;
-        memset (&ext.mantissa, 0, 8);
         if (f != 1/0.0)
             ext.mantissa[0] = ~0;
     }