audio/internal/readerdriver: Bug fix: Possible busy loop when a player reaches EOF

This commit is contained in:
Hajime Hoshi 2021-06-07 03:03:22 +09:00
parent ea6e2091c5
commit 9f9d53aad3

View File

@ -36,7 +36,7 @@ func newPlayers() *players {
func (ps *players) shouldWait() bool { func (ps *players) shouldWait() bool {
for p := range ps.players { for p := range ps.players {
if !p.isBufferFull() { if p.canReadSourceToBuffer() {
return false return false
} }
} }
@ -115,6 +115,7 @@ type playerImpl struct {
err error err error
state playerState state playerState
buf []byte buf []byte
eof bool
m sync.Mutex m sync.Mutex
} }
@ -184,7 +185,9 @@ func (p *playerImpl) playImpl() {
} }
} }
p.state = playerPlay if !p.eof || len(p.buf) > 0 {
p.state = playerPlay
}
p.m.Unlock() p.m.Unlock()
p.players.addPlayer(p) p.players.addPlayer(p)
@ -221,6 +224,7 @@ func (p *playerImpl) resetImpl() {
} }
p.state = playerPaused p.state = playerPaused
p.buf = p.buf[:0] p.buf = p.buf[:0]
p.eof = false
} }
func (p *player) IsPlaying() bool { func (p *player) IsPlaying() bool {
@ -320,10 +324,14 @@ func (p *playerImpl) readBufferAndAdd(buf []float32) int {
return n return n
} }
func (p *playerImpl) isBufferFull() bool { func (p *playerImpl) canReadSourceToBuffer() bool {
p.m.Lock() p.m.Lock()
defer p.m.Unlock() defer p.m.Unlock()
return len(p.buf) >= p.context.maxBufferSize()
if p.eof {
return false
}
return len(p.buf) < p.context.maxBufferSize()
} }
func (p *playerImpl) readSourceToBuffer() { func (p *playerImpl) readSourceToBuffer() {
@ -355,7 +363,8 @@ func (p *playerImpl) readSourceToBuffer() {
p.buf = append(p.buf, buf[:n]...) p.buf = append(p.buf, buf[:n]...)
if err == io.EOF && len(p.buf) == 0 { if err == io.EOF && len(p.buf) == 0 {
p.resetImpl() p.state = playerPaused
p.eof = true
} }
} }