From 7775d3b994c97139d753233e7dc638e927f8e1d6 Mon Sep 17 00:00:00 2001 From: pax-k Date: Mon, 15 Jul 2024 14:33:43 +0300 Subject: [PATCH] fix: bufferAccessQueue for scheduleNextBuffer? --- ios/AudioController.swift | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/ios/AudioController.swift b/ios/AudioController.swift index 8fb7c11..8ada12f 100644 --- a/ios/AudioController.swift +++ b/ios/AudioController.swift @@ -330,7 +330,6 @@ public class AudioController { } private func scheduleNextBuffer() { - // self.bufferAccessQueue.async { guard let engine = self.audioEngine, engine.isRunning else { DispatchQueue.main.asyncAfter(deadline: .now() + 0.05) { // Check every 50 milliseconds self.scheduleNextBuffer() @@ -346,19 +345,20 @@ public class AudioController { // promise(nil) // } // } - if let (buffer, promise) = bufferQueue.first { - bufferQueue.removeFirst() - - self.audioPlayerNode!.scheduleBuffer(buffer) { - promise(nil) + self.bufferAccessQueue.async { + if let (buffer, promise) = self.bufferQueue.first { + self.bufferQueue.removeFirst() - let bufferDuration = Double(buffer.frameLength) / buffer.format.sampleRate - DispatchQueue.main.asyncAfter(deadline: .now() + bufferDuration) { - self.scheduleNextBuffer() + self.audioPlayerNode!.scheduleBuffer(buffer) { + promise(nil) + + let bufferDuration = Double(buffer.frameLength) / buffer.format.sampleRate + DispatchQueue.main.asyncAfter(deadline: .now() + bufferDuration) { + self.scheduleNextBuffer() + } } } } - // } } // private func currentQueue() -> [(buffer: AVAudioPCMBuffer, promise: RCTPromiseResolveBlock)] {