1
0
mirror of https://github.com/Llewellynvdm/conky.git synced 2024-12-26 12:27:52 +00:00

Various XMMS2 updates (thanks Lassi).

This commit is contained in:
Lassi Selander 2009-04-28 10:02:24 -06:00 committed by Brenden Matthews
parent fb8ccd7a05
commit 49aee8707a
5 changed files with 167 additions and 160 deletions

View File

@ -1,3 +1,6 @@
2009-04-28
* Various XMMS2 updates (thanks Lassi)
2009-04-19 2009-04-19
* Make it possible to place spaces in front of RSS-items as a workaround * Make it possible to place spaces in front of RSS-items as a workaround
for the problem that $goto only moves the first RSS-item. This is only a for the problem that $goto only moves the first RSS-item. This is only a

View File

@ -4428,6 +4428,10 @@ static void generate_text_internal(char *p, int p_max_size,
#undef mpd_printf #undef mpd_printf
#endif #endif
#ifdef XMMS2
free_xmms2();
#endif
#ifdef MOC #ifdef MOC
#define MOC_PRINT(t, a) \ #define MOC_PRINT(t, a) \
snprintf(p, p_max_size, "%s", (moc.t ? moc.t : a)) snprintf(p, p_max_size, "%s", (moc.t ? moc.t : a))
@ -4537,7 +4541,7 @@ static void generate_text_internal(char *p, int p_max_size,
} }
} }
OBJ(if_xmms2_connected) { OBJ(if_xmms2_connected) {
if (cur->xmms2_conn_state != 1) { if (cur->xmms2.conn_state != 1) {
DO_JUMP; DO_JUMP;
} }
} }

View File

