pass max_chunks to calculateCrossFadeChunks()

Make calculateCrossFadeChunks() more generic and portable by
eliminating global variable access.
This commit is contained in:
Max Kellermann 2008-08-26 08:27:09 +02:00
parent 0fc2422cd0
commit 0aedf7dd5a

View File

@ -64,9 +64,10 @@ static void quitDecode(void)
wakeup_main_task(); wakeup_main_task();
} }
static unsigned calculateCrossFadeChunks(AudioFormat * af, float totalTime) static unsigned calculateCrossFadeChunks(AudioFormat * af,
float totalTime, unsigned max_chunks)
{ {
unsigned int buffered_chunks, chunks; unsigned int chunks;
if (pc.crossFade == 0 || pc.crossFade >= totalTime || if (pc.crossFade == 0 || pc.crossFade >= totalTime ||
!isCurrentAudioFormat(af)) !isCurrentAudioFormat(af))
@ -80,10 +81,8 @@ static unsigned calculateCrossFadeChunks(AudioFormat * af, float totalTime)
chunks = (af->sampleRate * af->bits * af->channels / 8.0 / CHUNK_SIZE); chunks = (af->sampleRate * af->bits * af->channels / 8.0 / CHUNK_SIZE);
chunks = (chunks * pc.crossFade + 0.5); chunks = (chunks * pc.crossFade + 0.5);
buffered_chunks = ob.size; if (chunks > max_chunks)
assert(buffered_chunks >= buffered_before_play); chunks = max_chunks;
if (chunks > (buffered_chunks - buffered_before_play))
chunks = buffered_chunks - buffered_before_play;
return chunks; return chunks;
} }
@ -500,7 +499,9 @@ static void decodeParent(void)
for it */ for it */
crossFadeChunks = crossFadeChunks =
calculateCrossFadeChunks(&(ob.audioFormat), calculateCrossFadeChunks(&(ob.audioFormat),
dc.totalTime); dc.totalTime,
ob.size -
buffered_before_play);
if (crossFadeChunks > 0) { if (crossFadeChunks > 0) {
do_xfade = XFADE_ENABLED; do_xfade = XFADE_ENABLED;
nextChunk = -1; nextChunk = -1;