mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-13 20:42:07 +01:00
audio/internal/readerdriver: Refactoring: Remove player.id
This commit is contained in:
parent
383bceddd5
commit
9caead5a38
@ -23,20 +23,6 @@ package readerdriver
|
|||||||
// void ebiten_readerdriver_render(void* inUserData, AudioQueueRef inAQ, AudioQueueBufferRef inBuffer);
|
// void ebiten_readerdriver_render(void* inUserData, AudioQueueRef inAQ, AudioQueueBufferRef inBuffer);
|
||||||
//
|
//
|
||||||
// void ebiten_readerdriver_setNotificationHandler();
|
// void ebiten_readerdriver_setNotificationHandler();
|
||||||
//
|
|
||||||
// // ebiten_readerdriver_AudioQueueNewOutput is a wrapper for AudioQueueNewOutput.
|
|
||||||
// // This is to avoid go-vet warnings of an unsafe.Pointer usage.
|
|
||||||
// // TODO: Use cgo.Handle (https://tip.golang.org/pkg/runtime/cgo/#Handle) when Go 1.17 becomes the minimum supported version.
|
|
||||||
// static OSStatus ebiten_readerdriver_AudioQueueNewOutput(
|
|
||||||
// const AudioStreamBasicDescription *inFormat,
|
|
||||||
// AudioQueueOutputCallback inCallbackProc,
|
|
||||||
// uintptr_t inUserData,
|
|
||||||
// CFRunLoopRef inCallbackRunLoop,
|
|
||||||
// CFStringRef inCallbackRunLoopMode,
|
|
||||||
// UInt32 inFlags,
|
|
||||||
// AudioQueueRef *outAQ) {
|
|
||||||
// return AudioQueueNewOutput(inFormat, inCallbackProc, (void*)(inUserData), inCallbackRunLoop, inCallbackRunLoopMode, inFlags, outAQ);
|
|
||||||
// }
|
|
||||||
import "C"
|
import "C"
|
||||||
|
|
||||||
import (
|
import (
|
||||||
@ -100,45 +86,36 @@ type playerImpl struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type players struct {
|
type players struct {
|
||||||
players map[int]*playerImpl
|
players map[C.AudioQueueRef]*playerImpl
|
||||||
toResume map[*playerImpl]struct{}
|
toResume map[*playerImpl]struct{}
|
||||||
m sync.Mutex
|
m sync.Mutex
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *players) add(player *playerImpl) int {
|
func (p *players) add(player *playerImpl, audioQueue C.AudioQueueRef) {
|
||||||
p.m.Lock()
|
p.m.Lock()
|
||||||
defer p.m.Unlock()
|
defer p.m.Unlock()
|
||||||
|
|
||||||
id := 1
|
|
||||||
for {
|
|
||||||
if _, ok := p.players[id]; ok {
|
|
||||||
id++
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
break
|
|
||||||
}
|
|
||||||
if p.players == nil {
|
if p.players == nil {
|
||||||
p.players = map[int]*playerImpl{}
|
p.players = map[C.AudioQueueRef]*playerImpl{}
|
||||||
}
|
}
|
||||||
p.players[id] = player
|
p.players[audioQueue] = player
|
||||||
return id
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *players) get(id int) *playerImpl {
|
func (p *players) get(audioQueue C.AudioQueueRef) *playerImpl {
|
||||||
p.m.Lock()
|
p.m.Lock()
|
||||||
defer p.m.Unlock()
|
defer p.m.Unlock()
|
||||||
return p.players[id]
|
return p.players[audioQueue]
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *players) remove(id int) {
|
func (p *players) remove(audioQueue C.AudioQueueRef) {
|
||||||
p.m.Lock()
|
p.m.Lock()
|
||||||
defer p.m.Unlock()
|
defer p.m.Unlock()
|
||||||
|
|
||||||
pl, ok := p.players[id]
|
pl, ok := p.players[audioQueue]
|
||||||
if !ok {
|
if !ok {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
delete(p.players, id)
|
delete(p.players, audioQueue)
|
||||||
delete(p.toResume, pl)
|
delete(p.toResume, pl)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -190,7 +167,6 @@ func (c *context) NewPlayer(src io.Reader) Player {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
runtime.SetFinalizer(p, (*player).Close)
|
runtime.SetFinalizer(p, (*player).Close)
|
||||||
p.p.id = thePlayers.add(p.p)
|
|
||||||
return p
|
return p
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -239,10 +215,10 @@ func (p *playerImpl) Play() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var audioQueue C.AudioQueueRef
|
var audioQueue C.AudioQueueRef
|
||||||
if osstatus := C.ebiten_readerdriver_AudioQueueNewOutput(
|
if osstatus := C.AudioQueueNewOutput(
|
||||||
&desc,
|
&desc,
|
||||||
(C.AudioQueueOutputCallback)(C.ebiten_readerdriver_render),
|
(C.AudioQueueOutputCallback)(C.ebiten_readerdriver_render),
|
||||||
C.uintptr_t(p.id),
|
nil,
|
||||||
(C.CFRunLoopRef)(0),
|
(C.CFRunLoopRef)(0),
|
||||||
(C.CFStringRef)(0),
|
(C.CFStringRef)(0),
|
||||||
0,
|
0,
|
||||||
@ -265,6 +241,8 @@ func (p *playerImpl) Play() {
|
|||||||
|
|
||||||
C.AudioQueueSetParameter(p.audioQueue, C.kAudioQueueParam_Volume, C.AudioQueueParameterValue(p.volume))
|
C.AudioQueueSetParameter(p.audioQueue, C.kAudioQueueParam_Volume, C.AudioQueueParameterValue(p.volume))
|
||||||
|
|
||||||
|
thePlayers.add(p, p.audioQueue)
|
||||||
|
|
||||||
runLoop = true
|
runLoop = true
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -451,18 +429,17 @@ func (p *playerImpl) closeImpl() error {
|
|||||||
if osstatus := C.AudioQueueDispose(p.audioQueue, C.true); osstatus != C.noErr && p.err != nil {
|
if osstatus := C.AudioQueueDispose(p.audioQueue, C.true); osstatus != C.noErr && p.err != nil {
|
||||||
p.err = fmt.Errorf("readerdriver: AudioQueueDispose failed: %d", osstatus)
|
p.err = fmt.Errorf("readerdriver: AudioQueueDispose failed: %d", osstatus)
|
||||||
}
|
}
|
||||||
|
thePlayers.remove(p.audioQueue)
|
||||||
p.audioQueue = nil
|
p.audioQueue = nil
|
||||||
}
|
}
|
||||||
p.state = playerClosed
|
p.state = playerClosed
|
||||||
p.cond.Signal()
|
p.cond.Signal()
|
||||||
thePlayers.remove(p.id)
|
|
||||||
return p.err
|
return p.err
|
||||||
}
|
}
|
||||||
|
|
||||||
//export ebiten_readerdriver_render
|
//export ebiten_readerdriver_render
|
||||||
func ebiten_readerdriver_render(inUserData unsafe.Pointer, inAQ C.AudioQueueRef, inBuffer C.AudioQueueBufferRef) {
|
func ebiten_readerdriver_render(inUserData unsafe.Pointer, inAQ C.AudioQueueRef, inBuffer C.AudioQueueBufferRef) {
|
||||||
id := int(uintptr(inUserData))
|
p := thePlayers.get(inAQ)
|
||||||
p := thePlayers.get(id)
|
|
||||||
queued, err := p.appendBuffer(inBuffer)
|
queued, err := p.appendBuffer(inBuffer)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
p.setError(err)
|
p.setError(err)
|
||||||
|
Loading…
Reference in New Issue
Block a user