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

Prospone pushing of DOM nodes on the stack until they are fully initialized

Goes for both attributes and elements.
This commit is contained in:
Jonas Fonseca 2005-12-05 10:26:55 +01:00 committed by Jonas Fonseca
parent 9dd84f8248
commit cc416b2234

View File

@ -46,18 +46,22 @@ add_sgml_element(struct dom_stack *stack, struct scanner_token *token)
struct dom_stack_state *state; struct dom_stack_state *state;
struct sgml_parser_state *pstate; struct sgml_parser_state *pstate;
struct dom_node *node; struct dom_node *node;
struct sgml_node_info *node_info;
node = add_dom_element(parent, token->string, token->length); node = add_dom_element(parent, token->string, token->length);
if (!node) return NULL;
if (!node || !push_dom_node(stack, node)) node_info = get_sgml_node_info(parser->info->elements, node);
node->data.element.type = node_info->type;
if (!push_dom_node(stack, node))
return NULL; return NULL;
state = get_dom_stack_top(stack); state = get_dom_stack_top(stack);
assert(node == state->node && state->data); assert(node == state->node && state->data);
pstate = state->data; pstate = state->data;
pstate->info = get_sgml_node_info(parser->info->elements, node); pstate->info = node_info;
node->data.element.type = pstate->info->type;
return node; return node;
} }
@ -77,9 +81,6 @@ add_sgml_attribute(struct dom_stack *stack,
node = add_dom_attribute(parent, token->string, token->length, node = add_dom_attribute(parent, token->string, token->length,
value, valuelen); value, valuelen);
if (!node || !push_dom_node(stack, node))
return;
info = get_sgml_node_info(parser->info->attributes, node); info = get_sgml_node_info(parser->info->attributes, node);
node->data.attribute.type = info->type; node->data.attribute.type = info->type;
@ -89,6 +90,9 @@ add_sgml_attribute(struct dom_stack *stack,
if (valtoken && valtoken->type == SGML_TOKEN_STRING) if (valtoken && valtoken->type == SGML_TOKEN_STRING)
node->data.attribute.quoted = 1; node->data.attribute.quoted = 1;
if (!node || !push_dom_node(stack, node))
return;
pop_dom_node(stack); pop_dom_node(stack);
} }