From ea324e5503e4a076d6aef68ce281e28a7ab06a32 Mon Sep 17 00:00:00 2001 From: Rupinder Singh Khokhar Date: Fri, 4 Jul 2014 08:57:10 +0530 Subject: Fixing some steps in table insertion mode, handling input tags --- src/treebuilder/in_body.c | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) (limited to 'src/treebuilder/in_body.c') diff --git a/src/treebuilder/in_body.c b/src/treebuilder/in_body.c index c9d1780..69ec3d6 100644 --- a/src/treebuilder/in_body.c +++ b/src/treebuilder/in_body.c @@ -12,6 +12,7 @@ #include "treebuilder/internal.h" #include "treebuilder/treebuilder.h" #include "utils/utils.h" +#include "utils/string.h" #undef DEBUG_IN_BODY @@ -337,8 +338,27 @@ hubbub_error process_start_tag(hubbub_treebuilder *treebuilder, return err; err = insert_element(treebuilder, &token->data.tag, false); - if (err == HUBBUB_OK) + if (err != HUBBUB_OK) + return err; + + size_t i; + bool found = 0; + + for (i = 0; i < token->data.tag.n_attributes; i++) { + hubbub_attribute *attr = &token->data.tag.attributes[i]; + + if (hubbub_string_match_ci(attr->name.ptr, attr->name.len, + (uint8_t *) "type", SLEN("type")) && + hubbub_string_match_ci(attr->value.ptr, attr->value.len, + (uint8_t *) "hidden", SLEN("hidden"))) { + found = 1; + break; + } + } + + if(!found) { treebuilder->context.frameset_ok = false; + } } else if (type == HR) { err = process_hr_in_body(treebuilder, token); } else if (type == IMAGE) { -- cgit v1.2.3