Audio Player: Add new method of signaling stop

This new method should cause all stops to default to immediate stoppage,
and only stops that occur after an end of track signal should indicate
to play out the entire buffer.

Signed-off-by: Christopher Snowhill <kode54@gmail.com>
main
Christopher Snowhill 2022-12-09 21:14:45 -08:00
parent 4f942ac890
commit 447a60afd9
No known key found for this signature in database
5 changed files with 30 additions and 1 deletions

View File

@ -315,6 +315,8 @@
// if there's already one at the head of chainQueue... r-r-right? // if there's already one at the head of chainQueue... r-r-right?
for(BufferChain *chain in chainQueue) { for(BufferChain *chain in chainQueue) {
if([chain isRunning]) { if([chain isRunning]) {
if(output)
[output setShouldPlayOutBuffer:YES];
atomic_fetch_sub(&refCount, 1); atomic_fetch_sub(&refCount, 1);
return YES; return YES;
} }
@ -338,6 +340,8 @@
while(duration >= 30.0 && shouldContinue) { while(duration >= 30.0 && shouldContinue) {
[semaphore wait]; [semaphore wait];
if(atomic_load_explicit(&resettingNow, memory_order_relaxed)) { if(atomic_load_explicit(&resettingNow, memory_order_relaxed)) {
if(output)
[output setShouldPlayOutBuffer:YES];
atomic_fetch_sub(&refCount, 1); atomic_fetch_sub(&refCount, 1);
return YES; return YES;
} }
@ -357,6 +361,8 @@
[self requestNextStream:nextStreamUserInfo]; [self requestNextStream:nextStreamUserInfo];
if(!nextStream) { if(!nextStream) {
if(output)
[output setShouldPlayOutBuffer:YES];
atomic_fetch_sub(&refCount, 1); atomic_fetch_sub(&refCount, 1);
return YES; return YES;
} }
@ -407,6 +413,8 @@
while(shouldContinue && ![newChain open:url withUserInfo:nextStreamUserInfo withRGInfo:nextStreamRGInfo]) { while(shouldContinue && ![newChain open:url withUserInfo:nextStreamUserInfo withRGInfo:nextStreamRGInfo]) {
if(nextStream == nil) { if(nextStream == nil) {
newChain = nil; newChain = nil;
if(output)
[output setShouldPlayOutBuffer:YES];
atomic_fetch_sub(&refCount, 1); atomic_fetch_sub(&refCount, 1);
return YES; return YES;
} }
@ -416,6 +424,8 @@
if([nextStream isEqualTo:url]) { if([nextStream isEqualTo:url]) {
newChain = nil; newChain = nil;
if(output)
[output setShouldPlayOutBuffer:YES];
atomic_fetch_sub(&refCount, 1); atomic_fetch_sub(&refCount, 1);
return YES; return YES;
} }
@ -442,6 +452,9 @@
// - self.nextStreamUserInfo == next playlist entry // - self.nextStreamUserInfo == next playlist entry
// - head of chainQueue is the buffer chain for the next entry (which has launched its threads already) // - head of chainQueue is the buffer chain for the next entry (which has launched its threads already)
if(output)
[output setShouldPlayOutBuffer:YES];
atomic_fetch_sub(&refCount, 1); atomic_fetch_sub(&refCount, 1);
return YES; return YES;
} }

View File

@ -63,6 +63,8 @@
- (void)setShouldContinue:(BOOL)s; - (void)setShouldContinue:(BOOL)s;
- (void)setShouldPlayOutBuffer:(BOOL)s;
- (void)pause; - (void)pause;
- (void)resume; - (void)resume;

View File

@ -170,6 +170,10 @@
// [output stop]; // [output stop];
} }
- (void)setShouldPlayOutBuffer:(BOOL)s {
[output setShouldPlayOutBuffer:s];
}
- (BOOL)isPaused { - (BOOL)isPaused {
return paused; return paused;
} }

View File

@ -117,6 +117,8 @@ using std::atomic_long;
BOOL resetStreamFormat; BOOL resetStreamFormat;
BOOL shouldPlayOutBuffer;
float *samplePtr; float *samplePtr;
float tempBuffer[512 * 32]; float tempBuffer[512 * 32];
float r8bTempBuffer[4096 * 32]; float r8bTempBuffer[4096 * 32];
@ -149,6 +151,8 @@ using std::atomic_long;
- (void)setEqualizerEnabled:(BOOL)enabled; - (void)setEqualizerEnabled:(BOOL)enabled;
- (void)setShouldPlayOutBuffer:(BOOL)enabled;
- (void)sustainHDCD; - (void)sustainHDCD;
@end @end

View File

@ -342,6 +342,7 @@ current_device_listener(AudioObjectID inObjectID, UInt32 inNumberAddresses, cons
- (void)threadEntry:(id)arg { - (void)threadEntry:(id)arg {
running = YES; running = YES;
started = NO; started = NO;
shouldPlayOutBuffer = NO;
secondsLatency = 1.0; secondsLatency = 1.0;
while(!stopping) { while(!stopping) {
@ -940,6 +941,7 @@ current_device_listener(AudioObjectID inObjectID, UInt32 inNumberAddresses, cons
stopInvoked = NO; stopInvoked = NO;
stopCompleted = NO; stopCompleted = NO;
commandStop = NO; commandStop = NO;
shouldPlayOutBuffer = NO;
audioFormatDescription = NULL; audioFormatDescription = NULL;
@ -1208,7 +1210,7 @@ current_device_listener(AudioObjectID inObjectID, UInt32 inNumberAddresses, cons
} }
if(renderSynchronizer || audioRenderer) { if(renderSynchronizer || audioRenderer) {
if(renderSynchronizer) { if(renderSynchronizer) {
if(!commandStop) { if(shouldPlayOutBuffer && !commandStop) {
int compareVal = 0; int compareVal = 0;
double secondsLatency = self->secondsLatency >= 0 ? self->secondsLatency : 0; double secondsLatency = self->secondsLatency >= 0 ? self->secondsLatency : 0;
int compareMax = (((1000000 / 5000) * secondsLatency) + (10000 / 5000)); // latency plus 10ms, divide by sleep intervals int compareMax = (((1000000 / 5000) * secondsLatency) + (10000 / 5000)); // latency plus 10ms, divide by sleep intervals
@ -1302,4 +1304,8 @@ current_device_listener(AudioObjectID inObjectID, UInt32 inNumberAddresses, cons
secondsHdcdSustained = 10.0; secondsHdcdSustained = 10.0;
} }
- (void)setShouldPlayOutBuffer:(BOOL)s {
shouldPlayOutBuffer = s;
}
@end @end