diff options
author | Max Kellermann <max@duempel.org> | 2009-01-15 16:12:22 +0100 |
---|---|---|
committer | Max Kellermann <max@duempel.org> | 2009-01-15 16:16:55 +0100 |
commit | f1790fc8bf1fe46f977b6ecad0e1cd03b7edde82 (patch) | |
tree | d5001bc451f68810949ebd0b9a3a6603198f250c | |
parent | fa3899f7b0e6c3250f3cb38ac4f9a07d0ab80874 (diff) | |
download | mpd-f1790fc8bf1fe46f977b6ecad0e1cd03b7edde82.tar.gz mpd-f1790fc8bf1fe46f977b6ecad0e1cd03b7edde82.tar.xz mpd-f1790fc8bf1fe46f977b6ecad0e1cd03b7edde82.zip |
input_curl: set "ready" flag on EOF
Set the "ready" flag for empty resources.
Diffstat (limited to '')
-rw-r--r-- | NEWS | 1 | ||||
-rw-r--r-- | src/input_curl.c | 5 |
2 files changed, 6 insertions, 0 deletions
@@ -27,6 +27,7 @@ MPD 0.14.1 - not yet released - use select() to eliminate busy loop during connect - honour http_proxy_* config directives - fix assertion failure on "connection refused" + - fix assertion failure with empty HTTP responses * log: automatically append newline * fix setenv() conflict on Solaris * configure.ac: check for pkg-config before using it diff --git a/src/input_curl.c b/src/input_curl.c index 8372f9924..afa85eb36 100644 --- a/src/input_curl.c +++ b/src/input_curl.c @@ -194,6 +194,7 @@ input_curl_multi_info_read(struct input_stream *is) &msgs_in_queue)) != NULL) { if (msg->msg == CURLMSG_DONE) { c->eof = true; + is->ready = true; if (msg->data.result != CURLE_OK) { g_warning("curl failed: %s\n", c->error); @@ -389,6 +390,7 @@ input_curl_read(struct input_stream *is, void *ptr, size_t size) g_warning("curl_multi_perform() failed: %s\n", curl_multi_strerror(mcode)); c->eof = true; + is->ready = true; return 0; } @@ -491,6 +493,7 @@ input_curl_buffer(struct input_stream *is) g_warning("curl_multi_perform() failed: %s\n", curl_multi_strerror(mcode)); c->eof = true; + is->ready = true; return -1; } @@ -784,6 +787,8 @@ input_curl_seek(struct input_stream *is, off_t offset, int whence) struct input_curl *c = is->data; bool ret; + assert(is->ready); + if (whence == SEEK_SET && offset == 0) { if (is->offset == 0) /* no-op */ |