# HG changeset patch # User michael # Date 1098988951 0 # Node ID cb3f0954e9820596cccd200cf82fd040679558e8 # Parent 5690ce009ebd075804311bb7f13bca681497f8dc cleanup diff -r 5690ce009ebd -r cb3f0954e982 h261.c --- a/h261.c Thu Oct 28 18:17:48 2004 +0000 +++ b/h261.c Thu Oct 28 18:42:31 2004 +0000 @@ -325,8 +325,7 @@ i = 1; } else if((block[0]==1 || block[0] == -1) && (s->block_last_index[n] > -1)){ //special case - put_bits(&s->pb,1,1); - put_bits(&s->pb,1,block[0]>0 ? 0 : 1 ); + put_bits(&s->pb,2,block[0]>0 ? 2 : 3 ); i = 1; } else { i = 0; @@ -354,12 +353,7 @@ if (code == rl->n) { put_bits(&s->pb, 6, run); assert(slevel != 0); - if(slevel < -127){ - slevel = -127; - } - else if(slevel > 127){ - slevel = 127; - } + assert(level <= 127); put_bits(&s->pb, 8, slevel & 0xff); } else { put_bits(&s->pb, 1, sign); @@ -742,7 +736,7 @@ /* escape */ // The remaining combinations of (run, level) are encoded with a 20-bit word consisting of 6 bits escape, 6 bits run and 8 bits level. run = get_bits(&s->gb, 6); - level = (int8_t)get_bits(&s->gb, 8); + level = get_sbits(&s->gb, 8); }else if(code == 0){ break; }else{