Compare commits

..

2 commits

Author SHA1 Message Date
Christopher Snowhill
646531f8ae Playback: Redo seeking to stick with the open file
Some checks are pending
Check if Cog buildable / Build Universal Cog.app (push) Waiting to run
Again, this is for the best anyway. Reopening the file repeatedly really
was slow, and resulted in deadlocks with rapid fire seeking, especially
with the Touch Bar scrubber control.

Signed-off-by: Christopher Snowhill <kode54@gmail.com>
2025-06-26 21:53:14 -07:00
Christopher Snowhill
b5b752c884 Playback: Relax waiting on main thread a bit
Relax it from cycling for 1ms to 10ms. This isn't absolutely time
critical, after all, since this usually happens when there is some
buffering.

Signed-off-by: Christopher Snowhill <kode54@gmail.com>
2025-06-26 21:53:09 -07:00

View file

@ -196,18 +196,28 @@
}
- (void)seekToTime:(double)time {
[output fadeOutBackground];
[output setVolume:volume];
[output seek:time];
[bufferChain seek:time];
CogStatus status = (CogStatus)currentPlaybackStatus;
NSURL *url;
BOOL paused = status == CogStatusPaused;
id userInfo;
NSDictionary *rgi;
@synchronized(chainQueue) {
url = [bufferChain streamURL];
userInfo = [bufferChain userInfo];
rgi = [bufferChain rgInfo];
}
[self play:url withUserInfo:userInfo withRGInfo:rgi startPaused:(status == CogStatusPaused) andSeekTo:time andResumeInterval:YES];
if(paused) {
[self setPlaybackStatus:CogStatusPaused waitUntilDone:YES];
if(time > 0.0) {
[self updatePosition:userInfo];
}
} else {
[output fadeIn];
}
}
- (void)setVolume:(double)v {
@ -694,7 +704,7 @@
while(atomic_load_explicit(&refCount, memory_order_relaxed) != 0) {
[semaphore signal]; // Gotta poke this periodically
if(mainThread)
[[NSRunLoop currentRunLoop] runUntilDate:[NSDate dateWithTimeIntervalSinceNow:0.001]];
[[NSRunLoop currentRunLoop] runUntilDate:[NSDate dateWithTimeIntervalSinceNow:0.01]];
else
usleep(500);
}