[FFmpeg-cvslog] r18268 - trunk/libavcodec/interplayvideo.c

reimar subversion
Tue Mar 31 16:04:54 CEST 2009


Author: reimar
Date: Tue Mar 31 16:04:54 2009
New Revision: 18268

Log:
Rearrange how the different cases are checked to reduce the number of
comparisons and allow further simplifications.

Modified:
   trunk/libavcodec/interplayvideo.c

Modified: trunk/libavcodec/interplayvideo.c
==============================================================================
--- trunk/libavcodec/interplayvideo.c	Tue Mar 31 16:00:46 2009	(r18267)
+++ trunk/libavcodec/interplayvideo.c	Tue Mar 31 16:04:54 2009	(r18268)
@@ -386,7 +386,8 @@ static int ipvideo_decode_block_opcode_0
     memcpy(P, s->stream_ptr, 4);
     s->stream_ptr += 4;
 
-    if ((P[0] <= P[1]) && (P[2] <= P[3])) {
+    if (P[0] <= P[1]) {
+        if (P[2] <= P[3]) {
 
         /* 1 of 4 colors for each pixel, need 16 more bytes */
         CHECK_STREAM_PTR(16);
@@ -400,7 +401,7 @@ static int ipvideo_decode_block_opcode_0
             s->pixel_ptr += s->line_inc;
         }
 
-    } else if ((P[0] <= P[1]) && (P[2] > P[3])) {
+        } else {
         uint32_t flags;
 
         /* 1 of 4 colors for each 2x2 block, need 4 more bytes */
@@ -418,7 +419,9 @@ static int ipvideo_decode_block_opcode_0
             s->pixel_ptr += s->stride * 2;
         }
 
-    } else if ((P[0] > P[1]) && (P[2] <= P[3])) {
+        }
+    } else {
+        if (P[2] <= P[3]) {
         uint64_t flags;
 
         /* 1 of 4 colors for each 2x1 block, need 8 more bytes */
@@ -432,8 +435,7 @@ static int ipvideo_decode_block_opcode_0
             }
             s->pixel_ptr += s->stride;
         }
-
-    } else {
+        } else {
         uint64_t flags;
 
         /* 1 of 4 colors for each 1x2 block, need 8 more bytes */
@@ -447,6 +449,7 @@ static int ipvideo_decode_block_opcode_0
             }
             s->pixel_ptr += s->stride * 2;
         }
+        }
     }
 
     /* report success */



More information about the ffmpeg-cvslog mailing list