diff options
-rw-r--r-- | Libraries/LibWeb/DOM/HTMLScriptElement.cpp | 62 | ||||
-rw-r--r-- | Libraries/LibWeb/DOM/HTMLScriptElement.h | 3 | ||||
-rw-r--r-- | Libraries/LibWeb/Parser/HTMLDocumentParser.cpp | 3 |
3 files changed, 3 insertions, 65 deletions
diff --git a/Libraries/LibWeb/DOM/HTMLScriptElement.cpp b/Libraries/LibWeb/DOM/HTMLScriptElement.cpp index 1aa2968fe6..e7552211b3 100644 --- a/Libraries/LibWeb/DOM/HTMLScriptElement.cpp +++ b/Libraries/LibWeb/DOM/HTMLScriptElement.cpp @@ -53,68 +53,6 @@ void HTMLScriptElement::set_non_blocking(Badge<HTMLDocumentParser>, bool non_blo m_non_blocking = non_blocking; } -void HTMLScriptElement::children_changed() -{ - HTMLElement::children_changed(); - - if (has_attribute(HTML::AttributeNames::src)) - return; - - StringBuilder builder; - for_each_child([&](auto& child) { - if (is<Text>(child)) - builder.append(to<Text>(child).text_content()); - }); - auto source = builder.to_string(); - if (source.is_empty()) - return; - - auto parser = JS::Parser(JS::Lexer(source)); - auto program = parser.parse_program(); - if (parser.has_errors()) { - parser.print_errors(); - return; - } - document().interpreter().run(document().interpreter().global_object(), *program); -} - -void HTMLScriptElement::inserted_into(Node& new_parent) -{ - HTMLElement::inserted_into(new_parent); - - auto src = attribute(HTML::AttributeNames::src); - if (src.is_null()) - return; - - URL src_url = document().complete_url(src); - if (src_url.protocol() == "file" && document().url().protocol() != src_url.protocol()) { - dbg() << "HTMLScriptElement: Forbidden to load " << src_url << " from " << document().url(); - return; - } - - String source; - ResourceLoader::the().load_sync(src_url, [&](auto& data, auto&) { - if (data.is_null()) { - dbg() << "HTMLScriptElement: Failed to load " << src; - return; - } - source = String::copy(data); - }); - if (source.is_empty()) { - dbg() << "HTMLScriptElement: No source to parse :("; - return; - } - - dbg() << "Parsing and running script from " << src_url; - auto parser = JS::Parser(JS::Lexer(source)); - auto program = parser.parse_program(); - if (parser.has_errors()) { - parser.print_errors(); - return; - } - document().interpreter().run(document().interpreter().global_object(), *program); -} - void HTMLScriptElement::execute_script() { auto parser = JS::Parser(JS::Lexer(m_script_source)); diff --git a/Libraries/LibWeb/DOM/HTMLScriptElement.h b/Libraries/LibWeb/DOM/HTMLScriptElement.h index 4c11556f38..9d89ecd812 100644 --- a/Libraries/LibWeb/DOM/HTMLScriptElement.h +++ b/Libraries/LibWeb/DOM/HTMLScriptElement.h @@ -36,9 +36,6 @@ public: HTMLScriptElement(Document&, const FlyString& tag_name); virtual ~HTMLScriptElement() override; - virtual void inserted_into(Node&) override; - virtual void children_changed() override; - bool is_non_blocking() const { return m_non_blocking; } bool is_ready_to_be_parser_executed() const { return m_ready_to_be_parser_executed; } bool failed_to_load() const { return m_failed_to_load; } diff --git a/Libraries/LibWeb/Parser/HTMLDocumentParser.cpp b/Libraries/LibWeb/Parser/HTMLDocumentParser.cpp index f8fed2ca5c..1c316e0d41 100644 --- a/Libraries/LibWeb/Parser/HTMLDocumentParser.cpp +++ b/Libraries/LibWeb/Parser/HTMLDocumentParser.cpp @@ -1637,6 +1637,9 @@ void HTMLDocumentParser::handle_text(HTMLToken& token) return; } if (token.is_end_tag() && token.tag_name() == HTML::TagNames::script) { + // Make sure the <script> element has up-to-date text content before preparing the script. + flush_character_insertions(); + NonnullRefPtr<HTMLScriptElement> script = to<HTMLScriptElement>(current_node()); m_stack_of_open_elements.pop(); m_insertion_mode = m_original_insertion_mode; |