input/Curl: require libcurl 7.18

This commit is contained in:
Max Kellermann 2013-01-10 20:46:47 +01:00
parent ed8798e82f
commit 3bb711837e
2 changed files with 5 additions and 25 deletions

View File

@ -691,7 +691,7 @@ dnl Input Plugins
dnl --------------------------------------------------------------------------- dnl ---------------------------------------------------------------------------
dnl ----------------------------------- CURL ---------------------------------- dnl ----------------------------------- CURL ----------------------------------
MPD_AUTO_PKG(curl, CURL, [libcurl], MPD_AUTO_PKG(curl, CURL, [libcurl >= 7.18],
[libcurl HTTP streaming], [libcurl not found]) [libcurl HTTP streaming], [libcurl not found])
if test x$enable_curl = xyes; then if test x$enable_curl = xyes; then
AC_DEFINE(ENABLE_CURL, 1, [Define when libcurl is used for HTTP streaming]) AC_DEFINE(ENABLE_CURL, 1, [Define when libcurl is used for HTTP streaming])

View File

@ -45,6 +45,10 @@ extern "C" {
#include <curl/curl.h> #include <curl/curl.h>
#include <glib.h> #include <glib.h>
#if LIBCURL_VERSION_NUM < 0x071200
#error libcurl is too old
#endif
#undef G_LOG_DOMAIN #undef G_LOG_DOMAIN
#define G_LOG_DOMAIN "input_curl" #define G_LOG_DOMAIN "input_curl"
@ -99,14 +103,12 @@ struct input_curl {
to, and input_curl_read() reads from them */ to, and input_curl_read() reads from them */
GQueue *buffers; GQueue *buffers;
#if LIBCURL_VERSION_NUM >= 0x071200
/** /**
* Is the connection currently paused? That happens when the * Is the connection currently paused? That happens when the
* buffer was getting too large. It will be unpaused when the * buffer was getting too large. It will be unpaused when the
* buffer is below the threshold again. * buffer is below the threshold again.
*/ */
bool paused; bool paused;
#endif
/** error message provided by libcurl */ /** error message provided by libcurl */
char error[CURL_ERROR_SIZE]; char error[CURL_ERROR_SIZE];
@ -153,7 +155,6 @@ static struct {
GSList *fds; GSList *fds;
#if LIBCURL_VERSION_NUM >= 0x070f04
/** /**
* Did CURL give us a timeout? If yes, then we need to call * Did CURL give us a timeout? If yes, then we need to call
* curl_multi_perform(), even if there was no event on any * curl_multi_perform(), even if there was no event on any
@ -166,7 +167,6 @@ static struct {
* used in the GSource method check(). * used in the GSource method check().
*/ */
gint64 absolute_timeout; gint64 absolute_timeout;
#endif
} curl; } curl;
static inline GQuark static inline GQuark
@ -194,8 +194,6 @@ input_curl_find_request(CURL *easy)
return NULL; return NULL;
} }
#if LIBCURL_VERSION_NUM >= 0x071200
static gpointer static gpointer
input_curl_resume(gpointer data) input_curl_resume(gpointer data)
{ {
@ -211,8 +209,6 @@ input_curl_resume(gpointer data)
return NULL; return NULL;
} }
#endif
/** /**
* Calculates the GLib event bit mask for one file descriptor, * Calculates the GLib event bit mask for one file descriptor,
* obtained from three #fd_set objects filled by curl_multi_fdset(). * obtained from three #fd_set objects filled by curl_multi_fdset().
@ -551,7 +547,6 @@ input_curl_source_prepare(G_GNUC_UNUSED GSource *source, gint *timeout_r)
{ {
curl_update_fds(); curl_update_fds();
#if LIBCURL_VERSION_NUM >= 0x070f04
curl.timeout = false; curl.timeout = false;
long timeout2; long timeout2;
@ -574,9 +569,6 @@ input_curl_source_prepare(G_GNUC_UNUSED GSource *source, gint *timeout_r)
} else } else
g_warning("curl_multi_timeout() failed: %s\n", g_warning("curl_multi_timeout() failed: %s\n",
curl_multi_strerror(mcode)); curl_multi_strerror(mcode));
#else
(void)timeout_r;
#endif
return false; return false;
} }
@ -587,7 +579,6 @@ input_curl_source_prepare(G_GNUC_UNUSED GSource *source, gint *timeout_r)
static gboolean static gboolean
input_curl_source_check(G_GNUC_UNUSED GSource *source) input_curl_source_check(G_GNUC_UNUSED GSource *source)
{ {
#if LIBCURL_VERSION_NUM >= 0x070f04
if (curl.timeout) { if (curl.timeout) {
/* when a timeout has expired, we need to call /* when a timeout has expired, we need to call
curl_multi_perform(), even if there was no file curl_multi_perform(), even if there was no file
@ -596,7 +587,6 @@ input_curl_source_check(G_GNUC_UNUSED GSource *source)
if (g_source_get_time(source) >= curl.absolute_timeout) if (g_source_get_time(source) >= curl.absolute_timeout)
return true; return true;
} }
#endif
for (GSList *i = curl.fds; i != NULL; i = i->next) { for (GSList *i = curl.fds; i != NULL; i = i->next) {
GPollFD *poll_fd = (GPollFD *)i->data; GPollFD *poll_fd = (GPollFD *)i->data;
@ -705,8 +695,6 @@ input_curl_finish(void)
curl_global_cleanup(); curl_global_cleanup();
} }
#if LIBCURL_VERSION_NUM >= 0x071200
/** /**
* Determine the total sizes of all buffers, including portions that * Determine the total sizes of all buffers, including portions that
* have already been consumed. * have already been consumed.
@ -728,8 +716,6 @@ curl_total_buffer_size(const struct input_curl *c)
return total; return total;
} }
#endif
static void static void
buffer_free_callback(gpointer data, G_GNUC_UNUSED gpointer user_data) buffer_free_callback(gpointer data, G_GNUC_UNUSED gpointer user_data)
{ {
@ -940,13 +926,11 @@ input_curl_read(struct input_stream *is, void *ptr, size_t size,
is->offset += (goffset)nbytes; is->offset += (goffset)nbytes;
#if LIBCURL_VERSION_NUM >= 0x071200
if (c->paused && curl_total_buffer_size(c) < CURL_RESUME_AT) { if (c->paused && curl_total_buffer_size(c) < CURL_RESUME_AT) {
g_mutex_unlock(c->base.mutex); g_mutex_unlock(c->base.mutex);
io_thread_call(input_curl_resume, c); io_thread_call(input_curl_resume, c);
g_mutex_lock(c->base.mutex); g_mutex_lock(c->base.mutex);
} }
#endif
return nbytes; return nbytes;
} }
@ -1064,13 +1048,11 @@ input_curl_writefunction(void *ptr, size_t size, size_t nmemb, void *stream)
g_mutex_lock(c->base.mutex); g_mutex_lock(c->base.mutex);
#if LIBCURL_VERSION_NUM >= 0x071200
if (curl_total_buffer_size(c) + size >= CURL_MAX_BUFFERED) { if (curl_total_buffer_size(c) + size >= CURL_MAX_BUFFERED) {
c->paused = true; c->paused = true;
g_mutex_unlock(c->base.mutex); g_mutex_unlock(c->base.mutex);
return CURL_WRITEFUNC_PAUSE; return CURL_WRITEFUNC_PAUSE;
} }
#endif
struct buffer *buffer = (struct buffer *) struct buffer *buffer = (struct buffer *)
g_malloc(sizeof(*buffer) - sizeof(buffer->data) + size); g_malloc(sizeof(*buffer) - sizeof(buffer->data) + size);
@ -1278,9 +1260,7 @@ input_curl_open(const char *url, GMutex *mutex, GCond *cond,
c->postponed_error = NULL; c->postponed_error = NULL;
#if LIBCURL_VERSION_NUM >= 0x071200
c->paused = false; c->paused = false;
#endif
if (!input_curl_easy_init(c, error_r)) { if (!input_curl_easy_init(c, error_r)) {
input_curl_free(c); input_curl_free(c);