From 430814a41d1ba988d35ef33a1202b4dcb2db939c Mon Sep 17 00:00:00 2001 From: Luiz Augusto von Dentz Date: Thu, 2 Oct 2008 16:48:17 -0300 Subject: Add property support for control interface. --- audio/control.c | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/audio/control.c b/audio/control.c index 4792b4ba..2c86ff25 100644 --- a/audio/control.c +++ b/audio/control.c @@ -55,6 +55,7 @@ #include "control.h" #include "sdpd.h" #include "glib-helper.h" +#include "dbus-common.h" #define AVCTP_PSM 23 @@ -933,14 +934,42 @@ static DBusMessage *control_is_connected(DBusConnection *conn, return reply; } +static DBusMessage *control_get_properties(DBusConnection *conn, + DBusMessage *msg, void *data) +{ + struct audio_device *device = data; + DBusMessage *reply; + DBusMessageIter iter; + DBusMessageIter dict; + gboolean value; + + dbus_message_iter_init_append(reply, &iter); + + dbus_message_iter_open_container(&iter, DBUS_TYPE_ARRAY, + DBUS_DICT_ENTRY_BEGIN_CHAR_AS_STRING + DBUS_TYPE_STRING_AS_STRING DBUS_TYPE_VARIANT_AS_STRING + DBUS_DICT_ENTRY_END_CHAR_AS_STRING, &dict); + + /* Connected */ + value = (device->control->session != NULL); + dbus_message_iter_append_dict_entry(&dict, "Connected", + DBUS_TYPE_BOOLEAN, &value); + + dbus_message_iter_close_container(&iter, &dict); + + return reply; +} + static GDBusMethodTable control_methods[] = { { "IsConnected", "", "b", control_is_connected }, + { "GetProperties", "", "a{sv}",control_get_properties }, { NULL, NULL, NULL, NULL } }; static GDBusSignalTable control_signals[] = { { "Connected", "" }, { "Disconnected", "" }, + { "PropertyChanged", "sv" }, { NULL, NULL } }; -- cgit