# HG changeset patch # User melanson # Date 1014051016 0 # Node ID f3562b5411f9e25ea6d0f9a8321f117da4bb3a7b # Parent 2ae67be77ec700242faaad80e8270e902b481a1c fixed RoQ file detection and FPS determination (maybe) diff -r 2ae67be77ec7 -r f3562b5411f9 libmpdemux/demux_roq.c --- a/libmpdemux/demux_roq.c Mon Feb 18 11:38:41 2002 +0000 +++ b/libmpdemux/demux_roq.c Mon Feb 18 16:50:16 2002 +0000 @@ -26,8 +26,6 @@ #define CHUNK_TYPE_AUDIO 0 #define CHUNK_TYPE_VIDEO 1 -#define RoQ_FPS 30 - typedef struct roq_chunk_t { int chunk_type; @@ -49,14 +47,14 @@ // Check if a stream qualifies as a RoQ file based on the magic numbers // at the start of the file: -// 84 10 FF FF FF FF 1E 00 +// 84 10 FF FF FF FF xx xx int roq_check_file(demuxer_t *demuxer) { stream_reset(demuxer->stream); stream_seek(demuxer->stream, 0); if ((stream_read_dword(demuxer->stream) == 0x8410FFFF) && - (stream_read_dword(demuxer->stream) == 0xFFFF1E00)) + ((stream_read_dword(demuxer->stream) & 0xFFFF0000) == 0xFFFF0000)) return 1; else return 0; @@ -103,6 +101,7 @@ int chunk_arg; int last_chunk_id = 0; int largest_audio_chunk = 0; + int fps; roq_data->total_chunks = 0; roq_data->current_chunk = 0; @@ -110,7 +109,8 @@ roq_data->chunks = NULL; // position the stream and start traversing - stream_seek(demuxer->stream, 8); + stream_seek(demuxer->stream, 6); + fps = stream_read_word_le(demuxer->stream); while (!stream_eof(demuxer->stream)) { chunk_id = stream_read_word_le(demuxer->stream); @@ -144,7 +144,7 @@ sh_video->format = mmioFOURCC('R', 'o', 'Q', 'V'); // constant frame rate - sh_video->fps = 1000 / RoQ_FPS; + sh_video->fps = fps; sh_video->frametime = 1 / sh_video->fps; } } @@ -240,7 +240,5 @@ stream_reset(demuxer->stream); -sh_audio = NULL; - return demuxer; }