mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-26 02:42:02 +01:00
audio/internal/readerdriver: Bug fix: Possible busy loop when a player reaches EOF
This commit is contained in:
parent
ea6e2091c5
commit
9f9d53aad3
@ -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
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user