do input buffering in while sleeping loop of sending stuff to output buffer

git-svn-id: https://svn.musicpd.org/mpd/trunk@1125 09075e82-0dd4-0310-85a5-a0d7c8717e4f
This commit is contained in:
Warren Dukes 2004-05-21 22:31:07 +00:00
parent aea1ae9b9e
commit 547e358796
11 changed files with 47 additions and 34 deletions

13
TODO
View File

@ -1,21 +1,16 @@
1) play streams 1) play streams
a) make seekings non-blocking: a) deal with pausing better
1) player: first check that seekWhere isn't already buffered
b) bufferInput in outputBuffer waiting!
1) implement some sort of callback mechanism for this
for abstraction sake
c) deal with pausing better
1) seekable, on resuming pause, check if we need to reconnect, 1) seekable, on resuming pause, check if we need to reconnect,
jumping to offset jumping to offset
2) if seekable, at some point after init, mark this! 2) if seekable, at some point after init, mark this!
3) if not seekable, reset buffer, and elapsedTime when 3) if not seekable, reset buffer, and elapsedTime when
unpaused unpaused
d) put some sort of error reporting for streaming/inputStream! b) put some sort of error reporting for streaming/inputStream!
e) fetch metadata and store in DecoderControl and pass to c) fetch metadata and store in DecoderControl and pass to
PlayerControl PlayerControl
1) eventually deal with icy-metadata 1) eventually deal with icy-metadata
2) parse metadata on the fly in decoders 2) parse metadata on the fly in decoders
f) command for dealing with the changing metadata, currentsonginfo d) command for dealing with the changing metadata, currentsonginfo
or something or something
2) how to deal with streams and the db 2) how to deal with streams and the db

View File

