assume the buffer is empty in flacWrite()
flacWrite() is the only function which sets data->chunk_length. If we flush the buffer before we return, we can assume that it is always empty upon entering flacWrite(). git-svn-id: https://svn.musicpd.org/mpd/trunk@7328 09075e82-0dd4-0310-85a5-a0d7c8717e4f
This commit is contained in:
parent
ca1090f93b
commit
a91f2a1f05
@ -238,7 +238,8 @@ static FLAC__StreamDecoderWriteStatus flacWrite(const flac_decoder *dec,
|
|||||||
const unsigned int bytes_per_sample = (data->dc->audioFormat.bits / 8);
|
const unsigned int bytes_per_sample = (data->dc->audioFormat.bits / 8);
|
||||||
const unsigned int bytes_per_channel =
|
const unsigned int bytes_per_channel =
|
||||||
bytes_per_sample * frame->header.channels;
|
bytes_per_sample * frame->header.channels;
|
||||||
unsigned int num_samples, max_samples;
|
const unsigned int max_samples = FLAC_CHUNK_SIZE / bytes_per_channel;
|
||||||
|
unsigned int num_samples;
|
||||||
float timeChange;
|
float timeChange;
|
||||||
FLAC__uint64 newPosition = 0;
|
FLAC__uint64 newPosition = 0;
|
||||||
|
|
||||||
@ -261,15 +262,13 @@ static FLAC__StreamDecoderWriteStatus flacWrite(const flac_decoder *dec,
|
|||||||
for (c_samp = 0; c_samp < frame->header.blocksize;
|
for (c_samp = 0; c_samp < frame->header.blocksize;
|
||||||
c_samp += num_samples) {
|
c_samp += num_samples) {
|
||||||
num_samples = frame->header.blocksize - c_samp;
|
num_samples = frame->header.blocksize - c_samp;
|
||||||
max_samples = (FLAC_CHUNK_SIZE - data->chunk_length) /
|
|
||||||
bytes_per_channel;
|
|
||||||
if (num_samples > max_samples)
|
if (num_samples > max_samples)
|
||||||
num_samples = max_samples;
|
num_samples = max_samples;
|
||||||
|
|
||||||
flac_convert(data->chunk + data->chunk_length,
|
flac_convert(data->chunk + data->chunk_length,
|
||||||
frame, bytes_per_sample, buf,
|
frame, bytes_per_sample, buf,
|
||||||
c_samp, c_samp + num_samples);
|
c_samp, c_samp + num_samples);
|
||||||
data->chunk_length += num_samples;
|
data->chunk_length = num_samples;
|
||||||
|
|
||||||
if (flacSendChunk(data) < 0) {
|
if (flacSendChunk(data) < 0) {
|
||||||
return
|
return
|
||||||
|
Loading…
x
Reference in New Issue
Block a user