1
0
mirror of https://github.com/rkd77/elinks.git synced 2025-01-03 14:57:44 -05:00

Bug 1071: Fix null-ptr crash in get_dom_node_child

struct dom_node contains a union that contains various structs that
have members of type struct dom_node * in them.
get_dom_node_list_by_type returns the address (struct dom_node **) of
one of those members, or NULL.  However the member itself can also be
NULL if no nodes have been added to the list and the list has thus not
yet been allocated.  (add_to_dom_node_list lazily allocates the lists.)
get_dom_node_child did not expect a null pointer there and crashed, as
shown in bug 1071.  Fix by adding a check so that it treats a NULL list
as an empty list.
This commit is contained in:
Kalle Olavi Niemitalo 2009-04-04 21:56:53 +03:00 committed by Kalle Olavi Niemitalo
parent 22fe77d14f
commit 8465b19d0c

View File

@ -295,7 +295,8 @@ get_dom_node_child(struct dom_node *parent, enum dom_node_type type,
int index; int index;
list = get_dom_node_list_by_type(parent, type); list = get_dom_node_list_by_type(parent, type);
if (!list) return NULL; if (!list) return NULL; /* parent doesn't support this type */
if (!*list) return NULL; /* list is empty and not yet allocated */
foreach_dom_node (*list, node, index) { foreach_dom_node (*list, node, index) {
if (node->type != type) if (node->type != type)