1
0
mirror of https://github.com/SuperBFG7/ympd synced 2025-01-15 19:55:49 +00:00

Renamed functions with mympd prefix

This commit is contained in:
jcorporation 2018-06-14 23:00:54 +01:00
parent 325094f6e7
commit fba2a0540a
4 changed files with 74 additions and 73 deletions

View File

@ -32,7 +32,6 @@ endif()
if(WITH_SSL) if(WITH_SSL)
find_package(OpenSSL REQUIRED) find_package(OpenSSL REQUIRED)
include_directories(${OPENSSL_INCLUDE_DIR}) include_directories(${OPENSSL_INCLUDE_DIR})
# list(APPEND LIB_LIST ${OPENSSL_LIBRARIES})
set_property(DIRECTORY APPEND PROPERTY COMPILE_DEFINITIONS NS_ENABLE_SSL) set_property(DIRECTORY APPEND PROPERTY COMPILE_DEFINITIONS NS_ENABLE_SSL)
endif() endif()
@ -50,7 +49,7 @@ set(SOURCES
src/mympd.c src/mympd.c
src/mpd_client.c src/mpd_client.c
src/mongoose/mongoose.c src/mongoose/mongoose.c
src/json_encode.c src/frozen/frozen.c
) )
add_executable(mympd ${SOURCES}) add_executable(mympd ${SOURCES})

View File

