[vlc-devel] Re: modules/codec/ffmpeg/mux.c oddness

Olivier Houchard doginou at dong.ci0.org
Thu Feb 15 16:52:31 CET 2007


On Thu, Feb 15, 2007 at 05:31:33PM +0200, Rmi Denis-Courmont wrote:
> Le jeudi 15 février 2007 17:10, Olivier Houchard a écrit :
> > Well I agree.
> > Attached patch naively calculate the length for http and udp, both of
> > which used to return 0.
> >
> > Comments ?
> 
> Please base patches on the parent to the trunk directory, or by default 
> to the trunk directory.
> 

Done.

Olivier
-------------- next part --------------
Index: vlc-trunk/modules/access_output/http.c
===================================================================
--- vlc-trunk/modules/access_output/http.c	(revision 18840)
+++ vlc-trunk/modules/access_output/http.c	(working copy)
@@ -374,6 +374,7 @@
 {
     sout_access_out_sys_t *p_sys = p_access->p_sys;
     int i_err = 0;
+    int i_len = 0;
 
     while( p_buffer )
     {
@@ -409,6 +410,7 @@
                                 p_sys->i_header_size );
         }
 
+        i_len += p_buffer->i_buffer;
         /* send data */
         i_err = httpd_StreamSend( p_sys->p_httpd_stream, p_buffer->p_buffer,
                                   p_buffer->i_buffer );
@@ -428,7 +430,7 @@
         block_ChainRelease( p_buffer );
     }
 
-    return( i_err < 0 ? VLC_EGENERIC : VLC_SUCCESS );
+    return( i_err < 0 ? VLC_EGENERIC : i_len );
 }
 
 /*****************************************************************************
Index: vlc-trunk/modules/access_output/udp.c
===================================================================
--- vlc-trunk/modules/access_output/udp.c	(revision 18840)
+++ vlc-trunk/modules/access_output/udp.c	(working copy)
@@ -386,6 +386,7 @@
 static int Write( sout_access_out_t *p_access, block_t *p_buffer )
 {
     sout_access_out_sys_t *p_sys = p_access->p_sys;
+    int i_len = 0;
 
     while( p_buffer )
     {
@@ -413,6 +414,7 @@
             p_sys->p_buffer = NULL;
         }
 
+        i_len += p_buffer->i_buffer;
         while( p_buffer->i_buffer )
         {
             int i_payload_size = p_sys->i_mtu;
@@ -462,7 +464,7 @@
         p_buffer = p_next;
     }
 
-    return( p_sys->p_thread->b_error ? -1 : 0 );
+    return( p_sys->p_thread->b_error ? -1 : i_len );
 }
 
 /*****************************************************************************
@@ -472,6 +474,7 @@
 {
     sout_access_out_sys_t   *p_sys = p_access->p_sys;
     block_t *p_buf;
+    int i_len;
 
     while ( p_sys->p_thread->p_empty_blocks->i_depth >= MAX_EMPTY_BLOCKS )
     {
@@ -479,9 +482,10 @@
         block_Release( p_buf );
     }
 
+    i_len = p_buffer->i_buffer;
     block_FifoPut( p_sys->p_thread->p_fifo, p_buffer );
 
-    return( p_sys->p_thread->b_error ? -1 : 0 );
+    return( p_sys->p_thread->b_error ? -1 : i_len );
 }
 
 /*****************************************************************************


More information about the vlc-devel mailing list