[vlc-devel] commit: dummy demux: implement seeking and positioning with vlc://pause ( Rémi Denis-Courmont )

git version control git at videolan.org
Thu Feb 18 18:22:08 CET 2010


vlc | branch: master | Rémi Denis-Courmont <remi at remlab.net> | Thu Feb 18 19:21:10 2010 +0200| [f5de3aee2c4e43ef6b84e3c3c5ae181f899bd7e5] | committer: Rémi Denis-Courmont 

dummy demux: implement seeking and positioning with vlc://pause

> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=f5de3aee2c4e43ef6b84e3c3c5ae181f899bd7e5
---

 modules/misc/dummy/input.c |   88 ++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 80 insertions(+), 8 deletions(-)

diff --git a/modules/misc/dummy/input.c b/modules/misc/dummy/input.c
index c0879ab..cb7b391 100644
--- a/modules/misc/dummy/input.c
+++ b/modules/misc/dummy/input.c
@@ -44,18 +44,81 @@ static int DemuxNoOp( demux_t *demux )
     return 0;
 }
 
+struct demux_sys_t
+{
+    mtime_t end;
+    mtime_t length;
+};
+
 static int DemuxPause( demux_t *demux )
 {
-    const mtime_t *p_end = (void *)demux->p_sys;
+    demux_sys_t *p_sys = demux->p_sys;
     mtime_t now = mdate();
 
-    if( now >= *p_end )
+    if( now >= p_sys->end )
         return 0;
 
     msleep( 10000 ); /* FIXME!!! */
     return 1;
 }
 
+static int ControlPause( demux_t *demux, int query, va_list args )
+{
+    demux_sys_t *p_sys = demux->p_sys;
+
+    switch( query )
+    {
+        case DEMUX_GET_POSITION:
+        {
+            double *ppos = va_arg( args, double * );
+            double pos;
+            mtime_t now = mdate();
+
+            pos = 1. + ((double)(now - p_sys->end) / (double)p_sys->length);
+            *ppos = (pos <= 1.) ? pos : 1.;
+            break;
+        }
+
+        case DEMUX_SET_POSITION:
+        {
+            double pos = va_arg( args, double );
+            mtime_t now = mdate();
+
+            p_sys->end = now + (p_sys->length * (1. - pos));
+            break;
+        }
+
+        case DEMUX_GET_LENGTH:
+        {
+            mtime_t *plen = va_arg( args, mtime_t * );
+            *plen = p_sys->length;
+            break;
+        }
+
+        case DEMUX_GET_TIME:
+        {
+            mtime_t *ppos = va_arg( args, mtime_t * );
+            *ppos = mdate() + p_sys->length - p_sys->end;
+            break;
+        }
+
+        case DEMUX_SET_TIME:
+        {
+            mtime_t pos = va_arg( args, mtime_t );
+            p_sys->end = mdate() + p_sys->length - pos;
+            break;
+        }
+
+        case DEMUX_CAN_SEEK:
+            *va_arg( args, bool * ) = true;
+            break;
+
+        default:
+            return DemuxControl( demux, query, args );
+    }
+    return VLC_SUCCESS;
+}
+
 /*****************************************************************************
  * OpenDemux: initialize the target, ie. parse the command
  *****************************************************************************/
@@ -64,14 +127,15 @@ int OpenDemux ( vlc_object_t *p_this )
     demux_t *p_demux = (demux_t*)p_this;
     char * psz_name = p_demux->psz_path;
 
-    p_demux->pf_control = DemuxControl;
     p_demux->p_sys = NULL;
 
     /* Check for a "vlc://nop" command */
     if( !strcasecmp( psz_name, "nop" ) )
     {
+nop:
         msg_Info( p_demux, "command `nop'" );
         p_demux->pf_demux = DemuxNoOp;
+        p_demux->pf_control = DemuxControl;
         return VLC_SUCCESS;
     }
 
@@ -80,6 +144,7 @@ int OpenDemux ( vlc_object_t *p_this )
     {
         msg_Info( p_demux, "command `quit'" );
         p_demux->pf_demux = DemuxNoOp;
+        p_demux->pf_control = DemuxControl;
         libvlc_Quit( p_demux->p_libvlc );
         return VLC_SUCCESS;
     }
@@ -88,15 +153,22 @@ int OpenDemux ( vlc_object_t *p_this )
     if( !strncasecmp( psz_name, "pause:", 6 ) )
     {
         double f = us_atof( psz_name + 6 );
-        mtime_t end = mdate() + f * (mtime_t)1000000;
+        mtime_t length = f * CLOCK_FREQ;
 
         msg_Info( p_demux, "command `pause %f'", f );
-        p_demux->pf_demux = DemuxPause;
+        if( length == 0 )
+            goto nop; /* avoid division by zero */
 
-        p_demux->p_sys = malloc( sizeof( end ) );
-        if( p_demux->p_sys == NULL )
+        demux_sys_t *p_sys = malloc( sizeof( *p_sys ) );
+        if( p_sys == NULL )
             return VLC_ENOMEM;
-        memcpy( p_demux->p_sys, &end, sizeof( end ) );
+
+        p_sys->end = mdate() + length;
+        p_sys->length = length;
+
+        p_demux->p_sys = p_sys;
+        p_demux->pf_demux = DemuxPause;
+        p_demux->pf_control = ControlPause;
         return VLC_SUCCESS;
     }
  




More information about the vlc-devel mailing list