# HG changeset patch # User arpi # Date 1009312322 0 # Node ID d358f4a74690e7141ef6277cdc623e7d15a3114d # Parent 38ee592422aaec5bceeafe5e80eee1aeb4f029e8 dvd seeking -> subtitle disappearing bugs fixed diff -r 38ee592422aa -r d358f4a74690 mplayer.c --- a/mplayer.c Tue Dec 25 19:25:27 2001 +0000 +++ b/mplayer.c Tue Dec 25 20:32:02 2001 +0000 @@ -2115,6 +2115,10 @@ drop_frame_cnt=0; too_slow_frame_cnt=0; too_fast_frame_cnt=0; + +#ifdef USE_DVDREAD + if(vo_spudec) spudec_reset(vo_spudec); +#endif } rel_seek_secs=0; abs_seek_pos=0; diff -r 38ee592422aa -r d358f4a74690 spudec.c --- a/spudec.c Tue Dec 25 19:25:27 2001 +0000 +++ b/spudec.c Tue Dec 25 20:32:02 2001 +0000 @@ -284,9 +284,10 @@ } } else { // Continue current fragment - if (spu->packet_size < spu->packet_offset + len) + if (spu->packet_size < spu->packet_offset + len){ fprintf(stderr,"invalid fragment\n"); - else { + spu->packet_size = spu->packet_offset = 0; + } else { memcpy(spu->packet + spu->packet_offset, packet, len); spu->packet_offset += len; } @@ -297,6 +298,13 @@ } } +void spudec_reset(void *this) // called after seek +{ + spudec_handle_t *spu = (spudec_handle_t*)this; + spu->now_pts = -1; + spu->packet_size = spu->packet_offset = 0; +} + void spudec_heartbeat(void *this, int pts100) { ((spudec_handle_t *)this)->now_pts = pts100; diff -r 38ee592422aa -r d358f4a74690 spudec.h --- a/spudec.h Tue Dec 25 19:25:27 2001 +0000 +++ b/spudec.h Tue Dec 25 20:32:02 2001 +0000 @@ -9,6 +9,7 @@ void spudec_draw(void *this, void (*draw_alpha)(int x0,int y0, int w,int h, unsigned char* src, unsigned char *srca, int stride)); void *spudec_new(dvd_priv_t *dvd_info); void spudec_free(void *this); +void spudec_reset(void *this); // called after seek #endif #endif