player/Thread: do not start the decoder twice

Upon receiving PlayerCommand::QUEUE, call StartDecoder() only if the
decoder is not already starting.  Checking just
DecoderControl::IsIdle() is not enough because the decoder may already
have finished decoding the song before the player has started playing
it and before it had a chance to call CheckDecoderStartup().

Omitting the StartDecoder() call now means it will be started later in
the Run() main loop, after CheckDecoderStartup() has succeeded (which
effectively switches to the song that has already been decoded by the
current decoder).

This fixes an assertion failure when compiled in debug mode
(`-Db_ndebug=false`) and random noise playback in non-debug mode
(`-Db_ndebug=true`).

Closes https://github.com/MusicPlayerDaemon/MPD/issues/1900
This commit is contained in:
Max Kellermann 2024-04-15 21:32:19 +02:00
parent c8ece786dd
commit 7236f83999

View File

@ -785,7 +785,7 @@ Player::ProcessCommand(std::unique_lock<Mutex> &lock) noexcept
queued = true;
pc.CommandFinished();
if (dc.IsIdle())
if (!decoder_starting && dc.IsIdle())
StartDecoder(lock, std::make_shared<MusicPipe>(),
false);