summaryrefslogtreecommitdiff
path: root/Userland/Libraries/LibWeb
diff options
context:
space:
mode:
authorAlexander <electrodeyt@gmail.com>2021-07-16 21:47:48 +0200
committerAli Mohammad Pur <Ali.mpfard@gmail.com>2021-07-17 01:48:04 +0430
commit459aa44f6bd38225a29d0e46ae5d0fd82dc5d04d (patch)
treeefcb380e57288b5ea9083365c3d116254f77c90d /Userland/Libraries/LibWeb
parent86c6e684315f1874db362cb2883e6a1eeb57c2dd (diff)
downloadserenity-459aa44f6bd38225a29d0e46ae5d0fd82dc5d04d.zip
LibWeb: Avoid UAF in query_selector{,_all}()
This fixes a bug that caused the selector to be dumped. It would relase the RefPtr into a dump function, and then use it.
Diffstat (limited to 'Userland/Libraries/LibWeb')
-rw-r--r--Userland/Libraries/LibWeb/DOM/ParentNode.cpp8
1 files changed, 4 insertions, 4 deletions
diff --git a/Userland/Libraries/LibWeb/DOM/ParentNode.cpp b/Userland/Libraries/LibWeb/DOM/ParentNode.cpp
index 447954e6b2..9a8ffdde32 100644
--- a/Userland/Libraries/LibWeb/DOM/ParentNode.cpp
+++ b/Userland/Libraries/LibWeb/DOM/ParentNode.cpp
@@ -17,11 +17,11 @@ RefPtr<Element> ParentNode::query_selector(const StringView& selector_text)
if (!selector)
return {};
- dump_selector(selector.release_nonnull());
+ dump_selector(*selector);
RefPtr<Element> result;
for_each_in_inclusive_subtree_of_type<Element>([&](auto& element) {
- if (SelectorEngine::matches(selector.release_nonnull(), element)) {
+ if (SelectorEngine::matches(*selector, element)) {
result = element;
return IterationDecision::Break;
}
@@ -37,11 +37,11 @@ NonnullRefPtrVector<Element> ParentNode::query_selector_all(const StringView& se
if (!selector)
return {};
- dump_selector(selector.release_nonnull());
+ dump_selector(*selector);
NonnullRefPtrVector<Element> elements;
for_each_in_inclusive_subtree_of_type<Element>([&](auto& element) {
- if (SelectorEngine::matches(selector.release_nonnull(), element)) {
+ if (SelectorEngine::matches(*selector, element)) {
elements.append(element);
}
return IterationDecision::Continue;