mirror of
https://github.com/danbee/persephone
synced 2025-03-04 08:39:11 +00:00
Fix a nasty deadlock
This commit is contained in:
parent
cff3e7bfc6
commit
6236884195
@ -42,14 +42,16 @@ extension MPDClient {
|
||||
|
||||
func handleIdleResult(_ result: mpd_idle) {
|
||||
let mpdIdle = MPDIdle(rawValue: result.rawValue)
|
||||
let wasIdle: Bool
|
||||
|
||||
do {
|
||||
idleLock.lock()
|
||||
defer { idleLock.unlock() }
|
||||
|
||||
if isIdle {
|
||||
wasIdle = isIdle
|
||||
isIdle = false
|
||||
}
|
||||
|
||||
if wasIdle {
|
||||
if mpdIdle.contains(.database) {
|
||||
self.fetchAllAlbums()
|
||||
}
|
||||
@ -79,11 +81,9 @@ extension MPDClient {
|
||||
self.delegate?.didFinishDatabaseUpdate(mpdClient: self)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if !mpdIdle.isEmpty {
|
||||
self.idle()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Loading…
Reference in New Issue
Block a user