mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2024-11-10 03:16:17 +01:00
gdbus: Use g_markup_collect_known_attributes() in GDBus introspection
In order to be able to cope with the introspection XML from the Telepathy specification, which uses attributes like tp:type and tp:name-for-bindings, we need to ignore unknown attributes when parsing. Closes: https://bugzilla.gnome.org/show_bug.cgi?id=665634
This commit is contained in:
parent
8d40389d15
commit
86329ba44f
@ -1276,14 +1276,12 @@ parser_start_element (GMarkupParseContext *context,
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (!g_markup_collect_attributes (element_name,
|
||||
attribute_names,
|
||||
attribute_values,
|
||||
error,
|
||||
G_MARKUP_COLLECT_STRING | G_MARKUP_COLLECT_OPTIONAL, "name", &name,
|
||||
/* some hand-written introspection XML documents use this */
|
||||
G_MARKUP_COLLECT_STRING | G_MARKUP_COLLECT_OPTIONAL, "xmlns:doc", NULL,
|
||||
G_MARKUP_COLLECT_INVALID))
|
||||
if (!g_markup_collect_known_attributes (element_name,
|
||||
attribute_names,
|
||||
attribute_values,
|
||||
error,
|
||||
G_MARKUP_COLLECT_STRING | G_MARKUP_COLLECT_OPTIONAL, "name", &name,
|
||||
G_MARKUP_COLLECT_INVALID))
|
||||
goto out;
|
||||
|
||||
g_dbus_node_info_set (data,
|
||||
@ -1315,14 +1313,12 @@ parser_start_element (GMarkupParseContext *context,
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (!g_markup_collect_attributes (element_name,
|
||||
attribute_names,
|
||||
attribute_values,
|
||||
error,
|
||||
G_MARKUP_COLLECT_STRING, "name", &name,
|
||||
/* seen in the wild */
|
||||
G_MARKUP_COLLECT_STRING | G_MARKUP_COLLECT_OPTIONAL, "version", NULL,
|
||||
G_MARKUP_COLLECT_INVALID))
|
||||
if (!g_markup_collect_known_attributes (element_name,
|
||||
attribute_names,
|
||||
attribute_values,
|
||||
error,
|
||||
G_MARKUP_COLLECT_STRING, "name", &name,
|
||||
G_MARKUP_COLLECT_INVALID))
|
||||
goto out;
|
||||
|
||||
g_dbus_interface_info_set (data,
|
||||
@ -1346,14 +1342,12 @@ parser_start_element (GMarkupParseContext *context,
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (!g_markup_collect_attributes (element_name,
|
||||
attribute_names,
|
||||
attribute_values,
|
||||
error,
|
||||
G_MARKUP_COLLECT_STRING, "name", &name,
|
||||
/* seen in the wild */
|
||||
G_MARKUP_COLLECT_STRING | G_MARKUP_COLLECT_OPTIONAL, "version", NULL,
|
||||
G_MARKUP_COLLECT_INVALID))
|
||||
if (!g_markup_collect_known_attributes (element_name,
|
||||
attribute_names,
|
||||
attribute_values,
|
||||
error,
|
||||
G_MARKUP_COLLECT_STRING, "name", &name,
|
||||
G_MARKUP_COLLECT_INVALID))
|
||||
goto out;
|
||||
|
||||
g_dbus_method_info_set (data,
|
||||
@ -1378,12 +1372,12 @@ parser_start_element (GMarkupParseContext *context,
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (!g_markup_collect_attributes (element_name,
|
||||
attribute_names,
|
||||
attribute_values,
|
||||
error,
|
||||
G_MARKUP_COLLECT_STRING, "name", &name,
|
||||
G_MARKUP_COLLECT_INVALID))
|
||||
if (!g_markup_collect_known_attributes (element_name,
|
||||
attribute_names,
|
||||
attribute_values,
|
||||
error,
|
||||
G_MARKUP_COLLECT_STRING, "name", &name,
|
||||
G_MARKUP_COLLECT_INVALID))
|
||||
goto out;
|
||||
|
||||
g_dbus_signal_info_set (data,
|
||||
@ -1409,14 +1403,14 @@ parser_start_element (GMarkupParseContext *context,
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (!g_markup_collect_attributes (element_name,
|
||||
attribute_names,
|
||||
attribute_values,
|
||||
error,
|
||||
G_MARKUP_COLLECT_STRING, "name", &name,
|
||||
G_MARKUP_COLLECT_STRING, "type", &type,
|
||||
G_MARKUP_COLLECT_STRING, "access", &access,
|
||||
G_MARKUP_COLLECT_INVALID))
|
||||
if (!g_markup_collect_known_attributes (element_name,
|
||||
attribute_names,
|
||||
attribute_values,
|
||||
error,
|
||||
G_MARKUP_COLLECT_STRING, "name", &name,
|
||||
G_MARKUP_COLLECT_STRING, "type", &type,
|
||||
G_MARKUP_COLLECT_STRING, "access", &access,
|
||||
G_MARKUP_COLLECT_INVALID))
|
||||
goto out;
|
||||
|
||||
if (strcmp (access, "read") == 0)
|
||||
@ -1460,14 +1454,14 @@ parser_start_element (GMarkupParseContext *context,
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (!g_markup_collect_attributes (element_name,
|
||||
attribute_names,
|
||||
attribute_values,
|
||||
error,
|
||||
G_MARKUP_COLLECT_STRING | G_MARKUP_COLLECT_OPTIONAL, "name", &name,
|
||||
G_MARKUP_COLLECT_STRING | G_MARKUP_COLLECT_OPTIONAL, "direction", &direction,
|
||||
G_MARKUP_COLLECT_STRING, "type", &type,
|
||||
G_MARKUP_COLLECT_INVALID))
|
||||
if (!g_markup_collect_known_attributes (element_name,
|
||||
attribute_names,
|
||||
attribute_values,
|
||||
error,
|
||||
G_MARKUP_COLLECT_STRING | G_MARKUP_COLLECT_OPTIONAL, "name", &name,
|
||||
G_MARKUP_COLLECT_STRING | G_MARKUP_COLLECT_OPTIONAL, "direction", &direction,
|
||||
G_MARKUP_COLLECT_STRING, "type", &type,
|
||||
G_MARKUP_COLLECT_INVALID))
|
||||
goto out;
|
||||
|
||||
if (strcmp (stack->next->data, "method") == 0)
|
||||
@ -1547,13 +1541,13 @@ parser_start_element (GMarkupParseContext *context,
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (!g_markup_collect_attributes (element_name,
|
||||
attribute_names,
|
||||
attribute_values,
|
||||
error,
|
||||
G_MARKUP_COLLECT_STRING, "name", &name,
|
||||
G_MARKUP_COLLECT_STRING, "value", &value,
|
||||
G_MARKUP_COLLECT_INVALID))
|
||||
if (!g_markup_collect_known_attributes (element_name,
|
||||
attribute_names,
|
||||
attribute_values,
|
||||
error,
|
||||
G_MARKUP_COLLECT_STRING, "name", &name,
|
||||
G_MARKUP_COLLECT_STRING, "value", &value,
|
||||
G_MARKUP_COLLECT_INVALID))
|
||||
goto out;
|
||||
|
||||
g_dbus_annotation_info_set (data,
|
||||
|
Loading…
Reference in New Issue
Block a user