From a5d7309d96cca974e1524dc746482ab2a26d7395 Mon Sep 17 00:00:00 2001 From: Adam Boot Date: Fri, 6 Apr 2007 21:48:17 +0000 Subject: Support resume for Musepack git-svn-id: svn://svn.rockbox.org/rockbox/trunk@13049 a1c6a512-1295-4272-9138-f99709370657 --- apps/codecs/mpc.c | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) (limited to 'apps/codecs/mpc.c') diff --git a/apps/codecs/mpc.c b/apps/codecs/mpc.c index fe22c8cccb..122cb22025 100644 --- a/apps/codecs/mpc.c +++ b/apps/codecs/mpc.c @@ -100,6 +100,8 @@ next_track: goto exit; } + samplesdone = ci->id3->offset; + /* read file's streaminfo data */ mpc_streaminfo_init(&info); if (mpc_streaminfo_read(&info, &reader) != ERROR_CODE_OK) { @@ -128,9 +130,21 @@ next_track: retval = CODEC_ERROR; goto done; } + + /* Resume to saved sample offset. */ + if(samplesdone > 0) { + /* hack to improve seek time if filebuf goes empty */ + ci->configure(CODEC_SET_FILEBUF_CHUNKSIZE, 1024*512); + if (mpc_decoder_seek_sample(&decoder, samplesdone)) { + ci->set_elapsed(samplesdone/frequency); + } else { + samplesdone = 0; + } + /* reset chunksize */ + ci->configure(CODEC_SET_FILEBUF_CHUNKSIZE, 1024*16); + } /* This is the decoding loop. */ - samplesdone = 0; do { #if 1 /* Complete seek handler. */ @@ -173,6 +187,7 @@ next_track: status); samplesdone += status; ci->set_elapsed(samplesdone/frequency); + ci->set_offset(samplesdone); } } while (status != 0); retval = CODEC_OK; -- cgit v1.2.3