Don't report standard interfaces more than once

If they have a custom implementation, don't add the canned
introspection XML, just rely on the generated XML. Fixes
https://bugzilla.gnome.org/show_bug.cgi?id=642042
This commit is contained in:
Matthias Clasen 2011-02-15 19:50:55 -05:00
parent 6f87ecc14e
commit 5df049706f

View File

@ -4228,7 +4228,7 @@ static const gchar introspect_header[] =
static const gchar introspect_tail[] = static const gchar introspect_tail[] =
"</node>\n"; "</node>\n";
static const gchar introspect_standard_interfaces[] = static const gchar introspect_properties_interface[] =
" <interface name=\"org.freedesktop.DBus.Properties\">\n" " <interface name=\"org.freedesktop.DBus.Properties\">\n"
" <method name=\"Get\">\n" " <method name=\"Get\">\n"
" <arg type=\"s\" name=\"interface_name\" direction=\"in\"/>\n" " <arg type=\"s\" name=\"interface_name\" direction=\"in\"/>\n"
@ -4249,7 +4249,9 @@ static const gchar introspect_standard_interfaces[] =
" <arg type=\"a{sv}\" name=\"changed_properties\"/>\n" " <arg type=\"a{sv}\" name=\"changed_properties\"/>\n"
" <arg type=\"as\" name=\"invalidated_properties\"/>\n" " <arg type=\"as\" name=\"invalidated_properties\"/>\n"
" </signal>\n" " </signal>\n"
" </interface>\n" " </interface>\n";
static const gchar introspect_introspectable_interface[] =
" <interface name=\"org.freedesktop.DBus.Introspectable\">\n" " <interface name=\"org.freedesktop.DBus.Introspectable\">\n"
" <method name=\"Introspect\">\n" " <method name=\"Introspect\">\n"
" <arg type=\"s\" name=\"xml_data\" direction=\"out\"/>\n" " <arg type=\"s\" name=\"xml_data\" direction=\"out\"/>\n"
@ -4268,12 +4270,6 @@ introspect_append_header (GString *s)
g_string_append (s, introspect_header); g_string_append (s, introspect_header);
} }
static void
introspect_append_standard_interfaces (GString *s)
{
g_string_append (s, introspect_standard_interfaces);
}
static void static void
maybe_add_path (const gchar *path, gsize path_len, const gchar *object_path, GHashTable *set) maybe_add_path (const gchar *path, gsize path_len, const gchar *object_path, GHashTable *set)
{ {
@ -4365,10 +4361,17 @@ handle_introspect (GDBusConnection *connection,
/* first the header with the standard interfaces */ /* first the header with the standard interfaces */
s = g_string_sized_new (sizeof (introspect_header) + s = g_string_sized_new (sizeof (introspect_header) +
sizeof (introspect_standard_interfaces) + sizeof (introspect_properties_interface) +
sizeof (introspect_introspectable_interface) +
sizeof (introspect_tail)); sizeof (introspect_tail));
introspect_append_header (s); introspect_append_header (s);
introspect_append_standard_interfaces (s); if (!g_hash_table_lookup (eo->map_if_name_to_ei,
"org.freedesktop.DBus.Properties"))
g_string_append (s, introspect_properties_interface);
if (!g_hash_table_lookup (eo->map_if_name_to_ei,
"org.freedesktop.DBus.Introspectable"))
g_string_append (s, introspect_introspectable_interface);
/* then include the registered interfaces */ /* then include the registered interfaces */
g_hash_table_iter_init (&hash_iter, eo->map_if_name_to_ei); g_hash_table_iter_init (&hash_iter, eo->map_if_name_to_ei);
@ -5377,6 +5380,8 @@ handle_subtree_introspect (GDBusConnection *connection,
GDBusInterfaceInfo **interfaces; GDBusInterfaceInfo **interfaces;
guint n; guint n;
gchar **subnode_paths; gchar **subnode_paths;
gboolean has_properties_interface;
gboolean has_introspectable_interface;
handled = FALSE; handled = FALSE;
@ -5416,7 +5421,20 @@ handle_subtree_introspect (GDBusConnection *connection,
es->user_data); es->user_data);
if (interfaces != NULL) if (interfaces != NULL)
{ {
introspect_append_standard_interfaces (s); has_properties_interface = FALSE;
has_introspectable_interface = FALSE;
for (n = 0; interfaces[n] != NULL; n++)
{
if (strcmp (interfaces[n]->name, "org.freedesktop.DBus.Properties") == 0)
has_properties_interface = TRUE;
else if (strcmp (interfaces[n]->name, "org.freedesktop.DBus.Introspectable") == 0)
has_introspectable_interface = TRUE;
}
if (!has_properties_interface)
g_string_append (s, introspect_properties_interface);
if (!has_introspectable_interface)
g_string_append (s, introspect_introspectable_interface);
for (n = 0; interfaces[n] != NULL; n++) for (n = 0; interfaces[n] != NULL; n++)
{ {