@ -33,10 +33,11 @@
#include "mpd_client.h" #include "mpd_client.h"
#include "config.h" #include "config.h"
#include "frozen/frozen.h"
#include "json_encode.h" #include "json_encode.h"
/* forward declaration */ /* forward declaration */
static int mpd_notify_callback(struct mg_connection *c, const char *param); static int mympd_notify_callback(struct mg_connection *c, const char *param);
const char * mpd_cmd_strs[] = { const char * mpd_cmd_strs[] = {
MPD_CMDS(GEN_STR) MPD_CMDS(GEN_STR)
@ -59,7 +60,7 @@ static inline enum mpd_cmd_ids get_cmd_id(const char *cmd)
return -1; return -1;
} }
void callback_mpd(struct mg_connection *nc, const struct mg_str msg) void callback_mympd(struct mg_connection *nc, const struct mg_str msg)
{ {
enum mpd_cmd_ids cmd_id = get_cmd_id(msg.p); enum mpd_cmd_ids cmd_id = get_cmd_id(msg.p);
size_t n = 0; size_t n = 0;
@ -149,7 +150,7 @@ void callback_mpd(struct mg_connection *nc, const struct mg_str msg)
mpd_run_mixrampdelay(mpd.conn, float_buf); mpd_run_mixrampdelay(mpd.conn, float_buf);
break; break;
case MPD_API_GET_OUTPUTNAMES: case MPD_API_GET_OUTPUTNAMES:
n = mpd_put_outputnames(mpd.buf); n = mympd_put_outputnames(mpd.buf);
break; break;
case MPD_API_TOGGLE_OUTPUT: case MPD_API_TOGGLE_OUTPUT:
if (sscanf(msg.p, "MPD_API_TOGGLE_OUTPUT,%u,%u", &uint_buf, &uint_buf_2)) { if (sscanf(msg.p, "MPD_API_TOGGLE_OUTPUT,%u,%u", &uint_buf, &uint_buf_2)) {
@ -169,10 +170,10 @@ void callback_mpd(struct mg_connection *nc, const struct mg_str msg)
break; break;
case MPD_API_GET_QUEUE: case MPD_API_GET_QUEUE:
if(sscanf(msg.p, "MPD_API_GET_QUEUE,%u", &uint_buf)) if(sscanf(msg.p, "MPD_API_GET_QUEUE,%u", &uint_buf))
n = mpd_put_queue(mpd.buf, uint_buf); n = mympd_put_queue(mpd.buf, uint_buf);
break; break;
case MPD_API_GET_CURRENT_SONG: case MPD_API_GET_CURRENT_SONG:
n = mpd_put_current_song(mpd.buf); n = mympd_put_current_song(mpd.buf);
break; break;
case MPD_API_GET_ARTISTS: case MPD_API_GET_ARTISTS:
@ -265,7 +266,7 @@ out_playlists:
} else { } else {
searchstr = strdup(token); searchstr = strdup(token);
} }
n = mpd_put_browse(mpd.buf, p_charbuf2, uint_buf, searchstr); n = mympd_put_browse(mpd.buf, p_charbuf2, uint_buf, searchstr);
free(searchstr); free(searchstr);
free(p_charbuf2); free(p_charbuf2);
out_browse: out_browse:
@ -349,7 +350,7 @@ out_save_queue:
} else { } else {
searchstr = strdup(token); searchstr = strdup(token);
} }
n = mpd_search_queue(mpd.buf, p_charbuf2, uint_buf, searchstr); n = mympd_search_queue(mpd.buf, p_charbuf2, uint_buf, searchstr);
free(searchstr); free(searchstr);
free(p_charbuf2); free(p_charbuf2);
out_search_queue: out_search_queue:
@ -371,7 +372,7 @@ out_search_queue:
} else { } else {
searchstr = strdup(token); searchstr = strdup(token);
} }
n = mpd_search_add(mpd.buf, p_charbuf2, searchstr); n = mympd_search_add(mpd.buf, p_charbuf2, searchstr);
free(searchstr); free(searchstr);
free(p_charbuf2); free(p_charbuf2);
out_search_add: out_search_add:
@ -395,7 +396,7 @@ out_search_add:
} else { } else {
searchstr = strdup(token); searchstr = strdup(token);
} }
n = mpd_search(mpd.buf, p_charbuf2, uint_buf, searchstr); n = mympd_search(mpd.buf, p_charbuf2, uint_buf, searchstr);
free(searchstr); free(searchstr);
free(p_charbuf2); free(p_charbuf2);
out_search: out_search:
@ -495,7 +496,7 @@ out_set_replaygain:
} }
} }
int mpd_close_handler(struct mg_connection *c) int mympd_close_handler(struct mg_connection *c)
{ {
/* Cleanup session data */ /* Cleanup session data */
if(c->user_data) if(c->user_data)
@ -503,7 +504,7 @@ int mpd_close_handler(struct mg_connection *c)
return 0; return 0;
} }
static int mpd_notify_callback(struct mg_connection *c, const char *param) { static int mympd_notify_callback(struct mg_connection *c, const char *param) {
size_t n; size_t n;
if(!is_websocket(c)) if(!is_websocket(c))
return 0; return 0;
@ -540,7 +541,7 @@ static int mpd_notify_callback(struct mg_connection *c, const char *param) {
if(s->song_id != mpd.song_id) if(s->song_id != mpd.song_id)
{ {
n=mpd_put_current_song(mpd.buf); n=mympd_put_current_song(mpd.buf);
#ifdef DEBUG #ifdef DEBUG
fprintf(stdout,"Notify: %s\n",mpd.buf); fprintf(stdout,"Notify: %s\n",mpd.buf);
#endif #endif
@ -563,7 +564,7 @@ static int mpd_notify_callback(struct mg_connection *c, const char *param) {
return 0; return 0;
} }
void mpd_poll(struct mg_mgr *s) void mympd_poll(struct mg_mgr *s)
{ {
switch (mpd.conn_state) { switch (mpd.conn_state) {
case MPD_DISCONNECTED: case MPD_DISCONNECTED:
@ -580,7 +581,7 @@ void mpd_poll(struct mg_mgr *s)
fprintf(stderr, "MPD connection: %s\n", mpd_connection_get_error_message(mpd.conn)); fprintf(stderr, "MPD connection: %s\n", mpd_connection_get_error_message(mpd.conn));
for (struct mg_connection *c = mg_next(s, NULL); c != NULL; c = mg_next(s, c)) for (struct mg_connection *c = mg_next(s, NULL); c != NULL; c = mg_next(s, c))
{ {
mpd_notify_callback(c, mpd_connection_get_error_message(mpd.conn)); mympd_notify_callback(c, mpd_connection_get_error_message(mpd.conn));
} }
mpd.conn_state = MPD_FAILURE; mpd.conn_state = MPD_FAILURE;
return; return;
@ -591,7 +592,7 @@ void mpd_poll(struct mg_mgr *s)
fprintf(stderr, "MPD connection: %s\n", mpd_connection_get_error_message(mpd.conn)); fprintf(stderr, "MPD connection: %s\n", mpd_connection_get_error_message(mpd.conn));
for (struct mg_connection *c = mg_next(s, NULL); c != NULL; c = mg_next(s, c)) for (struct mg_connection *c = mg_next(s, NULL); c != NULL; c = mg_next(s, c))
{ {
mpd_notify_callback(c, mpd_connection_get_error_message(mpd.conn)); mympd_notify_callback(c, mpd_connection_get_error_message(mpd.conn));
} }
mpd.conn_state = MPD_FAILURE; mpd.conn_state = MPD_FAILURE;
return; return;
@ -614,16 +615,16 @@ void mpd_poll(struct mg_mgr *s)
break; break;
case MPD_CONNECTED: case MPD_CONNECTED:
mpd.buf_size = mpd_put_state(mpd.buf, &mpd.song_id, &mpd.next_song_id, &mpd.queue_version); mpd.buf_size = mympd_put_state(mpd.buf, &mpd.song_id, &mpd.next_song_id, &mpd.queue_version);
for (struct mg_connection *c = mg_next(s, NULL); c != NULL; c = mg_next(s, c)) for (struct mg_connection *c = mg_next(s, NULL); c != NULL; c = mg_next(s, c))
{ {
mpd_notify_callback(c, NULL); mympd_notify_callback(c, NULL);
} }
break; break;
} }
} }
char* mpd_get_title(struct mpd_song const *song) char* mympd_get_title(struct mpd_song const *song)
{ {
char *str; char *str;
@ -635,7 +636,7 @@ char* mpd_get_title(struct mpd_song const *song)
return str; return str;
} }
char* mpd_get_track(struct mpd_song const *song) char* mympd_get_track(struct mpd_song const *song)
{ {
char *str; char *str;
@ -648,7 +649,7 @@ char* mpd_get_track(struct mpd_song const *song)
} }
char* mpd_get_album(struct mpd_song const *song) char* mympd_get_album(struct mpd_song const *song)
{ {
char *str; char *str;
@ -660,7 +661,7 @@ char* mpd_get_album(struct mpd_song const *song)
return str; return str;
} }
char* mpd_get_artist(struct mpd_song const *song) char* mympd_get_artist(struct mpd_song const *song)
{ {
char *str; char *str;
@ -672,7 +673,7 @@ char* mpd_get_artist(struct mpd_song const *song)
return str; return str;
} }
char* mpd_get_album_artist(struct mpd_song const *song) char* mympd_get_album_artist(struct mpd_song const *song)
{ {
char *str; char *str;
@ -684,7 +685,7 @@ char* mpd_get_album_artist(struct mpd_song const *song)
return str; return str;
} }
char* mpd_get_year(struct mpd_song const *song) char* mympd_get_year(struct mpd_song const *song)
{ {
char *str; char *str;
@ -696,7 +697,7 @@ char* mpd_get_year(struct mpd_song const *song)
return str; return str;
} }
int mpd_put_state(char *buffer, int *current_song_id, int *next_song_id, unsigned *queue_version) int mympd_put_state(char *buffer, int *current_song_id, int *next_song_id, unsigned *queue_version)
{ {
struct mpd_status *status; struct mpd_status *status;
const struct mpd_audio_format *audioformat; const struct mpd_audio_format *audioformat;
@ -825,7 +826,7 @@ int mympd_put_settings(char *buffer)
} }
int mpd_put_outputnames(char *buffer) int mympd_put_outputnames(char *buffer)
{ {
char *cur = buffer; char *cur = buffer;
const char *end = buffer + MAX_SIZE; const char *end = buffer + MAX_SIZE;
@ -854,7 +855,7 @@ int mpd_put_outputnames(char *buffer)
return cur - buffer; return cur - buffer;
} }
int mpd_put_current_song(char *buffer) int mympd_put_current_song(char *buffer)
{ {
char *cur = buffer; char *cur = buffer;
const char *end = buffer + MAX_SIZE; const char *end = buffer + MAX_SIZE;
@ -867,11 +868,11 @@ int mpd_put_current_song(char *buffer)
cur += json_emit_raw_str(cur, end - cur, "{\"type\": \"song_change\", \"data\":{\"pos\":"); cur += json_emit_raw_str(cur, end - cur, "{\"type\": \"song_change\", \"data\":{\"pos\":");
cur += json_emit_int(cur, end - cur, mpd_song_get_pos(song)); cur += json_emit_int(cur, end - cur, mpd_song_get_pos(song));
cur += json_emit_raw_str(cur, end - cur, ",\"title\":"); cur += json_emit_raw_str(cur, end - cur, ",\"title\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_title(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_title(song));
cur += json_emit_raw_str(cur, end - cur, ",\"artist\":"); cur += json_emit_raw_str(cur, end - cur, ",\"artist\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_artist(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_artist(song));
cur += json_emit_raw_str(cur, end - cur, ",\"album\":"); cur += json_emit_raw_str(cur, end - cur, ",\"album\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_album(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_album(song));
cur += json_emit_raw_str(cur, end - cur, ",\"uri\":"); cur += json_emit_raw_str(cur, end - cur, ",\"uri\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_song_get_uri(song)); cur += json_emit_quoted_str(cur, end - cur, mpd_song_get_uri(song));
cur += json_emit_raw_str(cur, end - cur, ",\"currentsongid\":"); cur += json_emit_raw_str(cur, end - cur, ",\"currentsongid\":");
@ -884,7 +885,7 @@ int mpd_put_current_song(char *buffer)
return cur - buffer; return cur - buffer;
} }
int mpd_put_queue(char *buffer, unsigned int offset) int mympd_put_queue(char *buffer, unsigned int offset)
{ {
char *cur = buffer; char *cur = buffer;
const char *end = buffer + MAX_SIZE; const char *end = buffer + MAX_SIZE;
@ -916,11 +917,11 @@ int mpd_put_queue(char *buffer, unsigned int offset)
cur += json_emit_raw_str(cur, end - cur, ",\"duration\":"); cur += json_emit_raw_str(cur, end - cur, ",\"duration\":");
cur += json_emit_int(cur, end - cur, mpd_song_get_duration(song)); cur += json_emit_int(cur, end - cur, mpd_song_get_duration(song));
cur += json_emit_raw_str(cur, end - cur, ",\"artist\":"); cur += json_emit_raw_str(cur, end - cur, ",\"artist\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_artist(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_artist(song));
cur += json_emit_raw_str(cur, end - cur, ",\"album\":"); cur += json_emit_raw_str(cur, end - cur, ",\"album\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_album(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_album(song));
cur += json_emit_raw_str(cur, end - cur, ",\"title\":"); cur += json_emit_raw_str(cur, end - cur, ",\"title\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_title(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_title(song));
cur += json_emit_raw_str(cur, end - cur, "},"); cur += json_emit_raw_str(cur, end - cur, "},");
} }
@ -943,7 +944,7 @@ int mpd_put_queue(char *buffer, unsigned int offset)
return cur - buffer; return cur - buffer;
} }
int mpd_put_browse(char *buffer, char *path, unsigned int offset, char *filter) int mympd_put_browse(char *buffer, char *path, unsigned int offset, char *filter)
{ {
char *cur = buffer; char *cur = buffer;
const char *end = buffer + MAX_SIZE; const char *end = buffer + MAX_SIZE;
@ -969,7 +970,7 @@ int mpd_put_browse(char *buffer, char *path, unsigned int offset, char *filter)
break; break;
case MPD_ENTITY_TYPE_SONG: case MPD_ENTITY_TYPE_SONG:
song = mpd_entity_get_song(entity); song = mpd_entity_get_song(entity);
entityName = mpd_get_title(song); entityName = mympd_get_title(song);
if (strncmp(filter,"-",1) == 0 || strncasecmp(filter,entityName,1) == 0 || if (strncmp(filter,"-",1) == 0 || strncasecmp(filter,entityName,1) == 0 ||
( strncmp(filter,"0",1) == 0 && isalpha(*entityName) == 0 ) ( strncmp(filter,"0",1) == 0 && isalpha(*entityName) == 0 )
) { ) {
@ -977,9 +978,9 @@ int mpd_put_browse(char *buffer, char *path, unsigned int offset, char *filter)
cur += json_emit_raw_str(cur, end - cur, "{\"type\":\"song\",\"uri\":"); cur += json_emit_raw_str(cur, end - cur, "{\"type\":\"song\",\"uri\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_song_get_uri(song)); cur += json_emit_quoted_str(cur, end - cur, mpd_song_get_uri(song));
cur += json_emit_raw_str(cur, end - cur, ",\"album\":"); cur += json_emit_raw_str(cur, end - cur, ",\"album\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_album(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_album(song));
cur += json_emit_raw_str(cur, end - cur, ",\"artist\":"); cur += json_emit_raw_str(cur, end - cur, ",\"artist\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_artist(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_artist(song));
cur += json_emit_raw_str(cur, end - cur, ",\"duration\":"); cur += json_emit_raw_str(cur, end - cur, ",\"duration\":");
cur += json_emit_int(cur, end - cur, mpd_song_get_duration(song)); cur += json_emit_int(cur, end - cur, mpd_song_get_duration(song));
cur += json_emit_raw_str(cur, end - cur, ",\"title\":"); cur += json_emit_raw_str(cur, end - cur, ",\"title\":");
@ -1151,9 +1152,9 @@ int mympd_put_songs_in_album(char *buffer, char *albumartist, char *album)
cur += json_emit_raw_str(cur, end - cur, ",\"duration\":"); cur += json_emit_raw_str(cur, end - cur, ",\"duration\":");
cur += json_emit_int(cur, end - cur, mpd_song_get_duration(song)); cur += json_emit_int(cur, end - cur, mpd_song_get_duration(song));
cur += json_emit_raw_str(cur, end - cur, ",\"title\":"); cur += json_emit_raw_str(cur, end - cur, ",\"title\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_title(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_title(song));
cur += json_emit_raw_str(cur, end - cur, ",\"track\":"); cur += json_emit_raw_str(cur, end - cur, ",\"track\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_track(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_track(song));
cur += json_emit_raw_str(cur, end - cur, "},"); cur += json_emit_raw_str(cur, end - cur, "},");
} }
mpd_song_free(song); mpd_song_free(song);
@ -1226,7 +1227,7 @@ int mympd_put_playlists(char *buffer, unsigned int offset, char *filter)
return cur - buffer; return cur - buffer;
} }
int mpd_search(char *buffer, char *mpdtagtype, unsigned int offset, char *searchstr) int mympd_search(char *buffer, char *mpdtagtype, unsigned int offset, char *searchstr)
{ {
char *cur = buffer; char *cur = buffer;
const char *end = buffer + MAX_SIZE; const char *end = buffer + MAX_SIZE;
@ -1260,13 +1261,13 @@ int mpd_search(char *buffer, char *mpdtagtype, unsigned int offset, char *search
cur += json_emit_raw_str(cur, end - cur, ",\"uri\":"); cur += json_emit_raw_str(cur, end - cur, ",\"uri\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_song_get_uri(song)); cur += json_emit_quoted_str(cur, end - cur, mpd_song_get_uri(song));
cur += json_emit_raw_str(cur, end - cur, ",\"album\":"); cur += json_emit_raw_str(cur, end - cur, ",\"album\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_album(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_album(song));
cur += json_emit_raw_str(cur, end - cur, ",\"artist\":"); cur += json_emit_raw_str(cur, end - cur, ",\"artist\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_artist(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_artist(song));
cur += json_emit_raw_str(cur, end - cur, ",\"duration\":"); cur += json_emit_raw_str(cur, end - cur, ",\"duration\":");
cur += json_emit_int(cur, end - cur, mpd_song_get_duration(song)); cur += json_emit_int(cur, end - cur, mpd_song_get_duration(song));
cur += json_emit_raw_str(cur, end - cur, ",\"title\":"); cur += json_emit_raw_str(cur, end - cur, ",\"title\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_title(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_title(song));
cur += json_emit_raw_str(cur, end - cur, "},"); cur += json_emit_raw_str(cur, end - cur, "},");
} }
mpd_song_free(song); mpd_song_free(song);
@ -1289,7 +1290,7 @@ int mpd_search(char *buffer, char *mpdtagtype, unsigned int offset, char *search
return cur - buffer; return cur - buffer;
} }
int mpd_search_add(char *buffer,char *mpdtagtype, char *searchstr) int mympd_search_add(char *buffer,char *mpdtagtype, char *searchstr)
{ {
char *cur = buffer; char *cur = buffer;
const char *end = buffer + MAX_SIZE; const char *end = buffer + MAX_SIZE;
@ -1318,7 +1319,7 @@ int mpd_search_add(char *buffer,char *mpdtagtype, char *searchstr)
return cur - buffer; return cur - buffer;
} }
int mpd_search_queue(char *buffer, char *mpdtagtype, unsigned int offset, char *searchstr) int mympd_search_queue(char *buffer, char *mpdtagtype, unsigned int offset, char *searchstr)
{ {
char *cur = buffer; char *cur = buffer;
const char *end = buffer + MAX_SIZE; const char *end = buffer + MAX_SIZE;
@ -1354,13 +1355,13 @@ int mpd_search_queue(char *buffer, char *mpdtagtype, unsigned int offset, char *
cur += json_emit_raw_str(cur, end - cur, ",\"pos\":"); cur += json_emit_raw_str(cur, end - cur, ",\"pos\":");
cur += json_emit_int(cur, end - cur, mpd_song_get_pos(song)); cur += json_emit_int(cur, end - cur, mpd_song_get_pos(song));
cur += json_emit_raw_str(cur, end - cur, ",\"album\":"); cur += json_emit_raw_str(cur, end - cur, ",\"album\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_album(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_album(song));
cur += json_emit_raw_str(cur, end - cur, ",\"artist\":"); cur += json_emit_raw_str(cur, end - cur, ",\"artist\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_artist(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_artist(song));
cur += json_emit_raw_str(cur, end - cur, ",\"duration\":"); cur += json_emit_raw_str(cur, end - cur, ",\"duration\":");
cur += json_emit_int(cur, end - cur, mpd_song_get_duration(song)); cur += json_emit_int(cur, end - cur, mpd_song_get_duration(song));
cur += json_emit_raw_str(cur, end - cur, ",\"title\":"); cur += json_emit_raw_str(cur, end - cur, ",\"title\":");
cur += json_emit_quoted_str(cur, end - cur, mpd_get_title(song)); cur += json_emit_quoted_str(cur, end - cur, mympd_get_title(song));
cur += json_emit_raw_str(cur, end - cur, "},"); cur += json_emit_raw_str(cur, end - cur, "},");
mpd_song_free(song); mpd_song_free(song);
} }
@ -1419,8 +1420,8 @@ int mympd_get_stats(char *buffer)
return cur - buffer; return cur - buffer;
} }
void mpd_disconnect() void mympd_disconnect()
{ {
mpd.conn_state = MPD_DISCONNECT; mpd.conn_state = MPD_DISCONNECT;
mpd_poll(NULL); mympd_poll(NULL);
} }

View File

@ -131,22 +131,23 @@ struct t_mpd_client_session {
unsigned queue_version; unsigned queue_version;
}; };
void mpd_poll(struct mg_mgr *s); void mympd_poll(struct mg_mgr *s);
void callback_mpd(struct mg_connection *nc, const struct mg_str msg); void callback_mympd(struct mg_connection *nc, const struct mg_str msg);
int mpd_close_handler(struct mg_connection *c); int mympd_close_handler(struct mg_connection *c);
int mpd_put_state(char *buffer, int *current_song_id, int *next_song_id, unsigned *queue_version); int mympd_put_state(char *buffer, int *current_song_id, int *next_song_id, unsigned *queue_version);
int mpd_put_outputnames(char *buffer); int mympd_put_outputnames(char *buffer);
int mpd_put_current_song(char *buffer); int mympd_put_current_song(char *buffer);
int mpd_put_queue(char *buffer, unsigned int offset); int mympd_put_queue(char *buffer, unsigned int offset);
int mpd_put_browse(char *buffer, char *path, unsigned int offset, char *filter); int mympd_put_browse(char *buffer, char *path, unsigned int offset, char *filter);
int mpd_search(char *buffer, char *mpdtagtype, unsigned int offset, char *searchstr); int mympd_search(char *buffer, char *mpdtagtype, unsigned int offset, char *searchstr);
int mpd_search_add(char *buffer, char *mpdtagtype, char *searchstr); int mympd_search_add(char *buffer, char *mpdtagtype, char *searchstr);
int mpd_search_queue(char *buffer, char *mpdtagtype, unsigned int offset, char *searchstr); int mympd_search_queue(char *buffer, char *mpdtagtype, unsigned int offset, char *searchstr);
int mympd_put_welcome(char *buffer);
int mympd_get_stats(char *buffer); int mympd_get_stats(char *buffer);
int mympd_put_settings(char *buffer); int mympd_put_settings(char *buffer);
int mympd_put_db_tag(char *buffer, unsigned int offset, char *mpdtagtype, char *mpdsearchtagtype, char *searchstr, char *filter); int mympd_put_db_tag(char *buffer, unsigned int offset, char *mpdtagtype, char *mpdsearchtagtype, char *searchstr, char *filter);
int mympd_put_songs_in_album(char *buffer, char *albumartist, char *album); int mympd_put_songs_in_album(char *buffer, char *albumartist, char *album);
int mympd_put_playlists(char *buffer, unsigned int offset, char *filter); int mympd_put_playlists(char *buffer, unsigned int offset, char *filter);
void mpd_disconnect(); void mympd_disconnect();
#endif #endif

View File

@ -48,7 +48,7 @@ static void handle_api(struct mg_connection *nc, struct http_message *hm) {
char buf[1000] = {0}; char buf[1000] = {0};
memcpy(buf, hm->body.p,sizeof(buf) - 1 < hm->body.len ? sizeof(buf) - 1 : hm->body.len); memcpy(buf, hm->body.p,sizeof(buf) - 1 < hm->body.len ? sizeof(buf) - 1 : hm->body.len);
struct mg_str d = {buf, strlen(buf)}; struct mg_str d = {buf, strlen(buf)};
callback_mpd(nc, d); callback_mympd(nc, d);
mg_send_http_chunk(nc, "", 0); /* Send empty chunk, the end of response */ mg_send_http_chunk(nc, "", 0); /* Send empty chunk, the end of response */
} }
@ -58,8 +58,8 @@ static void ev_handler(struct mg_connection *nc, int ev, void *ev_data) {
#ifdef DEBUG #ifdef DEBUG
fprintf(stdout,"New Websocket connection\n"); fprintf(stdout,"New Websocket connection\n");
#endif #endif
struct mg_str d = {(char *) "MPD_API_WELCOME" }; struct mg_str d = {(char *) "MPD_API_WELCOME", 15 };
callback_mpd(nc, d); callback_mympd(nc, d);
break; break;
} }
case MG_EV_WEBSOCKET_FRAME: { case MG_EV_WEBSOCKET_FRAME: {
@ -69,7 +69,7 @@ static void ev_handler(struct mg_connection *nc, int ev, void *ev_data) {
#ifdef DEBUG #ifdef DEBUG
fprintf(stdout,"Websocket request: %s\n",wm->data); fprintf(stdout,"Websocket request: %s\n",wm->data);
#endif #endif
callback_mpd(nc, d); callback_mympd(nc, d);
break; break;
} }
case MG_EV_HTTP_REQUEST: { case MG_EV_HTTP_REQUEST: {
@ -90,7 +90,7 @@ static void ev_handler(struct mg_connection *nc, int ev, void *ev_data) {
#ifdef DEBUG #ifdef DEBUG
fprintf(stdout,"Websocket connection closed\n"); fprintf(stdout,"Websocket connection closed\n");
#endif #endif
mpd_close_handler(nc); mympd_close_handler(nc);
} }
else { else {
#ifdef DEBUG #ifdef DEBUG
@ -221,10 +221,10 @@ int main(int argc, char **argv)
if(current_timer - last_timer) if(current_timer - last_timer)
{ {
last_timer = current_timer; last_timer = current_timer;
mpd_poll(&mgr); mympd_poll(&mgr);
} }
} }
mg_mgr_free(&mgr); mg_mgr_free(&mgr);
mpd_disconnect(); mympd_disconnect();
return EXIT_SUCCESS; return EXIT_SUCCESS;
} }