diff options
author | Rupinder Singh Khokhar <rsk1coder99@gmail.com> | 2014-07-04 08:57:10 +0530 |
---|---|---|
committer | Rupinder Singh Khokhar <rsk1coder99@gmail.com> | 2014-08-01 21:44:31 +0530 |
commit | ea324e5503e4a076d6aef68ce281e28a7ab06a32 (patch) | |
tree | 6bea3df388ccb12e2953045ab79e2b51d006281a /src/treebuilder/in_body.c | |
parent | 57abb7e471669e31e851743763774ddd6b7fafb4 (diff) | |
download | libhubbub-ea324e5503e4a076d6aef68ce281e28a7ab06a32.tar.gz libhubbub-ea324e5503e4a076d6aef68ce281e28a7ab06a32.tar.bz2 |
Fixing some steps in table insertion mode, handling input tags
Diffstat (limited to 'src/treebuilder/in_body.c')
-rw-r--r-- | src/treebuilder/in_body.c | 22 |
1 files changed, 21 insertions, 1 deletions
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) { |