decoder/Control: caller must lock mutex for Seek()
This commit is contained in:
@@ -128,8 +128,6 @@ DecoderControl::Stop() noexcept
|
|||||||
void
|
void
|
||||||
DecoderControl::Seek(SongTime t)
|
DecoderControl::Seek(SongTime t)
|
||||||
{
|
{
|
||||||
const std::lock_guard<Mutex> protect(mutex);
|
|
||||||
|
|
||||||
assert(state != DecoderState::START);
|
assert(state != DecoderState::START);
|
||||||
assert(state != DecoderState::ERROR);
|
assert(state != DecoderState::ERROR);
|
||||||
|
|
||||||
|
@@ -387,6 +387,8 @@ public:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Throws #std::runtime_error on error.
|
* Throws #std::runtime_error on error.
|
||||||
|
*
|
||||||
|
* Caller must lock the object.
|
||||||
*/
|
*/
|
||||||
void Seek(SongTime t);
|
void Seek(SongTime t);
|
||||||
|
|
||||||
|
@@ -628,6 +628,7 @@ Player::SeekDecoder() noexcept
|
|||||||
try {
|
try {
|
||||||
const PlayerControl::ScopeOccupied occupied(pc);
|
const PlayerControl::ScopeOccupied occupied(pc);
|
||||||
|
|
||||||
|
const std::lock_guard<Mutex> lock(pc.mutex);
|
||||||
dc.Seek(where + start_time);
|
dc.Seek(where + start_time);
|
||||||
} catch (...) {
|
} catch (...) {
|
||||||
/* decoder failure */
|
/* decoder failure */
|
||||||
|
Reference in New Issue
Block a user