Various XMMS2 updates (thanks Lassi).
authorLassi Selander <sleipner@users.sourceforge.net>
Tue, 28 Apr 2009 16:02:24 +0000 (10:02 -0600)
committerBrenden Matthews <brenden@rty.ca>
Tue, 28 Apr 2009 16:02:24 +0000 (10:02 -0600)
ChangeLog
src/conky.c
src/conky.h
src/xmms2.c
src/xmms2.h

index d90afef..adc122c 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,6 @@
+2009-04-28
+       * Various XMMS2 updates (thanks Lassi)
+
 2009-04-19
        * 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
index 8d2adf9..693b1a5 100644 (file)
@@ -4428,6 +4428,10 @@ static void generate_text_internal(char *p, int p_max_size,
 #undef mpd_printf
 #endif
 
+#ifdef XMMS2
+    free_xmms2();
+#endif
+
 #ifdef MOC
 #define MOC_PRINT(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) {
-                               if (cur->xmms2_conn_state != 1) {
+                               if (cur->xmms2.conn_state != 1) {
                                        DO_JUMP;
                                }
                        }
index 920648a..002ae9f 100644 (file)
@@ -235,8 +235,6 @@ struct information {
        int mail_running;
 #ifdef XMMS2
        struct xmms2_s xmms2;
-       int xmms2_conn_state;
-       xmmsc_connection_t *xmms2_conn;
 #endif
 #ifdef AUDACIOUS
        AUDACIOUS_S audacious;
index 57017c0..d50de77 100644 (file)
 
 #include "conky.h"
 
+xmms_socket_t xmms2_fd;
+fd_set xmms2_fdset;
+xmmsc_connection_t *xmms2_conn;
+
 #define CONN_INIT      0
 #define CONN_OK                1
 #define CONN_NO                2
 
-/* callbacks */
-
 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) {
                ptr->xmms2.artist = malloc(text_buffer_size);
-               ptr->xmms2.artist[0] = '\0';
        }
 
        if (ptr->xmms2.album == NULL) {
                ptr->xmms2.album = malloc(text_buffer_size);
-               ptr->xmms2.album[0] = '\0';
        }
 
        if (ptr->xmms2.title == NULL) {
                ptr->xmms2.title = malloc(text_buffer_size);
-               ptr->xmms2.title[0] = '\0';
        }
 
        if (ptr->xmms2.genre == NULL) {
                ptr->xmms2.genre = malloc(text_buffer_size);
-               ptr->xmms2.genre[0] = '\0';
        }
 
        if (ptr->xmms2.comment == NULL) {
                ptr->xmms2.comment = malloc(text_buffer_size);
-               ptr->xmms2.comment[0] = '\0';
        }
 
        if (ptr->xmms2.url == NULL) {
                ptr->xmms2.url = malloc(text_buffer_size);
-               ptr->xmms2.url[0] = '\0';
        }
 
        if (ptr->xmms2.date == NULL) {
                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.album[0] = '\0';
        ptr->xmms2.title[0] = '\0';
@@ -99,138 +86,133 @@ static void xmms_clear(struct information *ptr)
 void connection_lost(void *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",
-                    xmmsc_get_last_error ( ptr->xmms2_conn ));
-        fflush(stderr);
+        fprintf(stderr,"XMMS2 connection failed. %s\n", xmmsc_get_last_error(xmms2_conn));
 
-       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;
+       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);
-               xmmsc_result_wait(res2);
-
-               xmms_clear(ptr);
+       if (xmmsv_get_error(value, &errbuf)) {
+               fprintf(stderr,"XMMS2 server error. %s\n", errbuf);
+               return TRUE;
+               }
 
-               ptr->xmms2.id = current_id;
+       if (xmmsv_get_int(value, &current_id) && current_id > 0) {
 
-               char *temp;
+               res = xmmsc_medialib_get_info(xmms2_conn, current_id);
+               xmmsc_result_wait(res);
+               val = xmmsc_result_get_value(res);
 
-               xmmsc_result_get_dict_entry_string(res2, "artist", &temp);
-               if (temp != NULL) {
-                       strncpy(ptr->xmms2.artist, temp, text_buffer_size - 1);
-               } else {
-                       strncpy(ptr->xmms2.artist, "[Unknown]", text_buffer_size - 1);
+               if (xmmsv_get_error(val, &errbuf)) {
+                       fprintf(stderr,"XMMS2 server error. %s\n", errbuf);
+                       return TRUE;
                }
 
-               xmmsc_result_get_dict_entry_string(res2, "title", &temp);
-               if (temp != NULL) {
-                       strncpy(ptr->xmms2.title, temp, text_buffer_size - 1);
-               } else {
-                       strncpy(ptr->xmms2.title, "[Unknown]", text_buffer_size - 1);
-               }
+               xmms_alloc(ptr);
 
-               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) {
+               ptr->xmms2.id = current_id;
 
-                       strncpy(ptr->xmms2.genre, temp, text_buffer_size - 1);
-               } else {
-                       strncpy(ptr->xmms2.genre, "[Unknown]", text_buffer_size - 1);
-               }
+               infos = xmmsv_propdict_to_dict(val, NULL);
 
-               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);
-               }
+               if (xmmsv_dict_get(infos, "artist", &dict_entry) && xmmsv_get_string(dict_entry, &charval))
+                       strncpy(ptr->xmms2.artist, charval, 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);
-               }
+               if (xmmsv_dict_get(infos, "title", &dict_entry) && xmmsv_get_string(dict_entry, &charval)) 
+                       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);
 
