summaryrefslogtreecommitdiffstats
path: root/hcid
diff options
context:
space:
mode:
authorMarcel Holtmann <marcel@holtmann.org>2007-03-21 20:06:22 +0000
committerMarcel Holtmann <marcel@holtmann.org>2007-03-21 20:06:22 +0000
commitba0868228148425b65234eafc5d75cf498ad4838 (patch)
tree449f8a3b174f1673bb3f1df690f6519d380de617 /hcid
parent4128274b3b8c47a58f6895e1dbe5b1949887b9e1 (diff)
Add example for the dictionary based info methods
Diffstat (limited to 'hcid')
-rw-r--r--hcid/dbus-service.c38
1 files changed, 36 insertions, 2 deletions
diff --git a/hcid/dbus-service.c b/hcid/dbus-service.c
index 1b3e8012..acf21ca4 100644
--- a/hcid/dbus-service.c
+++ b/hcid/dbus-service.c
@@ -104,7 +104,42 @@ static void service_exit(const char *name, struct service *service)
static DBusHandlerResult get_info(DBusConnection *conn,
DBusMessage *msg, void *data)
{
- return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
+ struct service *service = data;
+ DBusMessage *reply;
+ DBusMessageIter iter;
+ DBusMessageIter dict;
+ DBusMessageIter entry;
+ DBusMessageIter value;
+ const char *key = "identifier";
+ const char *val = service->ident;
+
+ reply = dbus_message_new_method_return(msg);
+ if (!reply)
+ return DBUS_HANDLER_RESULT_NEED_MEMORY;
+
+ 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);
+
+ /* Begin key value pair */
+ dbus_message_iter_open_container(&dict, DBUS_TYPE_DICT_ENTRY, NULL, &entry);
+ dbus_message_iter_append_basic(&entry, DBUS_TYPE_STRING, &key);
+
+ dbus_message_iter_open_container(&entry, DBUS_TYPE_VARIANT,
+ DBUS_TYPE_STRING_AS_STRING, &value);
+ dbus_message_iter_append_basic(&value, DBUS_TYPE_STRING, &val);
+
+ dbus_message_iter_close_container(&entry, &value);
+
+ dbus_message_iter_close_container(&dict, &entry);
+ /* End key value pair */
+
+ dbus_message_iter_close_container(&iter, &dict);
+
+ return send_message_and_unref(conn, reply);
}
static DBusHandlerResult get_identifier(DBusConnection *conn,
@@ -1015,4 +1050,3 @@ int service_unregister(struct service *service)
{
return unregister_service(service);
}
-