input/{curl,soup}: convert to C++
This commit is contained in:
parent
d5516dee00
commit
33ba288622
@ -82,7 +82,6 @@ mpd_headers = \
|
|||||||
src/input_stream.h \
|
src/input_stream.h \
|
||||||
src/input/file_input_plugin.h \
|
src/input/file_input_plugin.h \
|
||||||
src/input/ffmpeg_input_plugin.h \
|
src/input/ffmpeg_input_plugin.h \
|
||||||
src/input/curl_input_plugin.h \
|
|
||||||
src/input/rewind_input_plugin.h \
|
src/input/rewind_input_plugin.h \
|
||||||
src/input/mms_input_plugin.h \
|
src/input/mms_input_plugin.h \
|
||||||
src/input/despotify_input_plugin.h \
|
src/input/despotify_input_plugin.h \
|
||||||
@ -731,14 +730,14 @@ INPUT_LIBS = \
|
|||||||
$(MMS_LIBS)
|
$(MMS_LIBS)
|
||||||
|
|
||||||
if ENABLE_CURL
|
if ENABLE_CURL
|
||||||
libinput_a_SOURCES += src/input/curl_input_plugin.c \
|
libinput_a_SOURCES += \
|
||||||
|
src/input/CurlInputPlugin.cxx src/input/CurlInputPlugin.hxx \
|
||||||
src/icy_metadata.c
|
src/icy_metadata.c
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if ENABLE_SOUP
|
if ENABLE_SOUP
|
||||||
libinput_a_SOURCES += \
|
libinput_a_SOURCES += \
|
||||||
src/input/soup_input_plugin.c \
|
src/input/SoupInputPlugin.cxx src/input/SoupInputPlugin.hxx
|
||||||
src/input/soup_input_plugin.h
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if ENABLE_CDIO_PARANOIA
|
if ENABLE_CDIO_PARANOIA
|
||||||
|
@ -26,11 +26,11 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef ENABLE_CURL
|
#ifdef ENABLE_CURL
|
||||||
#include "input/curl_input_plugin.h"
|
#include "input/CurlInputPlugin.hxx"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef ENABLE_SOUP
|
#ifdef ENABLE_SOUP
|
||||||
#include "input/soup_input_plugin.h"
|
#include "input/SoupInputPlugin.hxx"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_FFMPEG
|
#ifdef HAVE_FFMPEG
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2003-2011 The Music Player Daemon Project
|
* Copyright (C) 2003-2013 The Music Player Daemon Project
|
||||||
* http://www.musicpd.org
|
* http://www.musicpd.org
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
@ -18,13 +18,17 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "input/curl_input_plugin.h"
|
#include "CurlInputPlugin.hxx"
|
||||||
#include "input_internal.h"
|
|
||||||
#include "input_plugin.h"
|
#include "input_plugin.h"
|
||||||
#include "conf.h"
|
#include "conf.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
#include "input_internal.h"
|
||||||
#include "icy_metadata.h"
|
#include "icy_metadata.h"
|
||||||
#include "io_thread.h"
|
#include "io_thread.h"
|
||||||
|
}
|
||||||
|
|
||||||
#include "glib_compat.h"
|
#include "glib_compat.h"
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
@ -182,7 +186,7 @@ input_curl_find_request(CURL *easy)
|
|||||||
assert(io_thread_inside());
|
assert(io_thread_inside());
|
||||||
|
|
||||||
for (GSList *i = curl.requests; i != NULL; i = g_slist_next(i)) {
|
for (GSList *i = curl.requests; i != NULL; i = g_slist_next(i)) {
|
||||||
struct input_curl *c = i->data;
|
struct input_curl *c = (struct input_curl *)i->data;
|
||||||
if (c->easy == easy)
|
if (c->easy == easy)
|
||||||
return c;
|
return c;
|
||||||
}
|
}
|
||||||
@ -197,7 +201,7 @@ input_curl_resume(gpointer data)
|
|||||||
{
|
{
|
||||||
assert(io_thread_inside());
|
assert(io_thread_inside());
|
||||||
|
|
||||||
struct input_curl *c = data;
|
struct input_curl *c = (struct input_curl *)data;
|
||||||
|
|
||||||
if (c->paused) {
|
if (c->paused) {
|
||||||
c->paused = false;
|
c->paused = false;
|
||||||
@ -266,7 +270,7 @@ curl_update_fds(void)
|
|||||||
curl.fds = NULL;
|
curl.fds = NULL;
|
||||||
|
|
||||||
while (fds != NULL) {
|
while (fds != NULL) {
|
||||||
GPollFD *poll_fd = fds->data;
|
GPollFD *poll_fd = (GPollFD *)fds->data;
|
||||||
gushort events = input_curl_fd_events(poll_fd->fd, &rfds,
|
gushort events = input_curl_fd_events(poll_fd->fd, &rfds,
|
||||||
&wfds, &efds);
|
&wfds, &efds);
|
||||||
|
|
||||||
@ -335,7 +339,8 @@ struct easy_add_params {
|
|||||||
static gpointer
|
static gpointer
|
||||||
input_curl_easy_add_callback(gpointer data)
|
input_curl_easy_add_callback(gpointer data)
|
||||||
{
|
{
|
||||||
const struct easy_add_params *params = data;
|
const struct easy_add_params *params =
|
||||||
|
(const struct easy_add_params *)data;
|
||||||
|
|
||||||
bool success = input_curl_easy_add(params->c, params->error_r);
|
bool success = input_curl_easy_add(params->c, params->error_r);
|
||||||
return GUINT_TO_POINTER(success);
|
return GUINT_TO_POINTER(success);
|
||||||
@ -352,8 +357,8 @@ input_curl_easy_add_indirect(struct input_curl *c, GError **error_r)
|
|||||||
assert(c->easy != NULL);
|
assert(c->easy != NULL);
|
||||||
|
|
||||||
struct easy_add_params params = {
|
struct easy_add_params params = {
|
||||||
.c = c,
|
c,
|
||||||
.error_r = error_r,
|
error_r,
|
||||||
};
|
};
|
||||||
|
|
||||||
gpointer result =
|
gpointer result =
|
||||||
@ -392,7 +397,7 @@ input_curl_easy_free(struct input_curl *c)
|
|||||||
static gpointer
|
static gpointer
|
||||||
input_curl_easy_free_callback(gpointer data)
|
input_curl_easy_free_callback(gpointer data)
|
||||||
{
|
{
|
||||||
struct input_curl *c = data;
|
struct input_curl *c = (struct input_curl *)data;
|
||||||
|
|
||||||
input_curl_easy_free(c);
|
input_curl_easy_free(c);
|
||||||
curl_update_fds();
|
curl_update_fds();
|
||||||
@ -425,7 +430,8 @@ input_curl_abort_all_requests(GError *error)
|
|||||||
assert(error != NULL);
|
assert(error != NULL);
|
||||||
|
|
||||||
while (curl.requests != NULL) {
|
while (curl.requests != NULL) {
|
||||||
struct input_curl *c = curl.requests->data;
|
struct input_curl *c =
|
||||||
|
(struct input_curl *)curl.requests->data;
|
||||||
assert(c->postponed_error == NULL);
|
assert(c->postponed_error == NULL);
|
||||||
|
|
||||||
input_curl_easy_free(c);
|
input_curl_easy_free(c);
|
||||||
@ -593,7 +599,7 @@ input_curl_source_check(G_GNUC_UNUSED GSource *source)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
for (GSList *i = curl.fds; i != NULL; i = i->next) {
|
for (GSList *i = curl.fds; i != NULL; i = i->next) {
|
||||||
GPollFD *poll_fd = i->data;
|
GPollFD *poll_fd = (GPollFD *)i->data;
|
||||||
if (poll_fd->revents != 0)
|
if (poll_fd->revents != 0)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -622,9 +628,12 @@ input_curl_source_dispatch(G_GNUC_UNUSED GSource *source,
|
|||||||
* pointer, for whatever reason.
|
* pointer, for whatever reason.
|
||||||
*/
|
*/
|
||||||
static GSourceFuncs curl_source_funcs = {
|
static GSourceFuncs curl_source_funcs = {
|
||||||
.prepare = input_curl_source_prepare,
|
input_curl_source_prepare,
|
||||||
.check = input_curl_source_check,
|
input_curl_source_check,
|
||||||
.dispatch = input_curl_source_dispatch,
|
input_curl_source_dispatch,
|
||||||
|
nullptr,
|
||||||
|
nullptr,
|
||||||
|
nullptr,
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -712,7 +721,7 @@ curl_total_buffer_size(const struct input_curl *c)
|
|||||||
|
|
||||||
for (GList *i = g_queue_peek_head_link(c->buffers);
|
for (GList *i = g_queue_peek_head_link(c->buffers);
|
||||||
i != NULL; i = g_list_next(i)) {
|
i != NULL; i = g_list_next(i)) {
|
||||||
struct buffer *buffer = i->data;
|
struct buffer *buffer = (struct buffer *)i->data;
|
||||||
total += buffer->size;
|
total += buffer->size;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -724,7 +733,7 @@ curl_total_buffer_size(const struct input_curl *c)
|
|||||||
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)
|
||||||
{
|
{
|
||||||
struct buffer *buffer = data;
|
struct buffer *buffer = (struct buffer *)data;
|
||||||
|
|
||||||
assert(buffer->consumed <= buffer->size);
|
assert(buffer->consumed <= buffer->size);
|
||||||
|
|
||||||
@ -824,8 +833,8 @@ static size_t
|
|||||||
read_from_buffer(struct icy_metadata *icy_metadata, GQueue *buffers,
|
read_from_buffer(struct icy_metadata *icy_metadata, GQueue *buffers,
|
||||||
void *dest0, size_t length)
|
void *dest0, size_t length)
|
||||||
{
|
{
|
||||||
struct buffer *buffer = g_queue_pop_head(buffers);
|
struct buffer *buffer = (struct buffer *)g_queue_pop_head(buffers);
|
||||||
uint8_t *dest = dest0;
|
uint8_t *dest = (uint8_t *)dest0;
|
||||||
size_t nbytes = 0;
|
size_t nbytes = 0;
|
||||||
|
|
||||||
assert(buffer->size > 0);
|
assert(buffer->size > 0);
|
||||||
@ -906,7 +915,7 @@ input_curl_read(struct input_stream *is, void *ptr, size_t size,
|
|||||||
struct input_curl *c = (struct input_curl *)is;
|
struct input_curl *c = (struct input_curl *)is;
|
||||||
bool success;
|
bool success;
|
||||||
size_t nbytes = 0;
|
size_t nbytes = 0;
|
||||||
char *dest = ptr;
|
char *dest = (char *)ptr;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
/* fill the buffer */
|
/* fill the buffer */
|
||||||
@ -963,13 +972,14 @@ static size_t
|
|||||||
input_curl_headerfunction(void *ptr, size_t size, size_t nmemb, void *stream)
|
input_curl_headerfunction(void *ptr, size_t size, size_t nmemb, void *stream)
|
||||||
{
|
{
|
||||||
struct input_curl *c = (struct input_curl *)stream;
|
struct input_curl *c = (struct input_curl *)stream;
|
||||||
const char *header = ptr, *end, *value;
|
|
||||||
char name[64];
|
char name[64];
|
||||||
|
|
||||||
size *= nmemb;
|
size *= nmemb;
|
||||||
end = header + size;
|
|
||||||
|
|
||||||
value = memchr(header, ':', size);
|
const char *header = (const char *)ptr;
|
||||||
|
const char *end = header + size;
|
||||||
|
|
||||||
|
const char *value = (const char *)memchr(header, ':', size);
|
||||||
if (value == NULL || (size_t)(value - header) >= sizeof(name))
|
if (value == NULL || (size_t)(value - header) >= sizeof(name))
|
||||||
return size;
|
return size;
|
||||||
|
|
||||||
@ -1047,7 +1057,6 @@ static size_t
|
|||||||
input_curl_writefunction(void *ptr, size_t size, size_t nmemb, void *stream)
|
input_curl_writefunction(void *ptr, size_t size, size_t nmemb, void *stream)
|
||||||
{
|
{
|
||||||
struct input_curl *c = (struct input_curl *)stream;
|
struct input_curl *c = (struct input_curl *)stream;
|
||||||
struct buffer *buffer;
|
|
||||||
|
|
||||||
size *= nmemb;
|
size *= nmemb;
|
||||||
if (size == 0)
|
if (size == 0)
|
||||||
@ -1063,7 +1072,8 @@ input_curl_writefunction(void *ptr, size_t size, size_t nmemb, void *stream)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
buffer = g_malloc(sizeof(*buffer) - sizeof(buffer->data) + size);
|
struct buffer *buffer = (struct buffer *)
|
||||||
|
g_malloc(sizeof(*buffer) - sizeof(buffer->data) + size);
|
||||||
buffer->size = size;
|
buffer->size = size;
|
||||||
buffer->consumed = 0;
|
buffer->consumed = 0;
|
||||||
memcpy(buffer->data, ptr, size);
|
memcpy(buffer->data, ptr, size);
|
||||||
@ -1286,16 +1296,16 @@ input_curl_open(const char *url, GMutex *mutex, GCond *cond,
|
|||||||
}
|
}
|
||||||
|
|
||||||
const struct input_plugin input_plugin_curl = {
|
const struct input_plugin input_plugin_curl = {
|
||||||
.name = "curl",
|
"curl",
|
||||||
.init = input_curl_init,
|
input_curl_init,
|
||||||
.finish = input_curl_finish,
|
input_curl_finish,
|
||||||
|
input_curl_open,
|
||||||
.open = input_curl_open,
|
input_curl_close,
|
||||||
.close = input_curl_close,
|
input_curl_check,
|
||||||
.check = input_curl_check,
|
nullptr,
|
||||||
.tag = input_curl_tag,
|
input_curl_tag,
|
||||||
.available = input_curl_available,
|
input_curl_available,
|
||||||
.read = input_curl_read,
|
input_curl_read,
|
||||||
.eof = input_curl_eof,
|
input_curl_eof,
|
||||||
.seek = input_curl_seek,
|
input_curl_seek,
|
||||||
};
|
};
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2003-2011 The Music Player Daemon Project
|
* Copyright (C) 2003-2013 The Music Player Daemon Project
|
||||||
* http://www.musicpd.org
|
* http://www.musicpd.org
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
@ -17,8 +17,8 @@
|
|||||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef MPD_INPUT_CURL_H
|
#ifndef MPD_INPUT_CURL_HXX
|
||||||
#define MPD_INPUT_CURL_H
|
#define MPD_INPUT_CURL_HXX
|
||||||
|
|
||||||
struct input_stream;
|
struct input_stream;
|
||||||
|
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2003-2011 The Music Player Daemon Project
|
* Copyright (C) 2003-2013 The Music Player Daemon Project
|
||||||
* http://www.musicpd.org
|
* http://www.musicpd.org
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
@ -18,14 +18,20 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "input/soup_input_plugin.h"
|
#include "SoupInputPlugin.hxx"
|
||||||
#include "input_internal.h"
|
|
||||||
#include "input_plugin.h"
|
#include "input_plugin.h"
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
#include "input_internal.h"
|
||||||
#include "io_thread.h"
|
#include "io_thread.h"
|
||||||
|
}
|
||||||
|
|
||||||
#include "conf.h"
|
#include "conf.h"
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
#include <libsoup/soup-uri.h>
|
#include <libsoup/soup-uri.h>
|
||||||
#include <libsoup/soup-session-async.h>
|
#include <libsoup/soup-session-async.h>
|
||||||
|
}
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
@ -156,7 +162,7 @@ static void
|
|||||||
input_soup_session_callback(G_GNUC_UNUSED SoupSession *session,
|
input_soup_session_callback(G_GNUC_UNUSED SoupSession *session,
|
||||||
SoupMessage *msg, gpointer user_data)
|
SoupMessage *msg, gpointer user_data)
|
||||||
{
|
{
|
||||||
struct input_soup *s = user_data;
|
struct input_soup *s = (struct input_soup *)user_data;
|
||||||
|
|
||||||
assert(msg == s->msg);
|
assert(msg == s->msg);
|
||||||
assert(!s->completed);
|
assert(!s->completed);
|
||||||
@ -177,7 +183,7 @@ input_soup_session_callback(G_GNUC_UNUSED SoupSession *session,
|
|||||||
static void
|
static void
|
||||||
input_soup_got_headers(SoupMessage *msg, gpointer user_data)
|
input_soup_got_headers(SoupMessage *msg, gpointer user_data)
|
||||||
{
|
{
|
||||||
struct input_soup *s = user_data;
|
struct input_soup *s = (struct input_soup *)user_data;
|
||||||
|
|
||||||
g_mutex_lock(s->base.mutex);
|
g_mutex_lock(s->base.mutex);
|
||||||
|
|
||||||
@ -199,7 +205,7 @@ input_soup_got_headers(SoupMessage *msg, gpointer user_data)
|
|||||||
static void
|
static void
|
||||||
input_soup_got_chunk(SoupMessage *msg, SoupBuffer *chunk, gpointer user_data)
|
input_soup_got_chunk(SoupMessage *msg, SoupBuffer *chunk, gpointer user_data)
|
||||||
{
|
{
|
||||||
struct input_soup *s = user_data;
|
struct input_soup *s = (struct input_soup *)user_data;
|
||||||
|
|
||||||
assert(msg == s->msg);
|
assert(msg == s->msg);
|
||||||
|
|
||||||
@ -220,7 +226,7 @@ input_soup_got_chunk(SoupMessage *msg, SoupBuffer *chunk, gpointer user_data)
|
|||||||
static void
|
static void
|
||||||
input_soup_got_body(G_GNUC_UNUSED SoupMessage *msg, gpointer user_data)
|
input_soup_got_body(G_GNUC_UNUSED SoupMessage *msg, gpointer user_data)
|
||||||
{
|
{
|
||||||
struct input_soup *s = user_data;
|
struct input_soup *s = (struct input_soup *)user_data;
|
||||||
|
|
||||||
assert(msg == s->msg);
|
assert(msg == s->msg);
|
||||||
|
|
||||||
@ -256,7 +262,7 @@ input_soup_wait_data(struct input_soup *s)
|
|||||||
static gpointer
|
static gpointer
|
||||||
input_soup_queue(gpointer data)
|
input_soup_queue(gpointer data)
|
||||||
{
|
{
|
||||||
struct input_soup *s = data;
|
struct input_soup *s = (struct input_soup *)data;
|
||||||
|
|
||||||
soup_session_queue_message(soup_session, s->msg,
|
soup_session_queue_message(soup_session, s->msg,
|
||||||
input_soup_session_callback, s);
|
input_soup_session_callback, s);
|
||||||
@ -320,7 +326,7 @@ input_soup_open(const char *uri,
|
|||||||
static gpointer
|
static gpointer
|
||||||
input_soup_cancel(gpointer data)
|
input_soup_cancel(gpointer data)
|
||||||
{
|
{
|
||||||
struct input_soup *s = data;
|
struct input_soup *s = (struct input_soup *)data;
|
||||||
|
|
||||||
if (!s->completed)
|
if (!s->completed)
|
||||||
soup_session_cancel_message(soup_session, s->msg,
|
soup_session_cancel_message(soup_session, s->msg,
|
||||||
@ -352,7 +358,7 @@ input_soup_close(struct input_stream *is)
|
|||||||
g_mutex_unlock(s->base.mutex);
|
g_mutex_unlock(s->base.mutex);
|
||||||
|
|
||||||
SoupBuffer *buffer;
|
SoupBuffer *buffer;
|
||||||
while ((buffer = g_queue_pop_head(s->buffers)) != NULL)
|
while ((buffer = (SoupBuffer *)g_queue_pop_head(s->buffers)) != NULL)
|
||||||
soup_buffer_free(buffer);
|
soup_buffer_free(buffer);
|
||||||
g_queue_free(s->buffers);
|
g_queue_free(s->buffers);
|
||||||
|
|
||||||
@ -403,10 +409,11 @@ input_soup_read(struct input_stream *is, void *ptr, size_t size,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *p0 = ptr, *p = p0, *p_end = p0 + size;
|
char *p0 = (char *)ptr, *p = p0, *p_end = p0 + size;
|
||||||
|
|
||||||
while (p < p_end) {
|
while (p < p_end) {
|
||||||
SoupBuffer *buffer = g_queue_pop_head(s->buffers);
|
SoupBuffer *buffer = (SoupBuffer *)
|
||||||
|
g_queue_pop_head(s->buffers);
|
||||||
if (buffer == NULL) {
|
if (buffer == NULL) {
|
||||||
assert(s->current_consumed == 0);
|
assert(s->current_consumed == 0);
|
||||||
break;
|
break;
|
||||||
@ -460,14 +467,16 @@ input_soup_eof(G_GNUC_UNUSED struct input_stream *is)
|
|||||||
}
|
}
|
||||||
|
|
||||||
const struct input_plugin input_plugin_soup = {
|
const struct input_plugin input_plugin_soup = {
|
||||||
.name = "soup",
|
"soup",
|
||||||
.init = input_soup_init,
|
input_soup_init,
|
||||||
.finish = input_soup_finish,
|
input_soup_finish,
|
||||||
|
input_soup_open,
|
||||||
.open = input_soup_open,
|
input_soup_close,
|
||||||
.close = input_soup_close,
|
input_soup_check,
|
||||||
.check = input_soup_check,
|
nullptr,
|
||||||
.available = input_soup_available,
|
nullptr,
|
||||||
.read = input_soup_read,
|
input_soup_available,
|
||||||
.eof = input_soup_eof,
|
input_soup_read,
|
||||||
|
input_soup_eof,
|
||||||
|
nullptr,
|
||||||
};
|
};
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2003-2011 The Music Player Daemon Project
|
* Copyright (C) 2003-2013 The Music Player Daemon Project
|
||||||
* http://www.musicpd.org
|
* http://www.musicpd.org
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
@ -17,8 +17,8 @@
|
|||||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef MPD_INPUT_SOUP_H
|
#ifndef MPD_INPUT_SOUP_HXX
|
||||||
#define MPD_INPUT_SOUP_H
|
#define MPD_INPUT_SOUP_HXX
|
||||||
|
|
||||||
extern const struct input_plugin input_plugin_soup;
|
extern const struct input_plugin input_plugin_soup;
|
||||||
|
|
Loading…
Reference in New Issue
Block a user