-               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);
-               }
+               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);
+               
 
-               int itemp;
 
-               xmmsc_result_get_dict_entry_int(res2, "tracknr", &itemp);
-               ptr->xmms2.tracknr = itemp;
+               if (xmmsv_dict_get(infos, "tracknr", &dict_entry) && xmmsv_get_int(dict_entry, &intval))
+                       ptr->xmms2.tracknr = intval;
 
-               xmmsc_result_get_dict_entry_int(res2, "duration", &itemp);
-               ptr->xmms2.duration = itemp;
+               if (xmmsv_dict_get(infos, "duration", &dict_entry) && xmmsv_get_int(dict_entry, &intval))
+                       ptr->xmms2.duration = intval;
 
-               xmmsc_result_get_dict_entry_int(res2, "bitrate", &itemp);
-               ptr->xmms2.bitrate = itemp / 1000;
+               if (xmmsv_dict_get(infos, "bitrate", &dict_entry) && xmmsv_get_int(dict_entry, &intval))
+                       ptr->xmms2.bitrate = intval / 1000;
 
-               xmmsc_result_get_dict_entry_int(res2, "size", &itemp);
-               ptr->xmms2.size = (float) itemp / 1048576;
+               if (xmmsv_dict_get(infos, "size", &dict_entry) && xmmsv_get_int(dict_entry, &intval))
+                       ptr->xmms2.size = (float) intval / 1048576;
 
-               xmmsc_result_get_dict_entry_int( res2, "timesplayed", &itemp );
-               ptr->xmms2.timesplayed = itemp;
+               if (xmmsv_dict_get(infos, "timesplayed", &dict_entry) && xmmsv_get_int(dict_entry, &intval))
+                       ptr->xmms2.timesplayed = intval;
 
-               xmmsc_result_unref(res2);
+
+               xmmsv_unref(infos);
+               xmmsc_result_unref(res);
        }
+       return TRUE;
 }
 
