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:
parent
325094f6e7
commit
fba2a0540a
@ -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})
|
||||||
|
101
src/mpd_client.c
101
src/mpd_client.c
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
14
src/mympd.c
14
src/mympd.c
@ -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;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user