diff options
author | Max Kellermann <max@duempel.org> | 2008-08-26 08:27:18 +0200 |
---|---|---|
committer | Max Kellermann <max@duempel.org> | 2008-08-26 08:27:18 +0200 |
commit | 8a4970f863b03550123d1b4595cf69838a93e774 (patch) | |
tree | fceabe5effacc9e910c74cad535999f3a3a2adf3 /src/player_thread.c | |
parent | 7d3429a6d89634f098770f7dce8442f59aac9890 (diff) | |
download | mpd-8a4970f863b03550123d1b4595cf69838a93e774.tar.gz mpd-8a4970f863b03550123d1b4595cf69838a93e774.tar.xz mpd-8a4970f863b03550123d1b4595cf69838a93e774.zip |
added decoder_control.c
The source "decoder_control.c" provides an API for controlling the
decoder. This replaces various direct accesses to the DecoderControl
struct.
Diffstat (limited to 'src/player_thread.c')
-rw-r--r-- | src/player_thread.c | 67 |
1 files changed, 17 insertions, 50 deletions
diff --git a/src/player_thread.c b/src/player_thread.c index e2486f2d3..52f0beac0 100644 --- a/src/player_thread.c +++ b/src/player_thread.c @@ -31,30 +31,9 @@ enum xfade_state { XFADE_ENABLED = 1 }; -static void dc_command_wait(void) -{ - while (dc.command != DECODE_COMMAND_NONE) { - notify_signal(&dc.notify); - notify_wait(&pc.notify); - } -} - -static void dc_command(enum decoder_command cmd) -{ - dc.command = cmd; - dc_command_wait(); -} - -static void stopDecode(void) -{ - if (dc.command == DECODE_COMMAND_START || - dc.state != DECODE_STATE_STOP) - dc_command(DECODE_COMMAND_STOP); -} - static void quitDecode(void) { - stopDecode(); + dc_stop(&pc.notify); pc.state = PLAYER_STATE_STOP; dc.command = DECODE_COMMAND_NONE; pc.command = PLAYER_COMMAND_NONE; @@ -63,10 +42,7 @@ static void quitDecode(void) static int waitOnDecode(int *decodeWaitedOn) { - while (dc.command == DECODE_COMMAND_START) { - notify_signal(&dc.notify); - notify_wait(&pc.notify); - } + dc_command_wait(&pc.notify); if (dc.error != DECODE_ERROR_NOERROR) { assert(dc.next_song == NULL || dc.next_song->url != NULL); @@ -88,30 +64,27 @@ static int waitOnDecode(int *decodeWaitedOn) static int decodeSeek(int *decodeWaitedOn, int *next) { int ret = -1; + double where; if (dc.state == DECODE_STATE_STOP || dc.error != DECODE_ERROR_NOERROR || dc.current_song != pc.next_song) { - stopDecode(); + dc_stop(&pc.notify); *next = -1; ob_clear(); - dc.next_song = pc.next_song; - dc.error = DECODE_ERROR_NOERROR; - dc.command = DECODE_COMMAND_START; + dc_start_async(pc.next_song); waitOnDecode(decodeWaitedOn); } - if (dc.state != DECODE_STATE_STOP && dc.seekable) { - *next = -1; - dc.seekWhere = pc.seekWhere > pc.totalTime - 0.1 ? - pc.totalTime - 0.1 : pc.seekWhere; - dc.seekWhere = 0 > dc.seekWhere ? 0 : dc.seekWhere; - dc.seekError = 0; - dc_command(DECODE_COMMAND_SEEK); - if (!dc.seekError) { - pc.elapsedTime = dc.seekWhere; - ret = 0; - } - } + + where = pc.seekWhere; + if (where > pc.totalTime) + where = pc.totalTime - 0.1; + if (where < 0.0) + where = 0.0; + + ret = dc_seek(&pc.notify, where); + if (ret == 0) + pc.elapsedTime = where; player_command_finished(); @@ -291,12 +264,9 @@ static void decodeParent(void) /* the decoder has finished the current song; make it decode the next song */ next = ob.end; - dc.next_song = pc.next_song; - dc.error = DECODE_ERROR_NOERROR; - dc.command = DECODE_COMMAND_START; + dc_start_async(pc.next_song); pc.queueState = PLAYER_QUEUE_DECODE; wakeup_main_task(); - notify_signal(&dc.notify); } if (next >= 0 && do_xfade == XFADE_UNKNOWN && dc.command != DECODE_COMMAND_START && @@ -416,10 +386,7 @@ static void decode(void) { ob_clear(); - dc.next_song = pc.next_song; - dc.error = DECODE_ERROR_NOERROR; - dc_command(DECODE_COMMAND_START); - + dc_start(&pc.notify, pc.next_song); decodeParent(); } |