@ -235,8 +235,6 @@ struct information {
int mail_running; int mail_running;
#ifdef XMMS2 #ifdef XMMS2
struct xmms2_s xmms2; struct xmms2_s xmms2;
int xmms2_conn_state;
xmmsc_connection_t *xmms2_conn;
#endif #endif
#ifdef AUDACIOUS #ifdef AUDACIOUS
AUDACIOUS_S audacious; AUDACIOUS_S audacious;

View File

@ -26,58 +26,45 @@
#include "conky.h" #include "conky.h"
xmms_socket_t xmms2_fd;
fd_set xmms2_fdset;
xmmsc_connection_t *xmms2_conn;
#define CONN_INIT 0 #define CONN_INIT 0
#define CONN_OK 1 #define CONN_OK 1
#define CONN_NO 2 #define CONN_NO 2
/* callbacks */
static void xmms_alloc(struct information *ptr) static void xmms_alloc(struct information *ptr)
{ {
if (ptr->xmms2.status == NULL) {
ptr->xmms2.status = malloc(text_buffer_size);
ptr->xmms2.status[0] = '\0';
}
if (ptr->xmms2.artist == NULL) { if (ptr->xmms2.artist == NULL) {
ptr->xmms2.artist = malloc(text_buffer_size); ptr->xmms2.artist = malloc(text_buffer_size);
ptr->xmms2.artist[0] = '\0';
} }
if (ptr->xmms2.album == NULL) { if (ptr->xmms2.album == NULL) {
ptr->xmms2.album = malloc(text_buffer_size); ptr->xmms2.album = malloc(text_buffer_size);
ptr->xmms2.album[0] = '\0';
} }
if (ptr->xmms2.title == NULL) { if (ptr->xmms2.title == NULL) {
ptr->xmms2.title = malloc(text_buffer_size); ptr->xmms2.title = malloc(text_buffer_size);
ptr->xmms2.title[0] = '\0';
} }
if (ptr->xmms2.genre == NULL) { if (ptr->xmms2.genre == NULL) {
ptr->xmms2.genre = malloc(text_buffer_size); ptr->xmms2.genre = malloc(text_buffer_size);
ptr->xmms2.genre[0] = '\0';
} }
if (ptr->xmms2.comment == NULL) { if (ptr->xmms2.comment == NULL) {
ptr->xmms2.comment = malloc(text_buffer_size); ptr->xmms2.comment = malloc(text_buffer_size);
ptr->xmms2.comment[0] = '\0';
} }
if (ptr->xmms2.url == NULL) { if (ptr->xmms2.url == NULL) {
ptr->xmms2.url = malloc(text_buffer_size); ptr->xmms2.url = malloc(text_buffer_size);
ptr->xmms2.url[0] = '\0';
} }
if (ptr->xmms2.date == NULL) { if (ptr->xmms2.date == NULL) {
ptr->xmms2.date = malloc(text_buffer_size); ptr->xmms2.date = malloc(text_buffer_size);
ptr->xmms2.date[0] = '\0';
}
} }
static void xmms_clear(struct information *ptr)
{
xmms_alloc(ptr);
ptr->xmms2.artist[0] = '\0'; ptr->xmms2.artist[0] = '\0';
ptr->xmms2.album[0] = '\0'; ptr->xmms2.album[0] = '\0';
ptr->xmms2.title[0] = '\0'; ptr->xmms2.title[0] = '\0';
@ -99,138 +86,133 @@ static void xmms_clear(struct information *ptr)
void connection_lost(void *p) void connection_lost(void *p)
{ {
struct information *ptr = p; struct information *ptr = p;
ptr->xmms2_conn_state = CONN_NO; ptr->xmms2.conn_state = CONN_NO;
fprintf(stderr,PACKAGE_NAME": xmms2 connection failed. %s\n", fprintf(stderr,"XMMS2 connection failed. %s\n", xmmsc_get_last_error(xmms2_conn));
xmmsc_get_last_error ( ptr->xmms2_conn ));
fflush(stderr);
xmms_clear(ptr); xmms_alloc(ptr);
strncpy(ptr->xmms2.status, "Disocnnected", text_buffer_size - 1);
ptr->xmms2.playlist[0] = '\0';
ptr->xmms2.id = 0;
} }
void handle_curent_id(xmmsc_result_t *res, void *p)
int handle_curent_id(xmmsv_t *value, void *p)
{ {
uint current_id;
struct information *ptr = p; struct information *ptr = p;
xmmsv_t *val, *infos, *dict_entry;
xmmsc_result_t *res;
const char *errbuf;
int current_id;
if (xmmsc_result_get_uint(res, &current_id)) { const char *charval;
int intval;
xmmsc_result_t *res2;
res2 = xmmsc_medialib_get_info(ptr->xmms2_conn, current_id); if (xmmsv_get_error(value, &errbuf)) {
xmmsc_result_wait(res2); fprintf(stderr,"XMMS2 server error. %s\n", errbuf);
return TRUE;
}
if (xmmsv_get_int(value, &current_id) && current_id > 0) {
res = xmmsc_medialib_get_info(xmms2_conn, current_id);
xmmsc_result_wait(res);
val = xmmsc_result_get_value(res);
if (xmmsv_get_error(val, &errbuf)) {
fprintf(stderr,"XMMS2 server error. %s\n", errbuf);
return TRUE;
}
xmms_alloc(ptr);
xmms_clear(ptr);
ptr->xmms2.id = current_id; ptr->xmms2.id = current_id;
char *temp; infos = xmmsv_propdict_to_dict(val, NULL);
xmmsc_result_get_dict_entry_string(res2, "artist", &temp); if (xmmsv_dict_get(infos, "artist", &dict_entry) && xmmsv_get_string(dict_entry, &charval))
if (temp != NULL) { strncpy(ptr->xmms2.artist, charval, text_buffer_size - 1);
strncpy(ptr->xmms2.artist, temp, text_buffer_size - 1);
} else { if (xmmsv_dict_get(infos, "title", &dict_entry) && xmmsv_get_string(dict_entry, &charval))
strncpy(ptr->xmms2.artist, "[Unknown]", text_buffer_size - 1); strncpy(ptr->xmms2.title, charval, text_buffer_size - 1);
if (xmmsv_dict_get(infos, "album", &dict_entry) && xmmsv_get_string(dict_entry, &charval))
strncpy(ptr->xmms2.album, charval, text_buffer_size - 1);
if (xmmsv_dict_get(infos, "genre", &dict_entry) && xmmsv_get_string(dict_entry, &charval))
strncpy(ptr->xmms2.genre, charval, text_buffer_size - 1);
if (xmmsv_dict_get(infos, "comment", &dict_entry) && xmmsv_get_string(dict_entry, &charval))
strncpy(ptr->xmms2.comment, charval, text_buffer_size - 1);
if (xmmsv_dict_get(infos, "url", &dict_entry) && xmmsv_get_string(dict_entry, &charval))
strncpy(ptr->xmms2.url, charval, text_buffer_size - 1);
if (xmmsv_dict_get(infos, "date", &dict_entry) && xmmsv_get_string(dict_entry, &charval))
strncpy(ptr->xmms2.date, charval, text_buffer_size - 1);
if (xmmsv_dict_get(infos, "tracknr", &dict_entry) && xmmsv_get_int(dict_entry, &intval))
ptr->xmms2.tracknr = intval;
if (xmmsv_dict_get(infos, "duration", &dict_entry) && xmmsv_get_int(dict_entry, &intval))
ptr->xmms2.duration = intval;
if (xmmsv_dict_get(infos, "bitrate", &dict_entry) && xmmsv_get_int(dict_entry, &intval))
ptr->xmms2.bitrate = intval / 1000;
if (xmmsv_dict_get(infos, "size", &dict_entry) && xmmsv_get_int(dict_entry, &intval))
ptr->xmms2.size = (float) intval / 1048576;
if (xmmsv_dict_get(infos, "timesplayed", &dict_entry) && xmmsv_get_int(dict_entry, &intval))
ptr->xmms2.timesplayed = intval;
xmmsv_unref(infos);
xmmsc_result_unref(res);
}
return TRUE;
} }
xmmsc_result_get_dict_entry_string(res2, "title", &temp); int handle_playtime(xmmsv_t *value, void *p)
if (temp != NULL) {
strncpy(ptr->xmms2.title, temp, text_buffer_size - 1);
} else {
strncpy(ptr->xmms2.title, "[Unknown]", text_buffer_size - 1);
}
xmmsc_result_get_dict_entry_string(res2, "album", &temp);
if (temp != NULL) {
strncpy(ptr->xmms2.album, temp, text_buffer_size - 1);
} else {
strncpy(ptr->xmms2.album, "[Unknown]", text_buffer_size - 1);
}
xmmsc_result_get_dict_entry_string(res2, "genre", &temp);
if (temp != NULL) {
strncpy(ptr->xmms2.genre, temp, text_buffer_size - 1);
} else {
strncpy(ptr->xmms2.genre, "[Unknown]", text_buffer_size - 1);
}
xmmsc_result_get_dict_entry_string(res2, "comment", &temp);
if (temp != NULL) {
strncpy(ptr->xmms2.comment, temp, text_buffer_size - 1);
} else {
strncpy(ptr->xmms2.comment, "", text_buffer_size - 1);
}
xmmsc_result_get_dict_entry_string(res2, "url", &temp);
if (temp != NULL) {
strncpy(ptr->xmms2.url, temp, text_buffer_size - 1);
} else {
strncpy(ptr->xmms2.url, "[Unknown]", text_buffer_size - 1);
}
xmmsc_result_get_dict_entry_string(res2, "date", &temp);
if (temp != NULL) {
strncpy(ptr->xmms2.date, temp, text_buffer_size - 1);
} else {
strncpy(ptr->xmms2.date, "????", text_buffer_size - 1);
}
int itemp;
xmmsc_result_get_dict_entry_int(res2, "tracknr", &itemp);
ptr->xmms2.tracknr = itemp;
xmmsc_result_get_dict_entry_int(res2, "duration", &itemp);
ptr->xmms2.duration = itemp;
xmmsc_result_get_dict_entry_int(res2, "bitrate", &itemp);
ptr->xmms2.bitrate = itemp / 1000;
xmmsc_result_get_dict_entry_int(res2, "size", &itemp);
ptr->xmms2.size = (float) itemp / 1048576;
xmmsc_result_get_dict_entry_int( res2, "timesplayed", &itemp );
ptr->xmms2.timesplayed = itemp;
xmmsc_result_unref(res2);
}
}
void handle_playtime(xmmsc_result_t *res, void *p)
{ {
struct information *ptr = p; struct information *ptr = p;
xmmsc_result_t *res2; int play_time;
uint play_time; const char *errbuf;
if (xmmsc_result_iserror(res)) { if (xmmsv_get_error(value, &errbuf)) {
return; fprintf(stderr,"XMMS2 server error. %s\n", errbuf);
return TRUE;
} }
if (!xmmsc_result_get_uint(res, &play_time)) { if (xmmsv_get_int(value, &play_time)) {
return;
}
res2 = xmmsc_result_restart(res);
xmmsc_result_unref(res2);
ptr->xmms2.elapsed = play_time; ptr->xmms2.elapsed = play_time;
ptr->xmms2.progress = (float) play_time / ptr->xmms2.duration; ptr->xmms2.progress = (float) play_time / ptr->xmms2.duration;
} }
void handle_playback_state_change(xmmsc_result_t *res, void *p) return TRUE;
}
int handle_playback_state_change(xmmsv_t *value, void *p)
{ {
struct information *ptr = p; struct information *ptr = p;
uint pb_state = 0; int pb_state = 0;
const char *errbuf;
if (xmmsc_result_iserror(res)) { if (xmmsv_get_error(value, &errbuf)) {
return; fprintf(stderr,"XMMS2 server error. %s\n", errbuf);
return TRUE;
} }
if (!xmmsc_result_get_uint(res, &pb_state)) { if (ptr->xmms2.status == NULL) {
return; ptr->xmms2.status = malloc(text_buffer_size);
ptr->xmms2.status[0] = '\0';
} }
if (xmmsv_get_int(value, &pb_state)) {
switch (pb_state) { switch (pb_state) {
case XMMS_PLAYBACK_STATUS_PLAY: case XMMS_PLAYBACK_STATUS_PLAY:
strncpy(ptr->xmms2.status, "Playing", text_buffer_size - 1); strncpy(ptr->xmms2.status, "Playing", text_buffer_size - 1);
@ -245,19 +227,28 @@ void handle_playback_state_change(xmmsc_result_t *res, void *p)
strncpy(ptr->xmms2.status, "Unknown", text_buffer_size - 1); strncpy(ptr->xmms2.status, "Unknown", text_buffer_size - 1);
} }
} }
return TRUE;
}
void handle_playlist_loaded(xmmsc_result_t *res, void *p) { int handle_playlist_loaded(xmmsv_t *value, void *p)
{
struct information *ptr = p; struct information *ptr = p;
const char *c, *errbuf;
if (xmmsv_get_error(value, &errbuf)) {
fprintf(stderr,"XMMS2 server error. %s\n", errbuf);
return TRUE;
}
if (ptr->xmms2.playlist == NULL) { if (ptr->xmms2.playlist == NULL) {
ptr->xmms2.playlist = malloc(text_buffer_size); ptr->xmms2.playlist = malloc(text_buffer_size);
ptr->xmms2.playlist[0] = '\0'; ptr->xmms2.playlist[0] = '\0';
} }
if (!xmmsc_result_get_string(res, &ptr->xmms2.playlist)) { if (xmmsv_get_string(value, &c)) {
ptr->xmms2.playlist[0] = '\0'; strncpy(ptr->xmms2.playlist, c, text_buffer_size - 1);
} }
return TRUE;
} }
void update_xmms2() void update_xmms2()
@ -265,82 +256,91 @@ void update_xmms2()
struct information *current_info = &info; struct information *current_info = &info;
/* initialize connection */ /* initialize connection */
if (current_info->xmms2_conn_state == CONN_INIT) { if (current_info->xmms2.conn_state == CONN_INIT) {
if (current_info->xmms2_conn == NULL) { if (xmms2_conn == NULL) {
current_info->xmms2_conn = xmmsc_init(PACKAGE); xmms2_conn = xmmsc_init(PACKAGE);
} }
/* did init fail? */ /* did init fail? */
if (current_info->xmms2_conn == NULL) { if (xmms2_conn == NULL) {
fprintf(stderr, PACKAGE_NAME": xmms2 init failed. %s\n", fprintf(stderr,"XMMS2 init failed. %s\n", xmmsc_get_last_error(xmms2_conn));
xmmsc_get_last_error(current_info->xmms2_conn));
fflush(stderr);
return; return;
} }
/* init ok but not connected yet.. */ /* init ok but not connected yet.. */
current_info->xmms2_conn_state = CONN_NO; current_info->xmms2.conn_state = CONN_NO;
/* clear all values */ /* clear all values */
xmms_clear(current_info); xmms_alloc(current_info);
/* fprintf(stderr, PACKAGE_NAME": xmms2 init ok.\n");
fflush(stderr); */
} }
/* connect */ /* connect */
if (current_info->xmms2_conn_state == CONN_NO) { if (current_info->xmms2.conn_state == CONN_NO) {
char *path = getenv("XMMS_PATH"); char *path = getenv("XMMS_PATH");
if (!xmmsc_connect(current_info->xmms2_conn, path)) { if (!xmmsc_connect(xmms2_conn, path)) {
fprintf(stderr, PACKAGE_NAME": xmms2 connection failed. %s\n", fprintf(stderr,"XMMS2 connection failed. %s\n", xmmsc_get_last_error(xmms2_conn));
xmmsc_get_last_error(current_info->xmms2_conn)); current_info->xmms2.conn_state = CONN_NO;
fflush(stderr);
current_info->xmms2_conn_state = CONN_NO;
return; return;
} }
/* set callbacks */ /* set callbacks */
xmmsc_disconnect_callback_set(current_info->xmms2_conn, connection_lost, xmmsc_disconnect_callback_set(xmms2_conn, connection_lost, current_info);
current_info); XMMS_CALLBACK_SET(xmms2_conn, xmmsc_broadcast_playback_current_id,
XMMS_CALLBACK_SET(current_info->xmms2_conn, handle_curent_id, current_info);
xmmsc_broadcast_playback_current_id, handle_curent_id, XMMS_CALLBACK_SET(xmms2_conn, xmmsc_signal_playback_playtime,
current_info); handle_playtime, current_info);
XMMS_CALLBACK_SET(current_info->xmms2_conn, XMMS_CALLBACK_SET(xmms2_conn, xmmsc_broadcast_playback_status,
xmmsc_signal_playback_playtime, handle_playtime, current_info); handle_playback_state_change, current_info);
XMMS_CALLBACK_SET(current_info->xmms2_conn, XMMS_CALLBACK_SET(xmms2_conn, xmmsc_broadcast_playlist_loaded,
xmmsc_broadcast_playback_status, handle_playback_state_change, handle_playlist_loaded, current_info);
current_info);
XMMS_CALLBACK_SET(current_info->xmms2_conn,
xmmsc_broadcast_playlist_loaded, handle_playlist_loaded,
current_info);
XMMS_CALLBACK_SET(current_info->xmms2_conn,
xmmsc_broadcast_medialib_entry_changed, handle_curent_id,
current_info);
/* get playback status, current id and active playlist */ /* get playback status, current id and active playlist */
XMMS_CALLBACK_SET(current_info->xmms2_conn, XMMS_CALLBACK_SET(xmms2_conn, xmmsc_playback_current_id,
xmmsc_playback_current_id, handle_curent_id, current_info); handle_curent_id, current_info);
XMMS_CALLBACK_SET(current_info->xmms2_conn, XMMS_CALLBACK_SET(xmms2_conn, xmmsc_playback_status,
xmmsc_playback_status, handle_playback_state_change, current_info); handle_playback_state_change, current_info);
XMMS_CALLBACK_SET(current_info->xmms2_conn, XMMS_CALLBACK_SET(xmms2_conn, xmmsc_playlist_current_active,
xmmsc_playlist_current_active, handle_playlist_loaded, current_info); handle_playlist_loaded, current_info);
/* everything seems to be ok */ /* everything seems to be ok */
current_info->xmms2_conn_state = CONN_OK; current_info->xmms2.conn_state = CONN_OK;
/* fprintf(stderr, PACKAGE_NAME": xmms2 connected.\n");
fflush(stderr); */
} }
/* handle callbacks */ /* handle callbacks */
if (current_info->xmms2_conn_state == CONN_OK) { if (current_info->xmms2.conn_state == CONN_OK) {
struct timeval tmout;
xmmsc_io_in_handle(current_info->xmms2_conn); tmout.tv_sec = 0;
if (xmmsc_io_want_out(current_info->xmms2_conn)) { tmout.tv_usec = 100;
xmmsc_io_out_handle(current_info->xmms2_conn);
select(xmms2_fd + 1, &xmms2_fdset, NULL, NULL, &tmout);
xmmsc_io_in_handle(xmms2_conn);
if (xmmsc_io_want_out(xmms2_conn)) {
xmmsc_io_out_handle(xmms2_conn);
} }
} }
} }
void free_xmms2()
{
struct information *current_info = &info;
current_info->xmms2.conn_state = -1;
free(current_info->xmms2.artist);
free(current_info->xmms2.album);
free(current_info->xmms2.title);
free(current_info->xmms2.genre);
free(current_info->xmms2.comment);
free(current_info->xmms2.url);
free(current_info->xmms2.date);
free(current_info->xmms2.playlist);
free(current_info->xmms2.status);
}

View File

@ -48,8 +48,10 @@ struct xmms2_s {
float progress; float progress;
char *status; char *status;
int conn_state;
}; };
void update_xmms2(void); void update_xmms2(void);
void free_xmms2(void);
#endif /*XMMS2_H_*/ #endif /*XMMS2_H_*/