input/Curl: add constructor to input_curl class

This commit is contained in:
Max Kellermann 2013-01-10 22:18:23 +01:00
parent b9ac5e9e76
commit 12a8ed39d4

View File

@ -116,6 +116,22 @@ struct input_curl {
struct tag *tag; struct tag *tag;
GError *postponed_error; GError *postponed_error;
input_curl(const char *url, GMutex *mutex, GCond *cond)
:range(nullptr), request_headers(nullptr),
buffers(g_queue_new()),
paused(false),
meta_name(nullptr),
tag(nullptr),
postponed_error(nullptr) {
input_stream_init(&base, &input_plugin_curl, url, mutex, cond);
icy_clear(&icy_metadata);
}
~input_curl();
input_curl(const input_curl &) = delete;
input_curl &operator=(const input_curl &) = delete;
}; };
/** libcurl should accept "ICY 200 OK" */ /** libcurl should accept "ICY 200 OK" */
@ -718,26 +734,21 @@ input_curl_flush_buffers(struct input_curl *c)
g_queue_clear(c->buffers); g_queue_clear(c->buffers);
} }
/** input_curl::~input_curl()
* Frees this stream, including the input_stream struct.
*/
static void
input_curl_free(struct input_curl *c)
{ {
if (c->tag != NULL) if (tag != NULL)
tag_free(c->tag); tag_free(tag);
g_free(c->meta_name); g_free(meta_name);
input_curl_easy_free_indirect(c); input_curl_easy_free_indirect(this);
input_curl_flush_buffers(c); input_curl_flush_buffers(this);
g_queue_free(c->buffers); g_queue_free(buffers);
if (c->postponed_error != NULL) if (postponed_error != NULL)
g_error_free(c->postponed_error); g_error_free(postponed_error);
input_stream_deinit(&c->base); input_stream_deinit(&base);
g_free(c);
} }
static bool static bool
@ -924,7 +935,7 @@ input_curl_close(struct input_stream *is)
{ {
struct input_curl *c = (struct input_curl *)is; struct input_curl *c = (struct input_curl *)is;
input_curl_free(c); delete c;
} }
static bool static bool
@ -1227,31 +1238,18 @@ input_curl_open(const char *url, GMutex *mutex, GCond *cond,
assert(mutex != NULL); assert(mutex != NULL);
assert(cond != NULL); assert(cond != NULL);
struct input_curl *c;
if (strncmp(url, "http://", 7) != 0) if (strncmp(url, "http://", 7) != 0)
return NULL; return NULL;
c = g_new0(struct input_curl, 1); struct input_curl *c = new input_curl(url, mutex, cond);
input_stream_init(&c->base, &input_plugin_curl, url,
mutex, cond);
c->buffers = g_queue_new();
icy_clear(&c->icy_metadata);
c->tag = NULL;
c->postponed_error = NULL;
c->paused = false;
if (!input_curl_easy_init(c, error_r)) { if (!input_curl_easy_init(c, error_r)) {
input_curl_free(c); delete c;
return NULL; return NULL;
} }
if (!input_curl_easy_add_indirect(c, error_r)) { if (!input_curl_easy_add_indirect(c, error_r)) {
input_curl_free(c); delete c;
return NULL; return NULL;
} }