@ -362,8 +362,8 @@ int aac_decode(OutputBuffer * cb, DecoderControl * dc) {
sampleBufferLen = sampleCount*2; sampleBufferLen = sampleCount*2;
sendDataToOutputBuffer(cb,dc,sampleBuffer,sampleBufferLen, sendDataToOutputBuffer(cb, NULL, dc, sampleBuffer,
time,bitRate); sampleBufferLen, time, bitRate);
if(dc->seek) dc->seek = 0; if(dc->seek) dc->seek = 0;
else if(dc->stop) { else if(dc->stop) {
eof = 1; eof = 1;

View File

@ -109,7 +109,11 @@ int audiofile_decode(OutputBuffer * cb, DecoderControl * dc) {
if(ret<=0) eof = 1; if(ret<=0) eof = 1;
else { else {
current += ret; current += ret;
sendDataToOutputBuffer(cb,dc,chunk,ret*fs, sendDataToOutputBuffer(cb,
NULL,
dc,
chunk,
ret*fs,
(float)current / (float)current /
(float)dc->audioFormat.sampleRate, (float)dc->audioFormat.sampleRate,
bitRate); bitRate);

View File

@ -376,7 +376,7 @@ int flacSendChunk(FlacData * data) {
doReplayGain(data->chunk,data->chunk_length,&(data->dc->audioFormat), doReplayGain(data->chunk,data->chunk_length,&(data->dc->audioFormat),
data->replayGainScale); data->replayGainScale);
switch(sendDataToOutputBuffer(data->cb,data->dc,data->chunk, switch(sendDataToOutputBuffer(data->cb, NULL, data->dc, data->chunk,
data->chunk_length, data->time, data->bitRate)) data->chunk_length, data->time, data->bitRate))
{ {
case OUTPUT_BUFFER_DC_STOP: case OUTPUT_BUFFER_DC_STOP:

View File

@ -53,6 +53,9 @@ int openInputStream(InputStream * inStream, char * url);
int seekInputStream(InputStream * inStream, long offset, int whence); int seekInputStream(InputStream * inStream, long offset, int whence);
int closeInputStream(InputStream * inStream); int closeInputStream(InputStream * inStream);
int inputStreamAtEOF(InputStream * inStream); int inputStreamAtEOF(InputStream * inStream);
/* return value: -1 is error, 1 inidicates stuff was buffered, 0 means nothing
was buffered */
int bufferInputStream(InputStream * inStream); int bufferInputStream(InputStream * inStream);
size_t readFromInputStream(InputStream * inStream, void * ptr, size_t size, size_t readFromInputStream(InputStream * inStream, void * ptr, size_t size,

View File

@ -542,20 +542,20 @@ int inputStream_httpBuffer(InputStream * inStream) {
readed = read(data->sock, data->buffer+data->buflen, readed = read(data->sock, data->buffer+data->buflen,
(size_t)(HTTP_BUFFER_SIZE-1-data->buflen)); (size_t)(HTTP_BUFFER_SIZE-1-data->buflen));
if(readed < 0 && (errno == EAGAIN || errno == EINTR)); if(readed < 0 && (errno == EAGAIN || errno == EINTR)) {
readed = 0;
}
else if(readed <= 0) { else if(readed <= 0) {
close(data->sock); close(data->sock);
data->connState = HTTP_CONN_STATE_CLOSED; data->connState = HTTP_CONN_STATE_CLOSED;
readed = 0;
} }
else {
/*fwrite(data->buffer+data->buflen,1,readed,stdout);*/ /*fwrite(data->buffer+data->buflen,1,readed,stdout);*/
data->buflen += readed; data->buflen += readed;
} }
}
if(data->buflen > HTTP_PREBUFFER_SIZE) data->prebuffer = 0; if(data->buflen > HTTP_PREBUFFER_SIZE) data->prebuffer = 0;
return 0; return (readed ? 1 : 0);
} }
/* vim:set shiftwidth=8 tabstop=8 expandtab: */ /* vim:set shiftwidth=8 tabstop=8 expandtab: */

View File

@ -494,7 +494,9 @@ int mp3Read(mp3DecodeData * data, OutputBuffer * cb, DecoderControl * dc) {
if(data->outputPtr==data->outputBufferEnd) { if(data->outputPtr==data->outputBufferEnd) {
long ret; long ret;
ret = sendDataToOutputBuffer(cb,dc, ret = sendDataToOutputBuffer(cb,
data->inStream,
dc,
data->outputBuffer, data->outputBuffer,
MP3_DATA_OUTPUT_BUFFER_SIZE, MP3_DATA_OUTPUT_BUFFER_SIZE,
data->elapsedTime, data->elapsedTime,
@ -584,7 +586,7 @@ int mp3_decode(OutputBuffer * cb, DecoderControl * dc, InputStream * inStream) {
while(mp3Read(&data,cb,dc)!=DECODE_BREAK); while(mp3Read(&data,cb,dc)!=DECODE_BREAK);
/* send last little bit if not dc->stop */ /* send last little bit if not dc->stop */
if(data.outputPtr!=data.outputBuffer && data.flush) { if(data.outputPtr!=data.outputBuffer && data.flush) {
if(sendDataToOutputBuffer(cb,dc,data.outputBuffer, if(sendDataToOutputBuffer(cb,NULL,dc,data.outputBuffer,
data.outputPtr-data.outputBuffer, data.outputPtr-data.outputBuffer,
data.elapsedTime,data.bitRate/1000) == 0) data.elapsedTime,data.bitRate/1000) == 0)
{ {

View File

@ -279,7 +279,7 @@ int mp4_decode(OutputBuffer * cb, DecoderControl * dc) {
sampleBuffer+=offset*channels*2; sampleBuffer+=offset*channels*2;
sendDataToOutputBuffer(cb,dc,sampleBuffer, sendDataToOutputBuffer(cb, NULL, dc, sampleBuffer,
sampleBufferLen, time, bitRate); sampleBufferLen, time, bitRate);
if(dc->stop) { if(dc->stop) {
eof = 1; eof = 1;

View File

@ -241,15 +241,15 @@ int ogg_decode(OutputBuffer * cb, DecoderControl * dc, InputStream * inStream)
} }
doReplayGain(chunk,ret,&(dc->audioFormat), doReplayGain(chunk,ret,&(dc->audioFormat),
replayGainScale); replayGainScale);
sendDataToOutputBuffer(cb,dc,chunk,chunkpos, sendDataToOutputBuffer(cb, inStream, dc, chunk,
ov_time_tell(&vf),bitRate); chunkpos, ov_time_tell(&vf), bitRate);
if(dc->stop) break; if(dc->stop) break;
chunkpos = 0; chunkpos = 0;
} }
} }
if(!dc->stop && chunkpos > 0) { if(!dc->stop && chunkpos > 0) {
sendDataToOutputBuffer(cb,dc,chunk,chunkpos, sendDataToOutputBuffer(cb, NULL, dc, chunk, chunkpos,
ov_time_tell(&vf), bitRate); ov_time_tell(&vf), bitRate);
} }

View File

@ -43,8 +43,9 @@ void flushOutputBuffer(OutputBuffer * cb) {
} }
} }
int sendDataToOutputBuffer(OutputBuffer * cb, DecoderControl * dc, int sendDataToOutputBuffer(OutputBuffer * cb, InputStream * inStream,
char * dataIn, long dataInLen, float time, mpd_uint16 bitRate) DecoderControl * dc, char * dataIn, long dataInLen, float time,
mpd_uint16 bitRate)
{ {
mpd_uint16 dataToSend; mpd_uint16 dataToSend;
mpd_uint16 chunkLeft; mpd_uint16 chunkLeft;
@ -74,9 +75,13 @@ int sendDataToOutputBuffer(OutputBuffer * cb, DecoderControl * dc,
while(datalen) { while(datalen) {
if(currentChunk != cb->end) { if(currentChunk != cb->end) {
while(cb->begin==cb->end && cb->wrap && !dc->stop) while(cb->begin==cb->end && cb->wrap && !dc->stop)
{
if(!inStream ||
bufferInputStream(inStream) <= 0)
{ {
my_usleep(10000); my_usleep(10000);
} }
}
if(dc->stop) return OUTPUT_BUFFER_DC_STOP; if(dc->stop) return OUTPUT_BUFFER_DC_STOP;
currentChunk = cb->end; currentChunk = cb->end;

View File

@ -22,6 +22,7 @@
#include "mpd_types.h" #include "mpd_types.h"
#include "decode.h" #include "decode.h"
#include "audio.h" #include "audio.h"
#include "inputStream.h"
#define OUTPUT_BUFFER_DC_STOP -1 #define OUTPUT_BUFFER_DC_STOP -1
#define OUTPUT_BUFFER_DC_SEEK -2 #define OUTPUT_BUFFER_DC_SEEK -2
@ -42,8 +43,11 @@ void clearOutputBuffer(OutputBuffer * cb);
void flushOutputBuffer(OutputBuffer * cb); void flushOutputBuffer(OutputBuffer * cb);
int sendDataToOutputBuffer(OutputBuffer * cb, DecoderControl * dc, /* we send inStream where for buffering the inputStream while waiting to
char * data, long datalen, float time, mpd_uint16 bitRate); send the next chunk */
int sendDataToOutputBuffer(OutputBuffer * cb, InputStream * inStream,
DecoderControl * dc, char * data, long datalen, float time,
mpd_uint16 bitRate);
#endif #endif
/* vim:set shiftwidth=4 tabstop=8 expandtab: */ /* vim:set shiftwidth=4 tabstop=8 expandtab: */