From e7bf43c753dda82371be083bdb063a96767576eb Mon Sep 17 00:00:00 2001 From: Marcel Holtmann Date: Tue, 27 May 2008 07:57:04 +0000 Subject: Add introspection support for new interface handlers --- gdbus/object.c | 119 ++++++++++++++++++++++++++++++++++++++------------------- 1 file changed, 79 insertions(+), 40 deletions(-) (limited to 'gdbus') diff --git a/gdbus/object.c b/gdbus/object.c index 762ab74e..56d17c93 100644 --- a/gdbus/object.c +++ b/gdbus/object.c @@ -127,9 +127,80 @@ static void print_arguments(GString *gstr, const char *sig, const char *directio } } +static void generate_old_interface_xml(GString *gstr, struct interface_data *iface) +{ + DBusMethodVTable *method; + DBusSignalVTable *signal; + DBusPropertyVTable *property; + + for (method = iface->old_methods; method && method->name; method++) { + /* debug("%s: adding method %s.%s", + path, iface->name, method->name); */ + if (!strlen(method->signature) && !strlen(method->reply)) + g_string_append_printf(gstr, "\t\t\n", + method->name); + else { + g_string_append_printf(gstr, "\t\t\n", + method->name); + print_arguments(gstr, method->signature, "in"); + print_arguments(gstr, method->reply, "out"); + g_string_append_printf(gstr, "\t\t\n"); + } + } + + for (signal = iface->old_signals; signal && signal->name; signal++) { + /* debug("%s: adding signal %s.%s", + path, iface->name, signal->name); */ + if (!strlen(signal->signature)) + g_string_append_printf(gstr, "\t\t\n", + signal->name); + else { + g_string_append_printf(gstr, "\t\t\n", + signal->name); + print_arguments(gstr, signal->signature, NULL); + g_string_append_printf(gstr, "\t\t\n"); + } + } + + for (property = iface->old_properties; property && property->name; property++) { + debug("%s: adding property %s.%s", + path, iface->name, property->name); + } +} + +static void generate_interface_xml(GString *gstr, struct interface_data *iface) +{ + GDBusMethodTable *method; + GDBusSignalTable *signal; + + for (method = iface->methods; method && method->name; method++) { + if (!strlen(method->signature) && !strlen(method->reply)) + g_string_append_printf(gstr, "\t\t\n", + method->name); + else { + g_string_append_printf(gstr, "\t\t\n", + method->name); + print_arguments(gstr, method->signature, "in"); + print_arguments(gstr, method->reply, "out"); + g_string_append_printf(gstr, "\t\t\n"); + } + } + + for (signal = iface->signals; signal && signal->name; signal++) { + if (!strlen(signal->signature)) + g_string_append_printf(gstr, "\t\t\n", + signal->name); + else { + g_string_append_printf(gstr, "\t\t\n", + signal->name); + print_arguments(gstr, signal->signature, NULL); + g_string_append_printf(gstr, "\t\t\n"); + } + } +} + static void generate_introspection_xml(DBusConnection *conn, - struct generic_data *data, - const char *path) + struct generic_data *data, const char *path) { GSList *list; GString *gstr; @@ -144,45 +215,12 @@ static void generate_introspection_xml(DBusConnection *conn, for (list = data->interfaces; list; list = list->next) { struct interface_data *iface = list->data; - DBusMethodVTable *method; - DBusSignalVTable *signal; - DBusPropertyVTable *property; - - g_string_append_printf(gstr, "\t\n", iface->name); - - for (method = iface->old_methods; method && method->name; method++) { - /* debug("%s: adding method %s.%s", - path, iface->name, method->name); */ - if (!strlen(method->signature) && !strlen(method->reply)) - g_string_append_printf(gstr, "\t\t\n", - method->name); - else { - g_string_append_printf(gstr, "\t\t\n", - method->name); - print_arguments(gstr, method->signature, "in"); - print_arguments(gstr, method->reply, "out"); - g_string_append_printf(gstr, "\t\t\n"); - } - } - for (signal = iface->old_signals; signal && signal->name; signal++) { - /* debug("%s: adding signal %s.%s", - path, iface->name, signal->name); */ - if (!strlen(signal->signature)) - g_string_append_printf(gstr, "\t\t\n", - signal->name); - else { - g_string_append_printf(gstr, "\t\t\n", - signal->name); - print_arguments(gstr, signal->signature, NULL); - g_string_append_printf(gstr, "\t\t\n"); - } - } + g_string_append_printf(gstr, "\t\n", + iface->name); - for (property = iface->old_properties; property && property->name; property++) { - debug("%s: adding property %s.%s", - path, iface->name, property->name); - } + generate_interface_xml(gstr, iface); + generate_old_interface_xml(gstr, iface); g_string_append_printf(gstr, "\t\n"); } @@ -191,7 +229,8 @@ static void generate_introspection_xml(DBusConnection *conn, goto done; for (i = 0; children[i]; i++) - g_string_append_printf(gstr, "\t\n", children[i]); + g_string_append_printf(gstr, "\t\n", + children[i]); dbus_free_string_array(children); -- cgit