AM_CONDITIONAL(BUILD_BMPX, test x$want_bmpx = xyes)
if test x$want_bmpx = xyes; then
- PKG_CHECK_MODULES([DBUS], [dbus-1 >= 0.35 dbus-glib-1 >= 0.35])
- CFLAGS="$CFLAGS $DBUS_CFLAGS"
- LIBS="$LIBS $DBUS_LIBS"
- AC_CHECK_HEADERS([bmpx/dbus.h], [], [BMPX_MISSING=yes])
- if test "x$BMPX_MISSING" = xyes; then
- AC_MSG_ERROR([bmpx doesn't seem to be installed, or the headers aren't available])
- fi
+ PKG_CHECK_MODULES([BMPX], [bmp-2.0 >= 0.14.0])
+ CFLAGS="$CFLAGS $BMPX_CFLAGS"
+ LIBS="$LIBS $BMPX_LIBS"
AC_DEFINE(BMPX, 1, [Define if you want BMPx support])
fi
* $Id$
*/
-#include <bmpx/dbus.h>
+#include <bmp/dbus.h>
#include <dbus/dbus-glib.h>
#include <stdio.h>
{
GError *error = NULL;
struct information *current_info = &info;
- gchar *uri;
+ gint current_track;
GHashTable *metadata;
if (connected == 0) {
remote_object = dbus_g_proxy_new_for_name(bus,
BMP_DBUS_SERVICE,
- BMP_DBUS_PATH_SYSTEMCONTROL,
+ BMP_DBUS_PATH,
BMP_DBUS_INTERFACE);
if (!remote_object) {
ERR("BMPx error 2: %s\n", error->message);
}
if (connected == 1) {
- if (dbus_g_proxy_call(remote_object, "GetCurrentUri", &error,
+ if (dbus_g_proxy_call(remote_object, "GetCurrentTrack", &error,
G_TYPE_INVALID,
- G_TYPE_STRING, &uri, G_TYPE_INVALID)) {
- current_info->bmpx.uri = uri;
+ G_TYPE_INT, ¤t_track, G_TYPE_INVALID)) {
} else {
ERR("BMPx error 3: %s\n", error->message);
goto fail;
}
- if (dbus_g_proxy_call(remote_object, "GetMetadataForUri", &error,
- G_TYPE_STRING,
- uri,
+ if (dbus_g_proxy_call(remote_object, "GetMetadataForListItem", &error,
+ G_TYPE_INT,
+ current_track,
G_TYPE_INVALID,
DBUS_TYPE_G_STRING_VALUE_HASHTABLE,
&metadata,
current_info->bmpx.album = g_value_dup_string(g_hash_table_lookup(metadata, "album"));
current_info->bmpx.bitrate = g_value_get_int(g_hash_table_lookup(metadata, "bitrate"));
current_info->bmpx.track = g_value_get_int(g_hash_table_lookup(metadata, "track-number"));
+ current_info->bmpx.uri = g_value_get_string(g_hash_table_lookup(metadata, "location"));
} else {
ERR("BMPx error 4: %s\n", error->message);
goto fail;
}
- if (uri)
- free(uri);
g_hash_table_destroy(metadata);
} else {
fail: