]> git.sesse.net Git - vlc/commitdiff
Do not loose pts on stream properties changes.
authorLaurent Aimar <fenrir@videolan.org>
Sat, 13 Feb 2010 13:37:52 +0000 (14:37 +0100)
committerLaurent Aimar <fenrir@videolan.org>
Sat, 13 Feb 2010 14:12:00 +0000 (15:12 +0100)
It closes #2349.

modules/packetizer/flac.c
modules/packetizer/mlp.c
modules/packetizer/mpeg4audio.c

index 4d29a514fe91f585ce11c3614f02e274924bbc66..c001ea73e87be14e44f802b393d4a3806b119d1d 100644 (file)
@@ -285,8 +285,9 @@ static block_t *Packetize( decoder_t *p_dec, block_t **pp_block )
             if( p_sys->i_rate != p_dec->fmt_out.audio.i_rate )
             {
                 p_dec->fmt_out.audio.i_rate = p_sys->i_rate;
+                const mtime_t i_end_date = date_Get( &p_sys->end_date );
                 date_Init( &p_sys->end_date, p_sys->i_rate, 1 );
-                date_Set( &p_sys->end_date, p_sys->i_pts );
+                date_Set( &p_sys->end_date, i_end_date );
             }
             p_sys->i_state = STATE_NEXT_SYNC;
             p_sys->i_frame_size = p_sys->b_stream_info && p_sys->stream_info.min_framesize > 0 ?
index ee2479b60271848332e8d8b71fcca0651c8400d2..d466e77102904dc67cd37495eb6655c5a9e78a45 100644 (file)
@@ -302,8 +302,9 @@ static block_t *Packetize( decoder_t *p_dec, block_t **pp_block )
                 msg_Info( p_dec, "MLP channels: %d samplerate: %d",
                           p_sys->mlp.i_channels, p_sys->mlp.i_rate );
 
+                const mtime_t i_end_date = date_Get( &p_sys->end_date );
                 date_Init( &p_sys->end_date, p_sys->mlp.i_rate, 1 );
-                date_Set( &p_sys->end_date, p_sys->i_pts );
+                date_Set( &p_sys->end_date, i_end_date );
             }
 
             p_dec->fmt_out.audio.i_rate     = p_sys->mlp.i_rate;
index f47aecb3969cf824b8578596701d734127addbce..3e4561c09d213a64031992f729c671bed66e824c 100644 (file)
@@ -1205,8 +1205,9 @@ static void SetupOutput( decoder_t *p_dec, block_t *p_block )
         msg_Info( p_dec, "AAC channels: %d samplerate: %d",
                   p_sys->i_channels, p_sys->i_rate );
 
+        const mtime_t i_end_date = date_Get( &p_sys->end_date );
         date_Init( &p_sys->end_date, p_sys->i_rate, 1 );
-        date_Set( &p_sys->end_date, p_sys->i_pts );
+        date_Set( &p_sys->end_date, i_end_date );
     }
 
     p_dec->fmt_out.audio.i_rate     = p_sys->i_rate;