diff options
author | Max Kellermann <max@duempel.org> | 2009-12-25 23:12:10 +0100 |
---|---|---|
committer | Max Kellermann <max@duempel.org> | 2009-12-27 16:08:53 +0100 |
commit | 5787f737044e90b74e22d2179cd0d1b47fd17c76 (patch) | |
tree | 0455e67ab93ba5ba0bb221a1833f0aab50ff4db0 /src/decoder | |
parent | 201316cd67d374357c1aabc8a4aa2210fe20f1e8 (diff) | |
download | mpd-5787f737044e90b74e22d2179cd0d1b47fd17c76.tar.gz mpd-5787f737044e90b74e22d2179cd0d1b47fd17c76.tar.xz mpd-5787f737044e90b74e22d2179cd0d1b47fd17c76.zip |
decoder, player: support song ranges
Seek the decoder to the start of the range before beginning with
playback. Stop the decoder when the end of the range has been
reached. Add the start position to the seek position. Expose the
duration of the range, not the full song file.
Diffstat (limited to '')
-rw-r--r-- | src/decoder_api.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/src/decoder_api.c b/src/decoder_api.c index dde27727b..704f6dbf7 100644 --- a/src/decoder_api.c +++ b/src/decoder_api.c @@ -328,8 +328,9 @@ decoder_data(struct decoder *decoder, } dest = music_chunk_write(chunk, &dc->out_audio_format, - decoder->timestamp, kbit_rate, - &nbytes); + decoder->timestamp - + dc->song->start_ms / 1000.0, + kbit_rate, &nbytes); if (dest == NULL) { /* the chunk is full, flush it */ decoder_flush_chunk(decoder); @@ -366,6 +367,12 @@ decoder_data(struct decoder *decoder, decoder->timestamp += (double)nbytes / audio_format_time_to_size(&dc->in_audio_format); + + if (dc->song->end_ms > 0 && + decoder->timestamp >= dc->song->end_ms / 1000.0) + /* the end of this range has been reached: + stop decoding */ + return DECODE_COMMAND_STOP; } return DECODE_COMMAND_NONE; |