decoder_control: pass music_pipe to dc_start()

More abstraction for decoder_control.pipe.
This commit is contained in:
Max Kellermann 2010-11-05 17:42:08 +01:00
parent 5223261f19
commit cc261872c2
3 changed files with 18 additions and 12 deletions

View File

@ -18,6 +18,7 @@
*/ */
#include "decoder_control.h" #include "decoder_control.h"
#include "pipe.h"
#include <assert.h> #include <assert.h>
@ -58,22 +59,28 @@ static void dc_command_async(enum decoder_command cmd)
} }
void void
dc_start(struct notify *notify, struct song *song) dc_start(struct notify *notify, struct song *song, struct music_pipe *pipe)
{ {
assert(dc.pipe != NULL); assert(dc.pipe == NULL);
assert(song != NULL); assert(song != NULL);
assert(pipe != NULL);
assert(music_pipe_empty(pipe));
dc.next_song = song; dc.next_song = song;
dc.pipe = pipe;
dc_command(notify, DECODE_COMMAND_START); dc_command(notify, DECODE_COMMAND_START);
} }
void void
dc_start_async(struct song *song) dc_start_async(struct song *song, struct music_pipe *pipe)
{ {
assert(dc.pipe != NULL); assert(dc.pipe == NULL);
assert(song != NULL); assert(song != NULL);
assert(pipe != NULL);
assert(music_pipe_empty(pipe));
dc.next_song = song; dc.next_song = song;
dc.pipe = pipe;
dc_command_async(DECODE_COMMAND_START); dc_command_async(DECODE_COMMAND_START);
} }

View File

@ -118,10 +118,10 @@ void
dc_command_wait(struct notify *notify); dc_command_wait(struct notify *notify);
void void
dc_start(struct notify *notify, struct song *song); dc_start(struct notify *notify, struct song *song, struct music_pipe *pipe);
void void
dc_start_async(struct song *song); dc_start_async(struct song *song, struct music_pipe *pipe);
void void
dc_stop(struct notify *notify); dc_stop(struct notify *notify);

View File

@ -324,10 +324,9 @@ static bool player_seek_decoder(struct player *player)
/* clear music chunks which might still reside in the /* clear music chunks which might still reside in the
pipe */ pipe */
music_pipe_clear(player->pipe, player_buffer); music_pipe_clear(player->pipe, player_buffer);
dc.pipe = player->pipe;
/* re-start the decoder */ /* re-start the decoder */
dc_start_async(pc.next_song); dc_start_async(pc.next_song, player->pipe);
ret = player_wait_for_decoder(player); ret = player_wait_for_decoder(player);
if (!ret) { if (!ret) {
/* decoder failure */ /* decoder failure */
@ -665,8 +664,7 @@ static void do_play(void)
player.pipe = music_pipe_new(); player.pipe = music_pipe_new();
dc.buffer = player_buffer; dc.buffer = player_buffer;
dc.pipe = player.pipe; dc_start(&pc.notify, pc.next_song, player.pipe);
dc_start(&pc.notify, pc.next_song);
if (!player_wait_for_decoder(&player)) { if (!player_wait_for_decoder(&player)) {
player_dc_stop(&player); player_dc_stop(&player);
player_command_finished(); player_command_finished();
@ -735,9 +733,10 @@ static void do_play(void)
assert(pc.next_song != NULL); assert(pc.next_song != NULL);
assert(!player_dc_at_next_song(&player)); assert(!player_dc_at_next_song(&player));
dc.pipe = NULL;
player.queued = false; player.queued = false;
dc.pipe = music_pipe_new(); dc_start_async(pc.next_song, music_pipe_new());
dc_start_async(pc.next_song);
} }
if (player_dc_at_next_song(&player) && if (player_dc_at_next_song(&player) &&