aboutsummaryrefslogtreecommitdiffstats
path: root/src/DecoderThread.cxx
diff options
context:
space:
mode:
authorMax Kellermann <max@duempel.org>2013-11-13 20:57:09 +0100
committerMax Kellermann <max@duempel.org>2013-11-13 20:57:13 +0100
commit4ee147ea34057c0bcef31afed55f98b025b997dc (patch)
tree7077ad343ded2228d2e2dcc6d038515d92201d87 /src/DecoderThread.cxx
parentf1ca61d7d7fac7a0a93daa244bf86c2ae7ebabd7 (diff)
downloadmpd-4ee147ea34057c0bcef31afed55f98b025b997dc.tar.gz
mpd-4ee147ea34057c0bcef31afed55f98b025b997dc.tar.xz
mpd-4ee147ea34057c0bcef31afed55f98b025b997dc.zip
DecoderAPI: stop decoder on MPD error
This commit adds the basic infrastructure for reporting bugs from DecoderAPI.cxx via DecoderThread.cxx to DecoderControl.
Diffstat (limited to 'src/DecoderThread.cxx')
-rw-r--r--src/DecoderThread.cxx7
1 files changed, 6 insertions, 1 deletions
diff --git a/src/DecoderThread.cxx b/src/DecoderThread.cxx
index 4d0bc13b5..2df131d19 100644
--- a/src/DecoderThread.cxx
+++ b/src/DecoderThread.cxx
@@ -360,7 +360,12 @@ decoder_run_song(DecoderControl &dc,
dc.Lock();
- if (ret)
+ if (decoder.error.IsDefined()) {
+ /* copy the Error from sruct Decoder to
+ DecoderControl */
+ dc.state = DecoderState::ERROR;
+ dc.error = std::move(decoder.error);
+ } else if (ret)
dc.state = DecoderState::STOP;
else {
dc.state = DecoderState::ERROR;