summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2003-01-13 02:42:06 +0000
committerarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2003-01-13 02:42:06 +0000
commit1e166db2028c0f27ea32d3c9427f993cc24d85ce (patch)
tree062a78471fa9dfd96dc563945706f4cb0b150539
parent57b2503b004ce37b7de9cc62682dcfd58ff2a33a (diff)
downloadmpv-1e166db2028c0f27ea32d3c9427f993cc24d85ce.tar.bz2
mpv-1e166db2028c0f27ea32d3c9427f993cc24d85ce.tar.xz
patch adds support for MOV-Reference-Files.
it uses d_video queue to store playlist entries as strz. It also makes sure, that unnecessary items like qt5gateQT are removed and that the url/basepath is added to "local files" by Fabian Franz <FabianFranz@gmx.de> git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@8938 b3059339-0415-0410-9bf9-f77b7e298cf2
-rw-r--r--libmpdemux/demux_mov.c24
-rw-r--r--libmpdemux/demuxer.c2
-rw-r--r--mplayer.c56
3 files changed, 77 insertions, 5 deletions
diff --git a/libmpdemux/demux_mov.c b/libmpdemux/demux_mov.c
index 5beb69a9d0..1f2af95c66 100644
--- a/libmpdemux/demux_mov.c
+++ b/libmpdemux/demux_mov.c
@@ -356,6 +356,8 @@ int mov_check_file(demuxer_t* demuxer){
int ref=0;
skipped+=i;
mp_msg(MSGT_DEMUX,MSGL_INFO,"MOV: Reference Media file!!!\n");
+ //set demuxer type to playlist ...
+ demuxer->type=DEMUXER_TYPE_PLAYLIST;
while(i>0){
int len=stream_read_dword(demuxer->stream)-8;
int fcc=stream_read_dword(demuxer->stream);
@@ -369,10 +371,21 @@ int mov_check_file(demuxer_t* demuxer){
int tmp=stream_read_dword(demuxer->stream);
int type=stream_read_dword_le(demuxer->stream);
int slen=stream_read_dword(demuxer->stream);
- char* s=malloc(slen+1);
- stream_read(demuxer->stream,s,slen);
- s[slen]=0;
- mp_msg(MSGT_DEMUX,MSGL_INFO,"REF: [%.4s] %s\n",&type,s);
+ //char* s=malloc(slen+1);
+ //stream_read(demuxer->stream,s,slen);
+
+ //FIXME: also store type & data_rate ?
+ ds_read_packet(demuxer->video,
+ demuxer->stream,
+ slen,
+ 0,
+ stream_tell(demuxer->stream),
+ 0 // no flags
+ );
+ flags|=4;
+ mp_msg(MSGT_DEMUX,MSGL_V,"Added reference to playlist\n");
+ //s[slen]=0;
+ //mp_msg(MSGT_DEMUX,MSGL_INFO,"REF: [%.4s] %s\n",&type,s);
len-=12+slen;i-=12+slen; break;
}
case MOV_FOURCC('r','m','d','r'): {
@@ -434,6 +447,9 @@ skip_chunk:
}
free(priv);
+ if (flags==5) // reference & header sent
+ return 1;
+
if(flags==1)
mp_msg(MSGT_DEMUX,MSGL_WARN,"MOV: missing data (mdat) chunk! Maybe broken file...\n");
else if(flags==2)
diff --git a/libmpdemux/demuxer.c b/libmpdemux/demuxer.c
index c107eac273..e8926414dd 100644
--- a/libmpdemux/demuxer.c
+++ b/libmpdemux/demuxer.c
@@ -650,7 +650,7 @@ if(file_format==DEMUXER_TYPE_UNKNOWN || file_format==DEMUXER_TYPE_MOV){
demuxer=new_demuxer(stream,DEMUXER_TYPE_MOV,audio_id,video_id,dvdsub_id);
if(mov_check_file(demuxer)){
mp_msg(MSGT_DEMUXER,MSGL_INFO,MSGTR_Detected_XXX_FileFormat,"QuickTime/MOV");
- file_format=DEMUXER_TYPE_MOV;
+ file_format=demuxer->type;
} else {
free_demuxer(demuxer);
demuxer = NULL;
diff --git a/mplayer.c b/mplayer.c
index 589e2fac0a..85d6e02793 100644
--- a/mplayer.c
+++ b/mplayer.c
@@ -585,6 +585,8 @@ static int libmpdemux_was_interrupted(int eof) {
return eof;
}
+#define mp_basename(s) (strrchr(s,'/')==NULL?(char*)s:(strrchr(s,'/')+1))
+
int playtree_add_playlist(play_tree_t* entry)
{
if(!entry) {
@@ -1226,6 +1228,60 @@ if(stream_cache_size>0){
current_module="demux_open";
demuxer=demux_open(stream,file_format,audio_id,video_id,dvdsub_id);
+
+// HACK to get MOV Reference Files working
+
+if (demuxer && demuxer->type==DEMUXER_TYPE_PLAYLIST)
+{
+ unsigned char* playlist_entry;
+ play_tree_t *list = NULL, *entry = NULL;
+
+ current_module="handle_demux_playlist";
+ while (ds_get_packet(demuxer->video,&playlist_entry)>0)
+ {
+ char *temp, *bname;
+
+ mp_msg(MSGT_CPLAYER,MSGL_V,"Adding file %s to element entry\n",playlist_entry);
+
+ bname=mp_basename(playlist_entry);
+ if ((strlen(bname)>10) && !strncmp(bname,"qt",2) && !strncmp(bname+3,"gateQT",6))
+ continue;
+
+ entry = play_tree_new();
+
+ if (filename && !strcmp(mp_basename(playlist_entry),playlist_entry)) // add reference path of current file
+ {
+ temp=malloc((strlen(filename)-strlen(mp_basename(filename))+strlen(playlist_entry)+1)*sizeof(char));
+ if (temp)
+ {
+ strncpy(temp, filename, strlen(filename)-strlen(mp_basename(filename)));
+ temp[strlen(filename)-strlen(mp_basename(filename))]='\0';
+ strcat(temp, playlist_entry);
+ play_tree_add_file(entry,temp);
+ mp_msg(MSGT_CPLAYER,MSGL_V,"Resolving reference to %s\n",temp);
+ free(temp);
+ }
+ }
+ else
+ play_tree_add_file(entry,playlist_entry);
+
+ if(!list)
+ list = entry;
+ else
+ play_tree_append_entry(list,entry);
+ }
+ free_demuxer(demuxer);
+ demuxer = NULL;
+
+ if (list)
+ {
+ entry = play_tree_new();
+ play_tree_set_child(entry,list);
+ eof=playtree_add_playlist(entry);
+ goto goto_next_file;
+ }
+}
+
if(!demuxer)
{
play_tree_t* entry;