better handling of FLAC__STREAM_DECODER_READ_STATUS_END_OF_STREAM in read_callback_()
authorJosh Coalson <jcoalson@users.sourceforce.net>
Tue, 23 Sep 2003 20:45:59 +0000 (20:45 +0000)
committerJosh Coalson <jcoalson@users.sourceforce.net>
Tue, 23 Sep 2003 20:45:59 +0000 (20:45 +0000)
src/libOggFLAC/stream_decoder.c

index 66f2bdf107cc0a8a82f23f9e6a9751c5f444d5fd..c98cfef8414de306695b363bc50f516dbeab1bea 100644 (file)
@@ -484,9 +484,13 @@ FLAC__StreamDecoderReadStatus read_callback_(const FLAC__StreamDecoder *unused,
        }
 
        ogg_bytes_read = ogg_bytes_to_read;
-       if(decoder->private_->read_callback(decoder, (FLAC__byte*)oggbuf, &ogg_bytes_read, decoder->private_->client_data) != FLAC__STREAM_DECODER_READ_STATUS_CONTINUE) {
-               decoder->protected_->state = OggFLAC__STREAM_DECODER_READ_ERROR;
-               return FLAC__STREAM_DECODER_READ_STATUS_ABORT;
+       {
+               FLAC__StreamDecoderReadStatus read_status = decoder->private_->read_callback(decoder, (FLAC__byte*)oggbuf, &ogg_bytes_read, decoder->private_->client_data);
+               if(read_status != FLAC__STREAM_DECODER_READ_STATUS_CONTINUE) {
+                       if(read_status == FLAC__STREAM_DECODER_READ_STATUS_ABORT)
+                               decoder->protected_->state = OggFLAC__STREAM_DECODER_READ_ERROR;
+                       return read_status;
+               }
        }
 
        if(ogg_sync_wrote(&decoder->private_->ogg.sync_state, ogg_bytes_read) < 0) {