-void handle_playtime(xmmsc_result_t *res, void *p)
+int handle_playtime(xmmsv_t *value, void *p)
 {
        struct information *ptr = p;
-       xmmsc_result_t *res2;
-       uint play_time;
+       int play_time;
+       const char *errbuf;
 
-       if (xmmsc_result_iserror(res)) {
-               return;
+       if (xmmsv_get_error(value, &errbuf)) {
+               fprintf(stderr,"XMMS2 server error. %s\n", errbuf);
+               return TRUE;
        }
 
-       if (!xmmsc_result_get_uint(res, &play_time)) {
-               return;
+       if (xmmsv_get_int(value, &play_time)) {
+               ptr->xmms2.elapsed = play_time;
+               ptr->xmms2.progress = (float) play_time / ptr->xmms2.duration;
        }
 
-       res2 = xmmsc_result_restart(res);
-       xmmsc_result_unref(res2);
-
-       ptr->xmms2.elapsed = play_time;
-       ptr->xmms2.progress = (float) play_time / ptr->xmms2.duration;
+       return TRUE;
 }
 
-void handle_playback_state_change(xmmsc_result_t *res, void *p)
+int handle_playback_state_change(xmmsv_t *value, void *p)
 {
        struct information *ptr = p;
-       uint pb_state = 0;
+       int pb_state = 0;
+       const char *errbuf;
 
-       if (xmmsc_result_iserror(res)) {
-               return;
+       if (xmmsv_get_error(value, &errbuf)) {
+               fprintf(stderr,"XMMS2 server error. %s\n", errbuf);
+               return TRUE;
        }
 
-       if (!xmmsc_result_get_uint(res, &pb_state)) {
-               return;
+       if (ptr->xmms2.status == NULL) {
+               ptr->xmms2.status = malloc(text_buffer_size);
+               ptr->xmms2.status[0] = '\0';
        }
 
+       if (xmmsv_get_int(value, &pb_state)) {
        switch (pb_state) {
                case XMMS_PLAYBACK_STATUS_PLAY:
                        strncpy(ptr->xmms2.status, "Playing", text_buffer_size - 1);
@@ -244,20 +226,29 @@ void handle_playback_state_change(xmmsc_result_t *res, void *p)
                default:
                        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;
+       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) {
                ptr->xmms2.playlist = malloc(text_buffer_size);
                ptr->xmms2.playlist[0] = '\0';
        }
 
-       if (!xmmsc_result_get_string(res, &ptr->xmms2.playlist))  {
-               ptr->xmms2.playlist[0] = '\0';
+       if (xmmsv_get_string(value, &c))  {
+               strncpy(ptr->xmms2.playlist, c, text_buffer_size - 1);
        }
-
+       return TRUE;
 }
 
 void update_xmms2()
@@ -265,82 +256,91 @@ void update_xmms2()
        struct information *current_info = &info;
 
        /* initialize connection */
-       if (current_info->xmms2_conn_state == CONN_INIT) {
+       if (current_info->xmms2.conn_state == CONN_INIT) {
 
-               if (current_info->xmms2_conn == NULL) {
-                       current_info->xmms2_conn = xmmsc_init(PACKAGE);
+               if (xmms2_conn == NULL) {
+                       xmms2_conn = xmmsc_init(PACKAGE);
                }
 
                /* did init fail? */
-               if (current_info->xmms2_conn == NULL) {
-                       fprintf(stderr, PACKAGE_NAME": xmms2 init failed. %s\n",
-                                       xmmsc_get_last_error(current_info->xmms2_conn));
-                       fflush(stderr);
+               if (xmms2_conn == NULL) {
+                       fprintf(stderr,"XMMS2 init failed. %s\n", xmmsc_get_last_error(xmms2_conn));
                        return;
                }
 
                /* init ok but not connected yet.. */
-               current_info->xmms2_conn_state = CONN_NO;
+               current_info->xmms2.conn_state = CONN_NO;
 
                /* clear all values */
-               xmms_clear(current_info);
-
-               /* fprintf(stderr, PACKAGE_NAME": xmms2 init ok.\n");
-               fflush(stderr); */
+               xmms_alloc(current_info);
        }
 
        /* connect */
-       if (current_info->xmms2_conn_state == CONN_NO) {
+       if (current_info->xmms2.conn_state == CONN_NO) {
 
                char *path = getenv("XMMS_PATH");
 
-               if (!xmmsc_connect(current_info->xmms2_conn, path)) {
-                       fprintf(stderr, PACKAGE_NAME": xmms2 connection failed. %s\n",
-                               xmmsc_get_last_error(current_info->xmms2_conn));
-                       fflush(stderr);
-                       current_info->xmms2_conn_state = CONN_NO;
+               if (!xmmsc_connect(xmms2_conn, path)) {
+                       fprintf(stderr,"XMMS2 connection failed. %s\n", xmmsc_get_last_error(xmms2_conn));
+                       current_info->xmms2.conn_state = CONN_NO;
                        return;
                }
 
                /* set callbacks */
-               xmmsc_disconnect_callback_set(current_info->xmms2_conn, connection_lost,
-                       current_info);
-               XMMS_CALLBACK_SET(current_info->xmms2_conn,
-                       xmmsc_broadcast_playback_current_id, handle_curent_id,
-                       current_info);
-               XMMS_CALLBACK_SET(current_info->xmms2_conn,
-                       xmmsc_signal_playback_playtime, handle_playtime, current_info);
-               XMMS_CALLBACK_SET(current_info->xmms2_conn,
-                       xmmsc_broadcast_playback_status, handle_playback_state_change,
-                       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);
+               xmmsc_disconnect_callback_set(xmms2_conn, connection_lost, current_info);
+               XMMS_CALLBACK_SET(xmms2_conn, xmmsc_broadcast_playback_current_id, 
+                               handle_curent_id, current_info);
+               XMMS_CALLBACK_SET(xmms2_conn, xmmsc_signal_playback_playtime, 
+                               handle_playtime, current_info);
+               XMMS_CALLBACK_SET(xmms2_conn, xmmsc_broadcast_playback_status, 
+                               handle_playback_state_change, current_info);
+               XMMS_CALLBACK_SET(xmms2_conn, xmmsc_broadcast_playlist_loaded, 
+                               handle_playlist_loaded, current_info);
 
                /* get playback status, current id and active playlist */
-               XMMS_CALLBACK_SET(current_info->xmms2_conn,
-                               xmmsc_playback_current_id, handle_curent_id, current_info);
-               XMMS_CALLBACK_SET(current_info->xmms2_conn,
-                               xmmsc_playback_status, handle_playback_state_change, current_info);
-               XMMS_CALLBACK_SET(current_info->xmms2_conn,
-                               xmmsc_playlist_current_active, handle_playlist_loaded, current_info);
+               XMMS_CALLBACK_SET(xmms2_conn, xmmsc_playback_current_id, 
+                               handle_curent_id, current_info);
+               XMMS_CALLBACK_SET(xmms2_conn, xmmsc_playback_status, 
+                               handle_playback_state_change, current_info);
+               XMMS_CALLBACK_SET(xmms2_conn, xmmsc_playlist_current_active, 
+                               handle_playlist_loaded, current_info);
 
                /* everything seems to be ok */
-               current_info->xmms2_conn_state = CONN_OK;
-
-               /* fprintf(stderr, PACKAGE_NAME": xmms2 connected.\n");
-               fflush(stderr); */
+               current_info->xmms2.conn_state = CONN_OK;
        }
 
        /* handle callbacks */
-       if (current_info->xmms2_conn_state == CONN_OK) {
+       if (current_info->xmms2.conn_state == CONN_OK) {
+               struct timeval tmout;
+
+               tmout.tv_sec = 0;
+               tmout.tv_usec = 100;
                
-               xmmsc_io_in_handle(current_info->xmms2_conn);
-               if (xmmsc_io_want_out(current_info->xmms2_conn)) {
-                       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);
 }
+
+
index 8bea731..e51a93d 100644 (file)
@@ -37,7 +37,7 @@ struct xmms2_s {
        char *comment;
        char *url;
        char *date;
-       char* playlist;
+       char *playlist;
        int tracknr;
        int bitrate;
        unsigned int id;
@@ -48,8 +48,10 @@ struct xmms2_s {
 
        float progress;
        char *status;
+       int conn_state;
 };
 
 void update_xmms2(void);
+void free_xmms2(void);
 
 #endif /*XMMS2_H_*/