aboutsummaryrefslogtreecommitdiffstats
path: root/src/input_curl.c (unfollow)
Commit message (Collapse)AuthorFilesLines
2008-11-30input_curl: follow HTTP redirectsMax Kellermann1-0/+2
Follow HTTP redirects, but no more than 5.
2008-11-30input_curl: send a User-Agent headerMax Kellermann1-0/+3
Send "Music Player Daemon " + VERSION as the User-Agent request header.
2008-11-25input_curl: disable Icy-MetadataMax Kellermann1-0/+2
input_curl.c does not support parsing shoutcast metadata yet. Disable the "Icy-Metadata" header for now, since it may cause corruptions in the stream.
2008-11-24input_curl.c: replaced mpd_unused by G_GNUC_UNUSEDThomas Jansen1-2/+1
2008-11-21input_curl: try to seek by fast-forwarding the bufferMax Kellermann1-0/+26
If the caller attempts to seek only a few bytes forward, chances are good that the offset is already in the buffer. In this case, simply fast-forward the buffer.
2008-11-21input_curl: moved code to consume_buffer()Max Kellermann1-12/+26
Added some assertions.
2008-11-21input_curl: don't do temporary calculations with input_stream.offsetMax Kellermann1-4/+4
If someone calls seek() with an invalid (negative) offset, the curl implementation of that method returned false, but left this invalid offset in input_stream.offset. Move the calculation to a temporary variable.
2008-11-20input_curl: don't fail when seek to EOF is requestedMax Kellermann1-0/+8
HTTP servers respond with "416 Requested Range Not Satisfiable" when a client attempts to seek to the end of the file. Catch this special case in input_curl_seek(). This fixes a glitch in the ogg vorbis decoder plugin.
2008-11-20curl: don't check running_handles for EOFMax Kellermann1-7/+1
Since we are using curl_multi_info_read() / CURLMSG_DONE for detecting end-of-response, we can remove all running_handles==0 checks. For some reason, that has never worked correctly.
2008-11-20input_curl: always set eof=true on CURLMSG_DONEMax Kellermann1-5/+7
curl_multi_info_read() is the authoritative source of the "end-of-response" information. Always set c->eof when a CURLMSG_DONE message is received, and check the result (success/failure) after that.
2008-11-16input_stream: size==-1 means unknown sizeMax Kellermann1-0/+4
Define the special value "-1" as "unknown size". Previously, there was no indicator for streams with unknown size, which might confuse some decoders.
2008-11-06input_curl: retrieve error message from ERRORBUFFERMax Kellermann1-2/+5
libcurl provides better error messages than curl_multi_strerror() when you set the ERRORBUFFER option.
2008-11-06input_curl: return 0 on error from read()Max Kellermann1-1/+2
The read() method must not return a negative value. Make it return 0 on error, just like the file input stream. Also set the "error" attribute to -1.
2008-11-06input_curl: enable FAILONERRORMax Kellermann1-0/+1
I had this option enabled during development, but at some point, it must have gotten lost. FAILONERROR makes the curl stream fail when the server returns a status code 400 or higher. We are not interested in the server's error document.
2008-11-03input_curl: use curl_multi_info_read()Max Kellermann1-1/+32
The function curl_multi_info_read() provides access to errors from the curl easy interface.
2008-11-02input_curl: buffered rewindingMax Kellermann1-3/+115
During codec detection, the beginning of the stream is consumed. This is a common operation, which takes a lot of time when handling remote resources. To optimize this, remember the first 64 kB of a stream. This way, we can rewind the stream without actually fetching the start of the stream again.
2008-10-28input_stream: convert offset and size to the off_t data typeMax Kellermann1-6/+5
size_t and long aren't 64 bit safe (i.e. files larger than 2 GB on a 32 bit OS). Use off_t instead, which is a 64 bit integer if compiled with large file support.
2008-10-27input_file, input_curl: check URL type before attempting to openMax Kellermann1-0/+3
Don't attempt to open a HTTP URL as a local file, and don't send a local path to libcurl.
2008-10-26curl: read stream name from HTTP response headersMax Kellermann1-0/+5
If the server sends the headers "icy-name", "ice-name", "x-audiocast-name", set the stream title.
2008-10-26input_curl: set input_stream.mime from Content-Type response headerMax Kellermann1-0/+3
2008-10-26input_curl: added local variable "value"Max Kellermann1-14/+22
Replaced the local variable "colon" (which had only temporary meaning) with the variable "value". It is a pointer to the first byte of the header value.
2008-10-26input_stream: use "bool" instead of "int"Max Kellermann1-8/+8
For boolean values and success flags, use bool instead of integer (1/0 for true/false, 0/-1 for success/failure).
2008-10-26input_stream: input_stream_close() returns voidMax Kellermann1-2/+1
close() shouldn't fail with read-only streams.
2008-10-26input_stream: added struct input_pluginMax Kellermann1-7/+11
Instead of managing a set of method pointers in each input_stream struct, move these into the new input_plugin struct. Each input_stream has only a pointer to the plugin struct. Pointers to all implementations are kept in the array "input_plugins".
2008-10-26input_stream: renamed sources, no CamelCaseMax Kellermann1-1/+1
Renamed inputStream.c and inputStream_file.c.
2008-10-26http: use libcurlMax Kellermann1-0/+493
MPD's HTTP client code has always been broken, no matter how effort was put into fixing it. Replace it with libcurl, which is known to be quite stable. This adds a fat library dependency, but only for people who need streaming.