diff options
author | dec05eba <dec05eba@protonmail.com> | 2021-07-19 18:25:31 +0200 |
---|---|---|
committer | dec05eba <dec05eba@protonmail.com> | 2021-07-19 18:25:31 +0200 |
commit | 8d40850ffd52100aa51f9dc7814cc7b334381c32 (patch) | |
tree | 67c81a126ea02aed90ed7b5a33cf10df0fe4840a /src | |
parent | 11d3632fe4508bfd2f668b7b1c4d75a88cd6449d (diff) |
Fix script tag not getting closed until the end
Diffstat (limited to 'src')
-rw-r--r-- | src/HtmlParser.c | 31 |
1 files changed, 23 insertions, 8 deletions
diff --git a/src/HtmlParser.c b/src/HtmlParser.c index a760f98..8a595ac 100644 --- a/src/HtmlParser.c +++ b/src/HtmlParser.c @@ -26,9 +26,9 @@ static HtmlStringView void_tags[] = { static HtmlStringView script_tag = {"script", 6}; -static char to_lower(char c) { - if(c >= 'A' && c <= 'Z') - return c + 32; +static char to_upper(char c) { + if(c >= 'a' && c <= 'z') + return c - 32; else return c; } @@ -37,7 +37,7 @@ static int string_view_equals_case_insensitive(HtmlStringView *self, HtmlStringV size_t i = 0; if(self->size != other->size) return 0; for(; i < self->size; ++i) { - if(to_lower(self->data[i]) != to_lower(other->data[i])) + if(to_upper(self->data[i]) != to_upper(other->data[i])) return 0; } return 1; @@ -103,6 +103,12 @@ static int is_void_tag(HtmlStringView *tag_name) { } static void html_parser_init(HtmlParser *self, const char *html_source, size_t len, HtmlParseCallback parse_callback, void *userdata) { + /* Utf8 BOM */ + if(len >= 3 && memcmp(html_source, "\xef\xbb\xbf", 3) == 0) { + html_source += 3; + len -= 3; + } + self->source = html_source; self->source_len = len; self->parse_callback = parse_callback; @@ -268,6 +274,7 @@ static void html_parser_goto_end_of_js_string(HtmlParser *self, char quote_symbo } static int html_parser_goto_script_end_tag(HtmlParser *self) { + int res = 0; self->text.data = self->source + self->offset; self->text.size = 0; for(;;) { @@ -300,10 +307,18 @@ static int html_parser_goto_script_end_tag(HtmlParser *self) { } } - if(self->text_stripped.size > 0) - return self->parse_callback(self, HTML_PARSE_JAVASCRIPT_CODE, self->callback_userdata); - else - return 0; + if(self->text_stripped.size > 0) { + res = self->parse_callback(self, HTML_PARSE_JAVASCRIPT_CODE, self->callback_userdata); + if(res != 0) + return res; + } + + res = self->parse_callback(self, HTML_PARSE_TAG_END, self->callback_userdata); + if(res != 0) + return res; + + html_parser_try_pop_unclosed_tag(self); + return res; } static void html_parser_goto_comment_end(HtmlParser *self) { |