pass max_chunks to calculateCrossFadeChunks()
Make calculateCrossFadeChunks() more generic and portable by eliminating global variable access.
This commit is contained in:
parent
0fc2422cd0
commit
0aedf7dd5a
15
src/decode.c
15
src/decode.c
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user