gst-plugins-mythtv/src/gstmythtvsrc.c
branchtrunk
changeset 69 f7c91518d8f4
parent 61 dedcca2fe529
child 70 4ba74b706853
     1.1 --- a/gst-plugins-mythtv/src/gstmythtvsrc.c	Fri Oct 27 23:32:24 2006 +0100
     1.2 +++ b/gst-plugins-mythtv/src/gstmythtvsrc.c	Mon Nov 06 22:59:51 2006 +0000
     1.3 @@ -36,7 +36,7 @@
     1.4   
     1.5  #define GMYTHTV_TRANSFER_MAX_WAITS	100
     1.6  
     1.7 -#define GMYTHTV_TRANSFER_MAX_BUFFER	512*1024
     1.8 +#define GMYTHTV_TRANSFER_MAX_BUFFER	80*1024
     1.9  //( 32*1024  )
    1.10  
    1.11  /* 4*1024 ??? */
    1.12 @@ -140,7 +140,7 @@
    1.13  static void
    1.14  gst_mythtv_src_class_init (GstMythtvSrcClass * klass)
    1.15  {
    1.16 -  GObjectClass *gobject_class;
    1.17 +  GObjectClass *gobject_class; 
    1.18    //GstPushSrcClass *gstpushsrc_class;
    1.19    GstBaseSrcClass *gstbasesrc_class;
    1.20  
    1.21 @@ -225,6 +225,8 @@
    1.22    this->mythtv_version = GMYTHTV_VERSION_DEFAULT;
    1.23  
    1.24    this->bytes_read = 0;
    1.25 +  
    1.26 +  this->prev_content_size = 0;
    1.27  
    1.28    this->content_size = 0;
    1.29    this->read_offset = 0;
    1.30 @@ -314,7 +316,7 @@
    1.31  
    1.32        if ( src->live_tv == FALSE ) 
    1.33        {
    1.34 -	goto done;
    1.35 +	goto eos;
    1.36        } 
    1.37        else  
    1.38        {
    1.39 @@ -323,10 +325,9 @@
    1.40  	  if ( gst_mythtv_src_next_program_chain ( src ) )
    1.41  	    continue;
    1.42  	  else
    1.43 -	    goto done;
    1.44 +	    goto eos;	  	
    1.45  	} else 
    1.46 -	  if ( src->content_size <= 
    1.47 -	      ( src->read_offset + size + GMYTHTV_TRANSFER_MAX_BUFFER ) ) {
    1.48 +	  if ( abs( src->content_size - src->prev_content_size ) < GMYTHTV_TRANSFER_MAX_BUFFER )  {
    1.49  	    src->update_prog_chain = TRUE;
    1.50  	    if ( src->enable_timing_position ) {
    1.51  	      gint64 size_tmp = 0;
    1.52 @@ -340,7 +341,8 @@
    1.53  		g_print( "\t[%s]\tGET_POSITION: file_position = %lld\n",
    1.54  		    __FUNCTION__, size_tmp );
    1.55  	      }
    1.56 -	    } else {
    1.57 +	    } else if ( abs( src->content_size - src->prev_content_size ) < GMYTHTV_TRANSFER_MAX_BUFFER ) {
    1.58 +	      src->prev_content_size = src->content_size;
    1.59  	      gint64 new_offset = gmyth_file_transfer_get_file_position( src->file_transfer );
    1.60  	      if ( new_offset > 0 ) {
    1.61  		if ( src->content_size < new_offset ) {
    1.62 @@ -352,6 +354,7 @@
    1.63  	    }
    1.64  	    goto done;
    1.65  	  }
    1.66 +	  goto done;
    1.67        }
    1.68  
    1.69      }
    1.70 @@ -474,7 +477,7 @@
    1.71  		// go to the next program chain
    1.72  		src->unique_setup = FALSE;
    1.73  		src->update_prog_chain = TRUE;
    1.74 -		gst_mythtv_src_next_program_chain( src );  
    1.75 +		//gst_mythtv_src_next_program_chain( src );  
    1.76      return -101;
    1.77    }
    1.78  
    1.79 @@ -517,7 +520,10 @@
    1.80  
    1.81    gint64 size_tmp = 0;
    1.82    guint max_tries = 3;
    1.83 -  if (src->live_tv == TRUE) {
    1.84 +  if (src->live_tv == TRUE && ( abs( src->content_size - src->prev_content_size ) < 
    1.85 +	GMYTHTV_TRANSFER_MAX_BUFFER ) ) {
    1.86 +    /* sets the last content size amount before it can be updated */
    1.87 +    src->prev_content_size = src->content_size;
    1.88  get_file_pos:
    1.89      g_usleep( 10 );
    1.90      size_tmp = gmyth_file_transfer_get_file_position( src->file_transfer );
    1.91 @@ -716,6 +722,9 @@
    1.92  #endif
    1.93  
    1.94    src->content_size = src->file_transfer->filesize;
    1.95 +  while (  src->content_size < GMYTHTV_TRANSFER_MAX_BUFFER )
    1.96 +    src->content_size = gst_mythtv_src_get_position( src );
    1.97 +
    1.98    //src->read_offset = 0;
    1.99  
   1.100    //src->update_prog_chain = FALSE;
   1.101 @@ -814,13 +823,16 @@
   1.102  {
   1.103    GstMythtvSrc *src = GST_MYTHTV_SRC (bsrc);
   1.104    gboolean ret = TRUE;
   1.105 +  g_print( "[%s] Difference from previous content size: %d (max.: %d)\n", __FUNCTION__, 
   1.106 +  			abs( src->content_size - src->prev_content_size ), GMYTHTV_TRANSFER_MAX_BUFFER );
   1.107  
   1.108    if (src->content_size <= 0) {
   1.109      ret= FALSE;
   1.110 -  } else if ( src->live_tv ) {
   1.111 +  } else if ( src->live_tv && ( abs( src->content_size - src->bytes_read ) < 
   1.112 +	GMYTHTV_TRANSFER_MAX_BUFFER ) ) {
   1.113      //g_static_mutex_lock( &update_size_mutex );
   1.114      //GST_OBJECT_LOCK(src);
   1.115 -
   1.116 +    src->prev_content_size = src->content_size;
   1.117      gint64 new_offset = gmyth_file_transfer_get_file_position( src->file_transfer );
   1.118      if ( new_offset > 0 ) {
   1.119        if ( src->content_size < new_offset ) {
   1.120 @@ -1031,7 +1043,7 @@
   1.121  static GstStateChangeReturn
   1.122  gst_mythtv_src_change_state (GstElement * element, GstStateChange transition)
   1.123  {
   1.124 -  GstStateChangeReturn ret = GST_STATE_CHANGE_SUCCESS;
   1.125 +  GstStateChangeReturn ret = GST_STATE_CHANGE_NO_PREROLL;
   1.126    GstMythtvSrc *src = GST_MYTHTV_SRC (element);
   1.127  
   1.128    switch (transition) {
   1.129 @@ -1053,9 +1065,13 @@
   1.130  
   1.131    switch (transition) {
   1.132      case GST_STATE_CHANGE_READY_TO_NULL:
   1.133 +      g_print( "[%s] READY to NULL called!\n", __FUNCTION__ );
   1.134        break;
   1.135      case GST_STATE_CHANGE_PLAYING_TO_PAUSED:
   1.136 +      g_print( "[%s] PLAYING to PAUSED called!\n", __FUNCTION__ );
   1.137 +      break;
   1.138      case GST_STATE_CHANGE_PAUSED_TO_READY:
   1.139 +      g_print( "[%s] PAUSED to READY called!\n", __FUNCTION__ );
   1.140        if ( src->live_tv && src->update_prog_chain ) {
   1.141  	src->read_offset = 0;
   1.142  	src->bytes_read = 0;