Commit d5c16c23 authored by mmu_man's avatar mmu_man

Revert the fixed-size-sample patch as it brokes and others

WTF I thought I had commited this yesterday... was probably too asleep :°)


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@3864 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 793d6c21
...@@ -1247,7 +1247,7 @@ static int mov_read_stsz(MOVContext *c, ByteIOContext *pb, MOV_atom_t atom) ...@@ -1247,7 +1247,7 @@ static int mov_read_stsz(MOVContext *c, ByteIOContext *pb, MOV_atom_t atom)
for(i=0; i<entries; i++) { for(i=0; i<entries; i++) {
sc->sample_sizes[i] = get_be32(pb); sc->sample_sizes[i] = get_be32(pb);
#ifdef DEBUG #ifdef DEBUG
/* av_log(NULL, AV_LOG_DEBUG, "sample_sizes[]=%ld\n", sc->sample_sizes[i]); */ av_log(NULL, AV_LOG_DEBUG, "sample_sizes[]=%ld\n", sc->sample_sizes[i]);
#endif #endif
} }
return 0; return 0;
...@@ -1722,14 +1722,17 @@ static int mov_read_packet(AVFormatContext *s, AVPacket *pkt) ...@@ -1722,14 +1722,17 @@ static int mov_read_packet(AVFormatContext *s, AVPacket *pkt)
#ifdef MOV_SPLIT_CHUNKS #ifdef MOV_SPLIT_CHUNKS
if (mov->partial) { if (mov->partial) {
int idx;
sc = mov->partial; sc = mov->partial;
idx = sc->sample_to_chunk_index; idx = sc->sample_to_chunk_index;
if (idx < 0) return 0; if (idx < 0) return 0;
size = (sc->sample_size)?sc->sample_size:sc->sample_sizes[sc->current_sample]; #ifdef DEBUG
fprintf(stderr, "sc[ffid %d]->sample_size = %d\n", sc->ffindex, sc->sample_size);
#endif
//size = sc->sample_sizes[sc->current_sample];
// that ain't working...
//size = (sc->sample_size)?sc->sample_size:sc->sample_sizes[sc->current_sample];
size = (sc->sample_size > 1)?sc->sample_size:sc->sample_sizes[sc->current_sample];
sc->current_sample++; sc->current_sample++;
sc->left_in_chunk--; sc->left_in_chunk--;
...@@ -1816,6 +1819,7 @@ again: ...@@ -1816,6 +1819,7 @@ again:
#ifdef MOV_SPLIT_CHUNKS #ifdef MOV_SPLIT_CHUNKS
/* split chunks into samples */ /* split chunks into samples */
if (sc->sample_size == 0) {
idx = sc->sample_to_chunk_index; idx = sc->sample_to_chunk_index;
if ((idx + 1 < sc->sample_to_chunk_sz) if ((idx + 1 < sc->sample_to_chunk_sz)
&& (sc->next_chunk >= sc->sample_to_chunk[idx + 1].first)) && (sc->next_chunk >= sc->sample_to_chunk[idx + 1].first))
...@@ -1825,10 +1829,11 @@ again: ...@@ -1825,10 +1829,11 @@ again:
mov->partial = sc; mov->partial = sc;
/* we'll have to get those samples before next chunk */ /* we'll have to get those samples before next chunk */
sc->left_in_chunk = sc->sample_to_chunk[idx].count - 1; sc->left_in_chunk = sc->sample_to_chunk[idx].count - 1;
size = (sc->sample_size)?sc->sample_size:sc->sample_sizes[sc->current_sample]; size = (sc->sample_size > 1)?sc->sample_size:sc->sample_sizes[sc->current_sample];
} }
sc->current_sample++; sc->current_sample++;
}
#endif #endif
readchunk: readchunk:
...@@ -1879,14 +1884,14 @@ readchunk: ...@@ -1879,14 +1884,14 @@ readchunk:
pkt->flags |= PKT_FLAG_KEY; pkt->flags |= PKT_FLAG_KEY;
#ifdef DEBUG #ifdef DEBUG
/*
av_log(NULL, AV_LOG_DEBUG, "Packet (%d, %ld) ", pkt->stream_index, pkt->size); av_log(NULL, AV_LOG_DEBUG, "Packet (%d, %ld) ", pkt->stream_index, pkt->size);
for(i=0; i<8; i++) for(i=0; i<8; i++)
av_log(NULL, AV_LOG_DEBUG, "%02x ", pkt->data[i]); av_log(NULL, AV_LOG_DEBUG, "%02x ", pkt->data[i]);
for(i=0; i<8; i++) for(i=0; i<8; i++)
av_log(NULL, AV_LOG_DEBUG, "%c ", (pkt->data[i]) & 0x7F); av_log(NULL, AV_LOG_DEBUG, "%c ", (pkt->data[i]) & 0x7F);
av_log(NULL, AV_LOG_DEBUG, "\n"); av_log(NULL, AV_LOG_DEBUG, "\n");
*/
#endif #endif
mov->next_chunk_offset = offset + size; mov->next_chunk_offset = offset + size;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment