# HG changeset patch # User michael # Date 1141226513 0 # Node ID c21f07d85158f379aa264d7e2aada749baac060b # Parent 55519fa957c335a402559aae7b1ad03370654fca 10l forgot to set packet_size diff -r 55519fa957c3 -r c21f07d85158 avidec.c --- a/avidec.c Wed Mar 01 12:04:22 2006 +0000 +++ b/avidec.c Wed Mar 01 15:21:53 2006 +0000 @@ -34,7 +34,7 @@ int scale; int rate; - int sample_size; /* audio only data */ + int sample_size; /* size of one sample (or packet) (in the rate/scale sense) in bytes */ int start; int64_t cum_len; /* temporary storage (used during seek) */ @@ -474,8 +474,11 @@ url_fseek(&s->pb, pos + 8, SEEK_SET); // av_log(NULL, AV_LOG_DEBUG, "pos=%Ld\n", pos); + assert(best_ast->remaining <= best_ast->packet_size); + avi->stream_index= best_stream_index; if(!best_ast->remaining) + best_ast->packet_size= best_ast->remaining= best_st->index_entries[i].size; } } @@ -509,7 +512,7 @@ // pkt->dts += ast->start; if(ast->sample_size) pkt->dts /= ast->sample_size; -//av_log(NULL, AV_LOG_DEBUG, "dts:%Ld offset:%d %d/%d smpl_siz:%d base:%d st:%d size:%d\n", pkt->dts, ast->frame_offset, ast->scale, ast->rate, ast->sample_size, AV_TIME_BASE, n, size); +//av_log(NULL, AV_LOG_DEBUG, "dts:%Ld offset:%Ld %d/%d smpl_siz:%d base:%d st:%d size:%d\n", pkt->dts, ast->frame_offset, ast->scale, ast->rate, ast->sample_size, AV_TIME_BASE, avi->stream_index, size); pkt->stream_index = avi->stream_index; if (st->codec->codec_type == CODEC_TYPE_VIDEO) {