1
mirror of https://github.com/mpv-player/mpv synced 2025-01-01 04:36:24 +01:00

allow playing from stdin

git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@693 b3059339-0415-0410-9bf9-f77b7e298cf2
This commit is contained in:
arpi_esp 2001-05-03 23:32:56 +00:00
parent dc776b2b5c
commit 01df02c62c
5 changed files with 36 additions and 11 deletions

View File

@ -180,6 +180,9 @@ if(verbose){
// case 0x33000890: return "guid_index_chunk";
} // switch GUID
if((*((unsigned int*)&objh.guid))==0x75b22636) break; // movi chunk
if(!stream_seek(demuxer->stream,endpos)) break;
} // while EOF

View File

@ -49,6 +49,7 @@ while(1){
demuxer->movi_start=stream_tell(demuxer->stream);
demuxer->movi_end=demuxer->movi_start+len;
if(verbose>=1) printf("Found movie at 0x%X - 0x%X\n",demuxer->movi_start,demuxer->movi_end);
if(index_mode==-2) break; // reading from non-seekable source (stdin)
len=(len+1)&(~1);
stream_skip(demuxer->stream,len);
}

View File

@ -553,11 +553,18 @@ if(vcd_track){
} else {
//============ Open plain FILE ============
int len;
f=open(filename,O_RDONLY);
if(f<0){ printf("File not found: '%s'\n",filename);return 1; }
len=lseek(f,0,SEEK_END); lseek(f,0,SEEK_SET);
stream=new_stream(f,STREAMTYPE_FILE);
stream->end_pos=len;
if(!strcmp(filename,"-")){
// read from stdin
printf("Reading from stdin...\n");
f=0; // 0=stdin
stream=new_stream(f,STREAMTYPE_STREAM);
} else {
f=open(filename,O_RDONLY);
if(f<0){ printf("File not found: '%s'\n",filename);return 1; }
len=lseek(f,0,SEEK_END); lseek(f,0,SEEK_SET);
stream=new_stream(f,STREAMTYPE_FILE);
stream->end_pos=len;
}
}
#ifdef HAVE_LIBCSS
@ -658,7 +665,7 @@ d_dvdsub=demuxer->sub;
switch(file_format){
case DEMUXER_TYPE_AVI: {
//---- AVI header:
read_avi_header(demuxer,index_mode);
read_avi_header(demuxer,f?index_mode:-2);
stream_reset(demuxer->stream);
stream_seek(demuxer->stream,demuxer->movi_start);
demuxer->idx_pos=0;
@ -1157,7 +1164,7 @@ int osd_last_pts=-303;
#ifdef USE_TERMCAP
load_termcap(NULL); // load key-codes
#endif
getch2_enable();
if(f) getch2_enable();
//========= Catch terminate signals: ================
// terminate requests:
@ -1636,7 +1643,7 @@ switch(sh_video->codec->driver){
#ifdef HAVE_LIRC
lirc_mp_getinput()<=0 &&
#endif
getch2(20)<=0 && mplayer_get_key()<=0){
(!f || getch2(20)<=0) && mplayer_get_key()<=0){
video_out->check_events();
}
osd_function=OSD_PLAY;
@ -1653,7 +1660,7 @@ switch(sh_video->codec->driver){
#ifdef HAVE_LIRC
(c=lirc_mp_getinput())>0 ||
#endif
(c=getch2(0))>0 || (c=mplayer_get_key())>0) switch(c){
(f && (c=getch2(0)))>0 || (c=mplayer_get_key())>0) switch(c){
// seek 10 sec
case KEY_RIGHT:
osd_function=OSD_FFW;

View File

@ -24,6 +24,7 @@ int stream_fill_buffer(stream_t *s){
if(s->eof){ s->buf_pos=s->buf_len=0; return 0; }
switch(s->type){
case STREAMTYPE_FILE:
case STREAMTYPE_STREAM:
len=read(s->fd,s->buffer,STREAM_BUFFER_SIZE);break;
case STREAMTYPE_VCD:
#ifdef VCD_CACHE
@ -55,6 +56,7 @@ if(verbose>=3){
switch(s->type){
case STREAMTYPE_FILE:
case STREAMTYPE_STREAM:
newpos=pos&(~(STREAM_BUFFER_SIZE-1));break;
case STREAMTYPE_VCD:
newpos=(pos/VCD_SECTOR_DATA)*VCD_SECTOR_DATA;break;
@ -63,18 +65,29 @@ if(verbose>=3){
pos-=newpos;
if(newpos==0 || newpos!=s->pos){
s->pos=newpos; // real seek
switch(s->type){
case STREAMTYPE_FILE:
s->pos=newpos; // real seek
if(lseek(s->fd,s->pos,SEEK_SET)<0) s->eof=1;
break;
case STREAMTYPE_VCD:
s->pos=newpos; // real seek
#ifdef VCD_CACHE
vcd_cache_seek(s->pos/VCD_SECTOR_DATA);
#else
vcd_set_msf(s->pos/VCD_SECTOR_DATA);
#endif
break;
case STREAMTYPE_STREAM:
//s->pos=newpos; // real seek
if(newpos<s->pos){
printf("Cannot seek backward in linear streams!\n");
return 1;
}
while(s->pos<newpos){
if(stream_fill_buffer(s)<=0) break; // EOF
}
break;
}
// putchar('.');fflush(stdout);
//} else {

View File

@ -3,6 +3,7 @@
#define STREAMTYPE_FILE 0
#define STREAMTYPE_VCD 1
#define STREAMTYPE_STREAM 2 // same as FILE but no seeking (for stdin)
#define VCD_SECTOR_SIZE 2352
#define VCD_SECTOR_OFFS 24
@ -109,7 +110,7 @@ inline static int stream_seek(stream_t *s,unsigned int pos){
}
inline static void stream_skip(stream_t *s,int len){
if(len<0 || len>2*STREAM_BUFFER_SIZE){
if(len<0 || (len>2*STREAM_BUFFER_SIZE && s->type!=STREAMTYPE_STREAM)){
// negative or big skip!
stream_seek(s,stream_tell(s)+len);
return;