diff options
| -rwxr-xr-x | lib/rbcodec/codecs/wma.c | 40 |
1 files changed, 22 insertions, 18 deletions
diff --git a/lib/rbcodec/codecs/wma.c b/lib/rbcodec/codecs/wma.c index f9501ff..36e4285 100755 --- a/lib/rbcodec/codecs/wma.c +++ b/lib/rbcodec/codecs/wma.c @@ -106,11 +106,7 @@ restart_track: { enum codec_command_action action = ci->get_command(¶m); - if (action == CODEC_ACTION_HALT) - break; - - /* Deal with any pending seek requests */ - if (action == CODEC_ACTION_SEEK_TIME) { + if (action != CODEC_ACTION_NULL) { /*flush the wma decoder state*/ wmadec.last_superframe_len = 0; @@ -121,23 +117,31 @@ restart_track: memset((*(wmadec.frame_out)), 0, sizeof(fixed32) * MAX_CHANNELS * BLOCK_MAX_SIZE * 2); - if (param == 0) { - ci->set_elapsed(0); - ci->seek_complete(); - goto restart_track; /* Pretend you never saw this... */ - } + if (action == CODEC_ACTION_HALT) + break; + + /* Deal with any pending seek requests */ + if (action == CODEC_ACTION_SEEK_TIME) { + + if (param == 0) { + ci->set_elapsed(0); + ci->seek_complete(); + goto restart_track; /* Pretend you never saw this... */ + } + + elapsedtime = asf_seek(param, &wfx); + if (elapsedtime < 1){ + ci->set_elapsed(0); + ci->seek_complete(); + break; + } + /*DEBUGF("Seek returned %d\n", (int)elapsedtime);*/ - elapsedtime = asf_seek(param, &wfx); - if (elapsedtime < 1){ - ci->set_elapsed(0); + ci->set_elapsed(elapsedtime); ci->seek_complete(); - break; } - /*DEBUGF("Seek returned %d\n", (int)elapsedtime);*/ - - ci->set_elapsed(elapsedtime); - ci->seek_complete(); } + errcount = 0; new_packet: res = asf_read_packet(&audiobuf, &audiobufsize, &packetlength, &wfx); |